:root{--primary: #5f7d16;--primary-light: #7b9c29;--primary-dark: #49610d;--primary-50: rgba(95, 125, 22, .05);--primary-100: rgba(95, 125, 22, .1);--primary-200: rgba(95, 125, 22, .2);--secondary: #f97316;--secondary-light: #fb923c;--secondary-dark: #ea6a0a;--accent: #5f7d16;--accent-light: #7b9c29;--accent-dark: #49610d;--success: #5f7d16;--success-light: #7b9c29;--success-bg: rgba(95, 125, 22, .1);--warning: #F59E0B;--warning-light: #FFD37A;--warning-bg: rgba(245, 158, 11, .1);--danger: #DC2626;--danger-light: #FF8A8A;--danger-bg: rgba(220, 38, 38, .1);--info: #5f7d16;--info-light: #7b9c29;--info-bg: rgba(95, 125, 22, .1);--purple: #A78BFA;--purple-light: #C4B5FD;--purple-bg: rgba(167, 139, 250, .1);--bg-base: #040506;--bg-surface: #090b0f;--bg-elevated: #0e1014;--bg-hover: #13161c;--bg-glass: #090b0f;--bg-glass-light: #0e1014;--bg-glass-dark: #06080b;--text-primary: #f4f7fb;--text-secondary: rgba(244, 247, 251, .72);--text-muted: rgba(244, 247, 251, .45);--text-disabled: rgba(244, 247, 251, .2);--border-subtle: rgba(255, 255, 255, .04);--border-default: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--border-focus: rgba(95, 125, 22, .4);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 6px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .55);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px rgba(95, 125, 22, .15);--shadow-glow-strong: 0 0 40px rgba(95, 125, 22, .25);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-xs: var(--space-1);--space-sm: var(--space-2);--space-md: var(--space-4);--space-lg: var(--space-6);--space-xl: var(--space-8);--space-2xl: var(--space-12);--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .35s;--duration-slower: .5s;--transition-fast: var(--duration-fast) var(--ease-default);--transition-base: var(--duration-base) var(--ease-default);--transition-slow: var(--duration-slow) var(--ease-default);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--sidebar-width: 280px;--sidebar-width-collapsed: 80px;--header-height: 72px;--content-max-width: 1400px;--mobile-nav-height: 72px;--color-bg: var(--bg-base);--color-surface: var(--bg-surface);--color-surface-hover: var(--bg-hover);--color-border: var(--border-default);--color-text: var(--text-primary);--color-text-secondary: var(--text-secondary);--color-text-muted: var(--text-muted);--color-primary: var(--primary);--color-primary-hover: var(--primary-dark);--color-success: var(--success);--color-error: var(--danger);--color-warning: var(--warning);--transition-normal: var(--transition-base);--bg-primary: var(--bg-base);--surface: var(--bg-surface);--surface-hover: var(--bg-hover);--border: var(--border-default);--text-inverse: #ffffff;--spacing-0: var(--space-0);--spacing-1: var(--space-1);--spacing-2: var(--space-2);--spacing-3: var(--space-3);--spacing-4: var(--space-4);--spacing-5: var(--space-5);--spacing-6: var(--space-6);--spacing-8: var(--space-8);--spacing-10: var(--space-10);--spacing-12: var(--space-12);--spacing-16: var(--space-16);--gradient-accent: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);--gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);--shadow-accent-sm: 0 2px 6px rgba(95, 125, 22, .15);--shadow-accent-md: 0 4px 12px rgba(95, 125, 22, .18);--shadow-accent-lg: 0 8px 20px rgba(95, 125, 22, .2)}[data-theme=light]{--bg-base: #f3f6fb;--bg-surface: #ffffff;--bg-elevated: #eef2f7;--bg-hover: #e5ebf3;--bg-glass: rgba(255, 255, 255, .88);--bg-glass-light: #f8fafc;--bg-glass-dark: #e7edf5;--text-primary: #16202c;--text-secondary: #475569;--text-muted: #6b7a90;--text-disabled: #9aa7ba;--border-subtle: rgba(15, 23, 42, .06);--border-default: rgba(15, 23, 42, .1);--border-strong: rgba(15, 23, 42, .16);--border-focus: rgba(95, 125, 22, .35);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);--shadow-md: 0 12px 30px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 44px rgba(15, 23, 42, .1);--shadow-xl: 0 28px 70px rgba(15, 23, 42, .12);--shadow-glow: none;--shadow-glow-strong: none;--text-inverse: #16202c}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;height:100%;scroll-behavior:smooth;overflow-x:hidden;overflow-y:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);background:radial-gradient(circle at top left,rgba(95,125,22,.1),transparent 30%),radial-gradient(circle at top right,rgba(249,115,22,.12),transparent 26%),var(--bg-base);color:var(--text-primary);line-height:var(--leading-normal);height:100%;min-height:100%;overflow-x:hidden;overflow-y:auto}body:before{display:none}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-light)}button{font-family:inherit;cursor:pointer;border:none;background:none}img{max-width:100%;height:auto;display:block}::-moz-selection{background:var(--primary);color:#fff}::selection{background:var(--primary);color:#fff}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-full);-webkit-transition:background var(--transition-fast);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--primary)}*{scrollbar-width:thin;scrollbar-color:var(--bg-elevated) var(--bg-surface)}.main-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);height:64px;display:flex;align-items:center;padding:0 1.5rem;transition:box-shadow var(--transition-base)}.main-header.scrolled{box-shadow:var(--shadow-sm)}.header-container{width:100%;max-width:1800px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.header-logo{display:flex;align-items:center;gap:.625rem;text-decoration:none;flex-shrink:0}.header-logo-icon{width:36px;height:36px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast)}.header-logo:hover .header-logo-icon{transform:scale(1.05)}.header-logo-icon svg{width:20px;height:20px;fill:none;stroke:#fff}.header-logo-img{height:72px;width:auto;display:block;-o-object-fit:contain;object-fit:contain}.header-logo-text{font-size:1.3rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.header-thesis-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.45rem .8rem;border-radius:999px;border:1px solid rgba(245,158,11,.24);background:linear-gradient(135deg,#f59e0b1f,#f59e0b0d);color:#fbbf24;box-shadow:0 12px 30px #0f172a2e;white-space:nowrap;flex-shrink:0;position:relative;cursor:help;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.header-thesis-badge svg{width:16px;height:16px;flex-shrink:0}.header-thesis-badge__label{font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.header-thesis-badge:hover,.header-thesis-badge:focus-visible{transform:translateY(-1px);border-color:#fbbf2466;box-shadow:0 18px 34px #0f172a3d;outline:none}.header-thesis-badge__tooltip{position:absolute;top:calc(100% + .85rem);left:0;display:grid;gap:.45rem;width:min(320px,calc(100vw - 3rem));padding:.95rem 1rem;border-radius:20px;border:1px solid rgba(245,158,11,.32);background:linear-gradient(180deg,#11121efa,#0c0d18fa);box-shadow:0 24px 60px #0006;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px) scale(.98);transform-origin:top left;transition:opacity var(--transition-fast),transform var(--transition-fast),visibility var(--transition-fast);z-index:1200;white-space:normal}.header-thesis-badge__tooltip:before{content:"";position:absolute;top:-7px;left:1.1rem;width:12px;height:12px;border-top:1px solid rgba(245,158,11,.32);border-left:1px solid rgba(245,158,11,.32);background:#11121efa;transform:rotate(45deg)}.header-thesis-badge__tooltip strong{font-size:.96rem;font-weight:800;color:#fbbf24;letter-spacing:.01em}.header-thesis-badge__tooltip span{font-size:.9rem;line-height:1.5;color:#f4f7fbe0}.header-thesis-badge:hover .header-thesis-badge__tooltip,.header-thesis-badge:focus-visible .header-thesis-badge__tooltip,.header-thesis-badge:focus-within .header-thesis-badge__tooltip,.header-thesis-badge.is-open .header-thesis-badge__tooltip{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.header-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}@keyframes header-nav-item-enter{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.nav-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;color:var(--text-secondary);text-decoration:none;font-size:.8125rem;font-weight:500;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);position:relative;white-space:nowrap;transform:translateY(0);animation:header-nav-item-enter .42s cubic-bezier(.22,1,.36,1) both}.header-nav .nav-item:nth-child(1){animation-delay:.02s}.header-nav .nav-item:nth-child(2){animation-delay:.05s}.header-nav .nav-item:nth-child(3){animation-delay:.08s}.header-nav .nav-item:nth-child(4){animation-delay:.11s}.header-nav .nav-item:nth-child(5){animation-delay:.14s}.header-nav .nav-item:nth-child(6){animation-delay:.17s}.header-nav .nav-item:nth-child(7){animation-delay:.2s}.header-nav .nav-item:nth-child(8){animation-delay:.23s}.header-nav .nav-item:nth-child(9){animation-delay:.26s}.header-nav .nav-item:nth-child(10){animation-delay:.29s}.header-nav .nav-item:nth-child(11){animation-delay:.32s}.header-nav .nav-item:nth-child(12){animation-delay:.35s}.nav-item svg{width:18px;height:18px;fill:none;stroke:currentColor;opacity:.7;transition:opacity var(--transition-fast),transform var(--transition-fast)}.nav-item span{transition:color var(--transition-fast),transform var(--transition-fast)}.nav-item:after{content:"";position:absolute;bottom:-1px;left:50%;width:20px;height:2px;border-radius:999px;background:currentColor;opacity:0;transform:translate(-50%) scaleX(.35);transition:transform var(--transition-fast),opacity var(--transition-fast),background-color var(--transition-fast)}.nav-item:hover{color:var(--text-primary);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1a}.nav-item:hover svg{opacity:1;transform:translateY(-1px) scale(1.06)}.nav-item:hover:after,.nav-item:focus-visible:after,.nav-item.active:after{opacity:1;transform:translate(-50%) scaleX(1)}.nav-item.active{color:var(--primary);background:var(--primary-50);transform:translateY(-2px)}.nav-item.active svg{opacity:1;transform:translateY(-1px) scale(1.08)}.header-actions{display:flex;align-items:center;gap:.5rem}.header-icon-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.header-icon-btn svg{width:20px;height:20px;fill:currentColor}.header-icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.header-icon-btn .badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:var(--primary);color:#fff;font-size:.625rem;font-weight:600;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;padding:0 4px}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.625rem;padding:.25rem .5rem .25rem .25rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.user-menu-trigger:hover{background:var(--bg-elevated);border-color:var(--border-default)}.user-menu-avatar{width:36px;height:36px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-subtle)}.user-menu-info{text-align:left;display:none}@media(min-width:1200px){.user-menu-info{display:block}}.user-menu-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);line-height:1.2}.user-menu-role{font-size:.75rem;color:var(--text-muted)}.user-menu-arrow{width:14px;height:14px;fill:var(--text-muted);transition:transform var(--transition-fast)}.user-menu.open .user-menu-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .25s ease;box-shadow:var(--shadow-lg);overflow:hidden}.user-menu.open .user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.user-dropdown-header{display:flex;align-items:center;gap:.875rem;padding:1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle)}.user-dropdown-avatar{width:44px;height:44px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-subtle)}.user-dropdown-info{flex:1;min-width:0}.user-dropdown-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-email{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-body{padding:.375rem}.user-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .875rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left}.user-dropdown-item svg{width:18px;height:18px;fill:currentColor;opacity:.6}.user-dropdown-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.user-dropdown-item:hover svg{opacity:1}.user-dropdown-item.danger{color:var(--danger)}.user-dropdown-item.danger:hover{background:var(--danger-bg)}.user-dropdown-divider{height:1px;background:var(--border-subtle);margin:.375rem 0}.mobile-menu-btn{display:none;width:40px;height:40px;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer}.mobile-menu-btn svg{width:22px;height:22px;fill:currentColor}@media(max-width:1200px){.header-nav{display:none}.mobile-menu-btn{display:flex}}@media(max-width:900px){.header-thesis-badge{padding:.4rem .65rem}.header-thesis-badge__label{font-size:.62rem;letter-spacing:.06em}.header-thesis-badge__tooltip{width:min(280px,calc(100vw - 2rem))}}@media(max-width:640px){.main-header{padding:0 1rem}.header-logo-text{display:none}.header-thesis-badge{gap:.35rem;padding:.45rem .65rem;min-height:38px;transform:none}.header-thesis-badge:hover,.header-thesis-badge:focus-visible,.header-thesis-badge.is-open{transform:none;box-shadow:0 14px 28px #0f172a2e}.header-thesis-badge__label{display:inline;font-size:.6rem;letter-spacing:.05em}.header-thesis-badge__tooltip{position:fixed;top:calc(64px + env(safe-area-inset-top) + .6rem);left:50%;right:auto;width:min(320px,calc(100vw - 2rem));min-width:min(320px,calc(100vw - 2rem));max-width:calc(100vw - 2rem);box-sizing:border-box;transform-origin:top center;padding:.9rem .95rem;white-space:normal;word-break:normal;overflow-wrap:break-word;transform:translate(-50%) translateY(-8px) scale(.98)}.header-thesis-badge:hover .header-thesis-badge__tooltip,.header-thesis-badge:focus-visible .header-thesis-badge__tooltip,.header-thesis-badge:focus-within .header-thesis-badge__tooltip,.header-thesis-badge.is-open .header-thesis-badge__tooltip{transform:translate(-50%) translateY(0) scale(1)}.header-thesis-badge__tooltip:before{display:none}.header-thesis-badge__tooltip strong{font-size:.9rem}.header-thesis-badge__tooltip span{display:block;font-size:.84rem;line-height:1.45}}.main-content{padding:80px var(--space-8) var(--space-8);min-height:100vh}.content-wrapper{max-width:1400px;margin:0 auto;padding:2rem;overflow-x:hidden}@media(max-width:768px){.content-wrapper{padding:0}}@media(max-width:480px){.content-wrapper{padding:0}}[data-theme=light] .main-header{background:var(--bg-surface);border-bottom-color:var(--border-subtle)}[data-theme=light] .main-header.scrolled{box-shadow:var(--shadow-sm)}[data-theme=light] .header-thesis-badge{border-color:#d977063d;background:linear-gradient(135deg,#f59e0b24,#fbbf240f);color:#b45309;box-shadow:0 14px 30px #0f172a14}[data-theme=light] .header-thesis-badge:hover,[data-theme=light] .header-thesis-badge:focus-visible{border-color:#b4530957;box-shadow:0 18px 32px #0f172a1f}[data-theme=light] .header-thesis-badge__tooltip{border-color:#b4530938;background:linear-gradient(180deg,#fffcf5fa,#fff8ebfa);box-shadow:0 20px 44px #0f172a1f}[data-theme=light] .header-thesis-badge__tooltip:before{border-top-color:#b4530938;border-left-color:#b4530938;background:#fffcf5fa}[data-theme=light] .header-thesis-badge__tooltip strong{color:#b45309}[data-theme=light] .header-thesis-badge__tooltip span{color:#4b5563}[data-theme=light] .nav-item.active{color:#1e3a8a;background:#2563eb1a}[data-theme=light] .nav-item.active svg{opacity:1}[data-theme=light] .nav-item.active:after{background:#2563eb}[data-theme=light] .nav-item.active:hover{color:#1e40af;background:#2563eb24}@media(prefers-reduced-motion:reduce){.header-nav .nav-item{animation:none}.nav-item,.nav-item svg,.nav-item span,.nav-item:after{transition:none}}.guest-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#0a0a0a,#141414,#0a0a0a)}.guest-card{width:100%;max-width:28rem;padding:2rem;background:#1f1f1f;border:1px solid #2a2a2a;border-radius:1rem;box-shadow:0 25px 50px -12px #00000080}.guest-logo{display:flex;justify-content:center;margin-bottom:1.5rem}.guest-logo a{color:#5f7d16;font-size:2rem;font-weight:700;text-decoration:none}.text-gray-600,.text-gray-400{color:#a1a1aa!important}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:var(--z-fixed);transition:transform var(--transition-base)}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--border-subtle)}.logo{display:flex;align-items:center;gap:var(--space-4)}.logo-icon{width:44px;height:44px;background:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.logo-icon:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.logo-icon svg{width:24px;height:24px;fill:#fff}.logo-text{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:var(--space-2) var(--space-4);margin-bottom:var(--space-1)}.nav-link{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:var(--font-medium);font-size:var(--text-sm);transition:all var(--transition-fast);margin-bottom:var(--space-1);position:relative;overflow:hidden}.nav-link:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--primary);transform:scaleY(0);transition:transform var(--transition-fast);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.nav-link:hover{background:var(--bg-glass-light);color:var(--text-primary)}.nav-link:hover svg{fill:var(--primary-light)}.nav-link.active{background:var(--primary-100);color:var(--text-primary)}.nav-link.active:before{transform:scaleY(1)}.nav-link.active svg{fill:var(--primary-light)}.nav-link svg{width:20px;height:20px;fill:var(--text-muted);flex-shrink:0;transition:fill var(--transition-fast)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border-subtle)}.user-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-glass-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative}.user-card:hover{background:var(--bg-elevated)}.user-avatar{width:42px;height:42px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--primary)}.user-info{flex:1;min-width:0}.user-name{font-weight:var(--font-semibold);font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--text-xs);color:var(--text-muted)}.user-menu-icon{width:20px;height:20px;fill:var(--text-muted);transition:transform var(--transition-fast)}.user-card[aria-expanded=true] .user-menu-icon{transform:rotate(180deg)}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);width:100%;text-align:left}.dropdown-item:hover{background:var(--bg-glass-light);color:var(--text-primary)}.dropdown-item svg{width:18px;height:18px;fill:currentColor}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-bg)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:calc(var(--z-fixed) - 1);opacity:0;transition:opacity var(--transition-base);pointer-events:none}.sidebar-overlay.active{opacity:1;pointer-events:auto}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#0f0f0ffa;border-top:1px solid rgba(255,255,255,.06);padding:.5rem .75rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.layout-mobile-nav-hidden .mobile-bottom-nav{display:none!important}.layout-mobile-nav-hidden .main-content.main-content--mobile-flush{padding-bottom:0!important}@media(max-width:768px){.mobile-bottom-nav{display:block}.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom))}}.mobile-nav-items{display:flex;align-items:center;justify-content:space-around;gap:.25rem}@keyframes mobile-nav-item-enter{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .75rem;min-width:60px;text-decoration:none;color:var(--text-muted);border-radius:12px;position:relative;overflow:hidden;transform:translateY(0);transition:color .2s ease,background-color .2s ease,transform .2s ease,box-shadow .2s ease;animation:mobile-nav-item-enter .4s cubic-bezier(.22,1,.36,1) both}.mobile-nav-item:nth-child(1){animation-delay:.02s}.mobile-nav-item:nth-child(2){animation-delay:.06s}.mobile-nav-item:nth-child(3){animation-delay:.1s}.mobile-nav-item:nth-child(4){animation-delay:.14s}.mobile-nav-item:nth-child(5){animation-delay:.18s}.mobile-nav-item svg{width:24px;height:24px;fill:none;stroke:currentColor;transition:transform .2s ease,opacity .2s ease}.mobile-nav-item span{font-size:.6875rem;font-weight:500}.mobile-nav-item:after{content:"";position:absolute;left:50%;bottom:0;width:18px;height:2px;border-radius:999px;background:currentColor;opacity:0;transform:translate(-50%) scaleX(.4);transition:transform .2s ease,opacity .2s ease}.mobile-nav-item:hover{transform:translateY(-2px);background:#ffffff0d}.mobile-nav-item:hover svg{transform:translateY(-1px) scale(1.05)}.mobile-nav-item:hover:after,.mobile-nav-item.active:after{opacity:1;transform:translate(-50%) scaleX(1)}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:var(--primary);transform:translateY(-2px)}.mobile-nav-item.active svg{transform:translateY(-1px) scale(1.1)}[data-theme=light] .mobile-nav-item.active{color:#1e3a8a;background:#2563eb1a}.mobile-menu-overlay{display:none;position:fixed;inset:0;z-index:999;background:#0009;opacity:0;visibility:hidden;transition:all .3s ease}.mobile-menu-overlay.open{opacity:1;visibility:visible}@media(max-width:1024px){.mobile-menu-overlay{display:block}}.mobile-menu-panel{position:fixed;top:0;left:0;bottom:0;z-index:1001;width:300px;max-width:85vw;background:var(--bg-surface);border-right:1px solid rgba(255,255,255,.06);transform:translate(-100%);transition:transform .3s ease;overflow-y:auto;display:none}@media(max-width:1024px){.mobile-menu-panel{display:block}}.mobile-menu-panel.open{transform:translate(0)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.mobile-menu-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.mobile-menu-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center}.mobile-menu-logo-icon svg{width:24px;height:24px;fill:none;stroke:#fff}.mobile-menu-logo-text{font-size:1.25rem;font-weight:700;color:var(--primary)}.mobile-menu-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer}.mobile-menu-close svg{width:24px;height:24px;fill:currentColor}.mobile-menu-body{padding:1rem 0}.mobile-menu-section{margin-bottom:1rem}.mobile-menu-section-title{padding:.5rem 1.25rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.mobile-menu-link{display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;color:var(--text-secondary);text-decoration:none;font-size:.9375rem;font-weight:500;transform:translate(0);transition:color .18s ease,background-color .18s ease,transform .18s ease}.mobile-menu-link svg{width:22px;height:22px;fill:none;stroke:currentColor;opacity:.7;transition:opacity .18s ease,transform .18s ease,stroke .18s ease}.mobile-menu-link:hover,.mobile-menu-link.active{color:var(--primary);background:#5f7d161a;transform:translate(6px)}.mobile-menu-link:hover svg,.mobile-menu-link.active svg{opacity:1;stroke:var(--primary);transform:translate(2px) scale(1.05)}.mobile-menu-footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}.mobile-user-card{display:flex;align-items:center;gap:.875rem;padding:.75rem;background:#ffffff08;border-radius:12px;text-decoration:none}.mobile-user-avatar{width:44px;height:44px;border-radius:10px;-o-object-fit:cover;object-fit:cover}.mobile-user-info{flex:1;min-width:0}.mobile-user-name{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.mobile-user-email{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(prefers-reduced-motion:reduce){.mobile-nav-item{animation:none}.mobile-nav-item,.mobile-nav-item svg,.mobile-nav-item:after,.mobile-menu-link,.mobile-menu-link svg{transition:none}}.site-footer{width:100%;margin:0;padding:1.9rem 0 calc(1.6rem + env(safe-area-inset-bottom));background:#000;border-top:1px solid rgba(255,255,255,.08)}.site-footer__container{max-width:1380px;margin:0 auto;padding:0 2rem}.site-footer__main{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:2rem;align-items:end}.site-footer__brand{display:grid;gap:.9rem;max-width:34rem}.site-footer__logo{display:inline-flex;align-items:center;text-decoration:none}.site-footer__logo-img{display:block;width:auto;height:64px}.site-footer__copy{margin:0;color:#f4f7fb99;font-size:.96rem;line-height:1.7}.site-footer__nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:2.5rem}.site-footer__group{display:grid;gap:.65rem;min-width:8.5rem}.site-footer__title{color:#f4f7fb6b;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.site-footer__links{display:flex;flex-direction:column;align-items:flex-start;gap:.55rem}.site-footer__links a{color:#f4f7fbb8;text-decoration:none;font-size:.95rem;transition:color .2s ease,opacity .2s ease}.site-footer__links a:hover{color:#fff}.site-footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08);color:#f4f7fb85;font-size:.84rem}.site-footer__bottom-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.8rem 1.2rem}.site-footer__bottom-links a{color:#f4f7fb9e;text-decoration:none;transition:color .2s ease}.site-footer__bottom-links a:hover{color:#fff}@media(max-width:1200px){.site-footer__main{grid-template-columns:1fr;align-items:start}.site-footer__nav{justify-content:flex-start}}@media(max-width:900px){.site-footer{padding-top:2rem}.site-footer__container{padding:0 1rem}.site-footer__nav,.site-footer__bottom,.site-footer__bottom-links{flex-direction:column;align-items:flex-start}.site-footer__nav{gap:1.25rem}.site-footer--with-mobile-nav{padding-bottom:calc(6.4rem + env(safe-area-inset-bottom))}}@media(max-width:992px){.site-footer{padding:1.4rem 0 calc(1.2rem + env(safe-area-inset-bottom))}.site-footer__container{padding:0 1rem}.site-footer__main{gap:1.1rem}.site-footer__brand{gap:.75rem;justify-items:start;text-align:left;max-width:none;padding-bottom:.95rem;border-bottom:1px solid rgba(255,255,255,.08)}.site-footer__logo{justify-content:flex-start}.site-footer__logo-img{height:50px}.site-footer__copy{font-size:.88rem;line-height:1.55;max-width:34rem}.site-footer__nav{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem 1rem;align-items:stretch}.site-footer__group{min-width:0;padding:.9rem 1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:14px;justify-items:start;text-align:left;gap:.55rem;align-content:start}.site-footer__group:last-child{grid-column:1 / -1}.site-footer__title{font-size:.68rem;letter-spacing:.12em}.site-footer__links{align-items:flex-start;gap:.45rem}.site-footer__links a{font-size:.9rem;line-height:1.35}.site-footer__bottom{margin-top:1rem;padding-top:.9rem;flex-direction:column;align-items:flex-start;text-align:left;gap:.7rem}.site-footer__bottom-links{width:100%;justify-content:flex-start;gap:.55rem .8rem}}@media(max-width:560px){.site-footer__container{padding:0 .9rem}.site-footer__nav{grid-template-columns:1fr}.site-footer__group{padding:.85rem .9rem}.site-footer__group:last-child{grid-column:auto}}.fl-page-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.fl-page-header__icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary-100);border:1px solid var(--primary-200);border-radius:var(--radius-xl);color:var(--primary);flex-shrink:0}.fl-page-header__icon--accent{background:#0ea5e91a;border-color:#0ea5e933;color:var(--accent)}.fl-page-header__icon--secondary{background:#f973161a;border-color:#f9731633;color:var(--secondary)}.fl-page-header__icon--warning{background:#f59e0b1a;border-color:#f59e0b33;color:var(--warning)}.fl-page-header__icon--danger{background:#ef44441a;border-color:#ef444433;color:var(--danger)}.fl-page-header__text h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight)}.fl-page-header__text p{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.fl-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.fl-card:hover{border-color:var(--border-default)}.fl-card__header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-5)}.fl-card__header-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-muted);flex-shrink:0}.fl-card__header-icon--primary{background:var(--primary-100);border-color:var(--primary-200);color:var(--primary)}.fl-card__header-icon--accent{background:#0ea5e91a;border-color:#0ea5e933;color:var(--accent)}.fl-card__header-icon--secondary{background:#f973161a;border-color:#f9731633;color:var(--secondary)}.fl-card__header-icon--warning{background:#f59e0b1a;border-color:#f59e0b33;color:var(--warning)}.fl-card__header-icon--danger{background:#ef44441a;border-color:#ef444433;color:var(--danger)}.fl-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);line-height:var(--leading-tight)}.fl-card__subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.fl-card__action{margin-left:auto;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary);white-space:nowrap;transition:color var(--transition-fast)}.fl-card__action:hover{color:var(--primary-light)}.fl-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:44px;padding:0 var(--space-6);font-family:inherit;font-size:var(--text-sm);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;line-height:1}.fl-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.fl-btn svg{width:18px;height:18px;flex-shrink:0}.fl-btn--sm{height:36px;padding:0 var(--space-4);font-size:var(--text-xs);border-radius:var(--radius-sm)}.fl-btn--lg{height:48px;padding:0 var(--space-8);font-size:var(--text-base);font-weight:var(--font-bold);border-radius:var(--radius-lg)}.fl-btn--primary{background:var(--primary);color:var(--bg-base)}.fl-btn--primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-accent-sm)}.fl-btn--accent{background:var(--accent);color:var(--bg-base)}.fl-btn--accent:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e94d}.fl-btn--secondary{background:var(--secondary);color:var(--bg-base)}.fl-btn--secondary:hover:not(:disabled){background:var(--secondary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #f973164d}.fl-btn--warning{background:var(--warning);color:var(--bg-base)}.fl-btn--warning:hover:not(:disabled){background:var(--warning);transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.fl-btn--danger{background:var(--danger);color:#fff}.fl-btn--danger:hover:not(:disabled){background:var(--danger-light);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.fl-btn--ghost{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle)}.fl-btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.fl-btn--outline-primary{background:transparent;color:var(--primary);border:1px solid var(--primary)}.fl-btn--outline-primary:hover:not(:disabled){background:var(--primary-100)}.fl-btn--outline-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.fl-btn--outline-danger:hover:not(:disabled){background:var(--danger-bg)}.fl-form__group{display:flex;flex-direction:column;gap:var(--space-2)}.fl-form__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.fl-form__label .fl-form__required{color:var(--danger);margin-left:2px}.fl-form__input,.fl-form__select,.fl-form__textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:var(--text-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.fl-form__input:focus,.fl-form__select:focus,.fl-form__textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.fl-form__input::-moz-placeholder,.fl-form__textarea::-moz-placeholder{color:var(--text-muted)}.fl-form__input::placeholder,.fl-form__textarea::placeholder{color:var(--text-muted)}.fl-form__select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;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='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10)}.fl-form__textarea{min-height:100px;resize:vertical;line-height:var(--leading-relaxed)}.fl-form__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-5)}.fl-form__grid .fl-form__group--full{grid-column:1 / -1}.fl-form__error{font-size:var(--text-xs);color:var(--danger);margin-top:var(--space-1)}.fl-form__hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.fl-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-lg);overflow:hidden}.fl-table thead th{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);color:var(--text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border-default)}.fl-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.fl-table tbody tr{transition:background var(--transition-fast)}.fl-table tbody tr:hover{background:var(--bg-elevated)}.fl-table tbody tr:last-child td{border-bottom:none}.fl-table .no-data{text-align:center;color:var(--text-muted);padding:var(--space-8)}html{overscroll-behavior-y:none;overscroll-behavior-x:auto;background:var(--bg-base)}@media(max-width:900px){input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],input[type=tel],input[type=url],textarea,select{font-size:16px!important}}.header-logo-icon svg,.nav-item svg,.mobile-nav-item svg,.mobile-menu-logo-icon svg,.mobile-menu-link svg{fill:none!important;stroke:currentColor!important}.fl-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);line-height:1.4}.fl-badge--primary{background:var(--primary-100);color:var(--primary)}.fl-badge--accent{background:#0ea5e926;color:var(--accent)}.fl-badge--success{background:var(--success-bg);color:var(--success)}.fl-badge--warning{background:var(--warning-bg);color:var(--warning)}.fl-badge--danger{background:var(--danger-bg);color:var(--danger)}.fl-badge--info{background:var(--info-bg);color:var(--info)}.fl-badge--secondary{background:#f9731626;color:var(--secondary)}.fl-alert{display:none;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium)}.fl-alert.show{display:flex}.fl-alert--success{display:flex;background:var(--success-bg);border:1px solid rgba(16,185,129,.3);color:var(--success)}.fl-alert--error{display:flex;background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:var(--danger)}.fl-alert--warning{display:flex;background:var(--warning-bg);border:1px solid rgba(245,158,11,.3);color:var(--warning)}.fl-alert--info{display:flex;background:var(--info-bg);border:1px solid rgba(59,130,246,.3);color:var(--info)}.fl-pagination{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-5)}.fl-pagination a,.fl-pagination span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-sm);text-decoration:none;border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.fl-pagination a:hover{background:var(--primary);color:var(--bg-base);border-color:var(--primary)}.fl-pagination .active span,.fl-pagination span[aria-current=page]{background:var(--primary);color:var(--bg-base);border-color:var(--primary);font-weight:var(--font-semibold)}.fl-pagination .disabled span{opacity:.4;cursor:not-allowed}.fl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);text-align:center}.fl-empty__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-xl);color:var(--text-muted)}.fl-empty__icon svg{width:28px;height:28px}.fl-empty__text{font-size:var(--text-sm);color:var(--text-muted);max-width:360px}.fl-result{display:flex;align-items:center;gap:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5)}.fl-result__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.fl-result__icon--primary{background:var(--primary-100);color:var(--primary)}.fl-result__icon--accent{background:#0ea5e926;color:var(--accent)}.fl-result__icon--secondary{background:#f9731626;color:var(--secondary)}.fl-result__icon--warning{background:#f59e0b26;color:var(--warning)}.fl-result__icon svg{width:32px;height:32px}.fl-result__body{display:flex;flex-direction:column;gap:2px}.fl-result__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.fl-result__value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.fl-result__value--primary{color:var(--primary)}.fl-result__value--accent{color:var(--accent)}.fl-result__value--secondary{color:var(--secondary)}.fl-result__value--warning{color:var(--warning)}.fl-result__comment{font-size:var(--text-sm);color:var(--text-muted)}.fl-progress{height:10px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.fl-progress__bar{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--primary-light));transition:width var(--transition-slow)}.fl-progress__bar--accent{background:linear-gradient(90deg,var(--accent),var(--accent-light))}.fl-progress__bar--secondary{background:linear-gradient(90deg,var(--secondary),var(--secondary-light))}.fl-progress__bar--warning{background:linear-gradient(90deg,var(--warning),var(--warning-light))}.fl-progress__bar--danger{background:linear-gradient(90deg,var(--danger),var(--danger-light))}@media(max-width:768px){.fl-page-header__icon{width:44px;height:44px}.fl-page-header__text h1{font-size:var(--text-xl)}.fl-card{padding:var(--space-4)}.fl-result{flex-direction:column;text-align:center}.fl-form__grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px;fill:currentColor}.btn-primary{background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold)}.btn-primary:hover:not(:disabled){background:var(--primary-light)}.btn-secondary{background:var(--bg-glass-light);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--primary)}.btn-success{background:var(--success);color:var(--bg-base);font-weight:var(--font-semibold)}.btn-success:hover:not(:disabled){background:var(--success-light)}.btn-danger{background:var(--danger);color:#fff;font-weight:var(--font-semibold)}.btn-danger:hover:not(:disabled){background:var(--danger-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-glass-light);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full)}.btn-icon.btn-sm{width:32px;height:32px}.btn-icon.btn-lg{width:48px;height:48px}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:all var(--transition-fast)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-strong)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-200)}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%2394a3b8' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.form-error{color:var(--danger);font-size:var(--text-xs);margin-top:var(--space-1)}.form-hint{color:var(--text-muted);font-size:var(--text-xs);margin-top:var(--space-1)}.form-check{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-check-input{width:18px;height:18px;accent-color:var(--primary)}.form-check-label{font-size:var(--text-sm);color:var(--text-secondary)}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;min-width:300px;max-width:420px;padding:14px 16px;border-radius:12px;background:#1e1e1ef2;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006;pointer-events:auto;transform:translate(120%);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.toast.show{transform:translate(0);opacity:1}.toast-icon{flex-shrink:0;width:24px;height:24px}.toast-icon svg{width:100%;height:100%}.toast-message{flex:1;font-size:.9375rem;font-weight:500;color:#f8fafc;line-height:1.4}.toast-close{flex-shrink:0;width:24px;height:24px;padding:0;border:none;background:none;cursor:pointer;opacity:.5;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-close svg{width:100%;height:100%;fill:#a1a1aa}.toast-success{border-color:var(--border-strong)}.toast-success .toast-icon svg{fill:#5f7d16}.toast-error{border-color:#ef44444d}.toast-error .toast-icon svg{fill:#ef4444}.toast-warning{border-color:#f59e0b4d}.toast-warning .toast-icon svg{fill:#f59e0b}.toast-info{border-color:#3b82f64d}.toast-info .toast-icon svg{fill:#3b82f6}@media(max-width:480px){.toast-container{inset:auto 10px 20px}.toast{min-width:auto;max-width:none}}.fitconfirm-backdrop{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;background:#000000a6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:opacity .2s ease}.fitconfirm-backdrop.open{opacity:1;pointer-events:all}.fitconfirm-modal{width:340px;max-width:calc(100vw - 2rem);padding:2rem 1.75rem 1.5rem;background:#141618;border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 24px 64px #000000b3;text-align:center;transform:scale(.9) translateY(8px);transition:transform .2s ease}.fitconfirm-backdrop.open .fitconfirm-modal{transform:scale(1) translateY(0)}.fitconfirm-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;margin:0 auto 1rem;background:#ef44441f;border:1px solid rgba(239,68,68,.2);border-radius:14px;color:#ef4444}.fitconfirm-message{margin:0 0 1.75rem;color:#ffffffb8;font-size:.9375rem;line-height:1.5}.fitconfirm-actions{display:flex;gap:.75rem;justify-content:center}.fitconfirm-no,.fitconfirm-yes{flex:1;padding:.625rem 1rem;border-radius:999px;font-family:inherit;font-size:.875rem;cursor:pointer;transition:all .15s}.fitconfirm-no{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff9;font-weight:500}.fitconfirm-no:hover{background:#ffffff17;color:#ffffffd9}.fitconfirm-yes{background:#ef4444;border:none;color:#fff;font-weight:600}.fitconfirm-yes:hover{background:#dc2626}.auth-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.auth-container{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-6);padding-top:calc(var(--header-height) + var(--spacing-8))}.auth-card{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:var(--spacing-8);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--spacing-8)}.auth-logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-6)}.auth-logo-icon{width:48px;height:48px;background:var(--gradient-accent);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent-md)}.auth-logo-icon svg{width:28px;height:28px;color:var(--text-inverse)}.auth-logo-text{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.auth-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.auth-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-5)}.auth-form .form-group{margin-bottom:0}.auth-form .form-label{display:flex;align-items:center;justify-content:space-between}.auth-form .form-link{font-size:var(--text-xs);color:var(--accent);text-decoration:none}.auth-form .form-link:hover{color:var(--accent-light);text-decoration:underline}.auth-input-wrapper{position:relative}.auth-input-wrapper .form-input{padding-left:var(--spacing-12)}.auth-input-wrapper .input-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-muted);pointer-events:none}.auth-input-wrapper .toggle-password{position:absolute;right:var(--spacing-4);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-1);transition:color var(--transition-fast)}.auth-input-wrapper .toggle-password:hover{color:var(--text-primary)}.auth-input-wrapper .toggle-password svg{width:20px;height:20px}.auth-remember{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4)}.auth-submit{width:100%;height:52px;background:var(--gradient-accent);color:var(--text-inverse);font-size:var(--text-base);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-accent-sm)}.auth-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-accent-md)}.auth-submit:active{transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;gap:var(--spacing-4);margin:var(--spacing-6) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.auth-social{display:flex;flex-direction:column;gap:var(--spacing-3)}.auth-social-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);width:100%;height:48px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);text-decoration:none;cursor:pointer;transition:all var(--transition-normal)}.auth-social-btn:hover{background:var(--surface-active);border-color:var(--border-light)}.auth-social-btn svg,.auth-social-btn img{width:20px;height:20px}.auth-footer{text-align:center;margin-top:var(--spacing-6);padding-top:var(--spacing-6);border-top:1px solid var(--border)}.auth-footer-text{font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer-link{color:var(--accent);text-decoration:none;font-weight:var(--font-medium)}.auth-footer-link:hover{color:var(--accent-light);text-decoration:underline}.auth-errors{background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-5)}.auth-errors ul{list-style:none;padding:0;margin:0}.auth-errors li{font-size:var(--text-sm);color:var(--error);display:flex;align-items:center;gap:var(--spacing-2)}.auth-errors li:before{content:"•"}.auth-success{background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-5);font-size:var(--text-sm);color:var(--success)}.auth-notice{background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-5)}.auth-notice-text{font-size:var(--text-sm);color:var(--info);margin-bottom:var(--spacing-3)}.auth-notice-resend{display:inline-flex;align-items:center;gap:var(--spacing-2)}@media(max-width:480px){.auth-card{padding:var(--spacing-6);border-radius:var(--radius-xl)}.auth-title{font-size:var(--text-xl)}.auth-social{flex-direction:column}}.auth-navbar{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#030305cc;border-bottom:1px solid var(--border);z-index:var(--z-fixed);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-6)}.auth-navbar-brand{display:flex;align-items:center;gap:var(--spacing-3);text-decoration:none}.auth-navbar-brand-icon{width:36px;height:36px;background:var(--gradient-accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.auth-navbar-brand-icon svg{width:20px;height:20px;color:var(--text-inverse)}.auth-navbar-brand-text{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.auth-navbar-link{font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.auth-navbar-link:hover{color:var(--accent)}@media(min-width:1024px){.auth-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-split-left{display:flex;align-items:center;justify-content:center;padding:var(--spacing-8);background:var(--bg-secondary)}.auth-split-right{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);background:var(--surface);position:relative;overflow:hidden}.auth-split-right:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-accent)}.auth-hero{max-width:480px;text-align:center}.auth-hero-icon{width:120px;height:120px;margin:0 auto var(--spacing-8);background:var(--gradient-accent);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent-lg)}.auth-hero-icon svg{width:64px;height:64px;color:var(--text-inverse)}.auth-hero-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--spacing-4)}.auth-hero-description{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed)}.auth-hero-features{margin-top:var(--spacing-8);display:flex;flex-direction:column;gap:var(--spacing-4);text-align:left}.auth-hero-feature{display:flex;align-items:center;gap:var(--spacing-3)}.auth-hero-feature-icon{width:32px;height:32px;background:var(--accent-muted);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.auth-hero-feature-icon svg{width:16px;height:16px}.auth-hero-feature-text{font-size:var(--text-sm);color:var(--text-secondary)}}body.auth-shell-page{background-color:#040506;overscroll-behavior-y:none;overscroll-behavior-x:auto}:root{--auth-shell-bg: #040506;--auth-shell-card: rgba(14, 16, 20, .82);--auth-shell-elevated: rgba(255, 255, 255, .04);--auth-shell-primary: #5f7d16;--auth-shell-primary-glow: rgba(95, 125, 22, .18);--auth-shell-text: #f4f7fb;--auth-shell-text-muted: rgba(244, 247, 251, .52);--auth-shell-border: rgba(255, 255, 255, .07);--auth-shell-error: #ef4444;--auth-shell-gradient: linear-gradient(135deg, #7b9c29 0%, #5f7d16 45%, #49610d 100%)}.auth-shell-page{font-family:Inter,sans-serif;background:radial-gradient(circle at top left,rgba(95,125,22,.14),transparent 32%),radial-gradient(circle at top right,rgba(249,115,22,.16),transparent 28%),linear-gradient(180deg,#040506,#090b0f 42%,#050607);color:var(--auth-shell-text);line-height:1.6;min-height:100vh;margin:0}.auth-shell-page ::-webkit-scrollbar{width:8px}.auth-shell-page ::-webkit-scrollbar-track{background:var(--auth-shell-bg)}.auth-shell-page ::-webkit-scrollbar-thumb{background:var(--auth-shell-primary);border-radius:4px}.auth-shell-nav{padding:0 2.5rem;height:96px;display:grid;grid-template-columns:max-content 1fr max-content;align-items:center;background:#06080bb8;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:none;width:100%;box-sizing:border-box}.auth-shell-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;justify-self:start}.auth-shell-logo-img{height:72px;width:auto;display:block}.auth-shell-logo-icon{width:38px;height:38px;border-radius:10px;font-weight:800;font-size:1.1rem;color:#07080a;flex-shrink:0;font-family:Inter,sans-serif}.auth-shell-logo-text{font-family:Inter,sans-serif;font-size:1.4rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#f4f7fb;background:none;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-shell-nav-actions{display:flex;gap:1rem;align-items:center;justify-self:end;color:var(--auth-shell-text-muted);font-size:.95rem}.auth-shell-nav-text{color:var(--auth-shell-text-muted)}.auth-shell-nav-button{padding:.6rem 1.25rem;border-radius:999px;font-size:.88rem;transition:all .2s;border:1px solid transparent;box-sizing:border-box;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.auth-shell-nav-button--primary{background:var(--auth-shell-gradient);color:#07080a}.auth-shell-nav-button--ghost{border-color:#ffffff1a;background:transparent;color:var(--auth-shell-text)}.auth-shell-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 2rem;position:relative;box-sizing:border-box}.auth-shell-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,var(--auth-shell-primary-glow) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(6,182,212,.2) 0%,transparent 50%);pointer-events:none}.auth-shell{width:100%;max-width:460px;position:relative;z-index:1;margin:0 auto}.auth-shell--wide{max-width:540px}.auth-shell-card{width:100%;background:#0e1014b8;border:1px solid rgba(255,255,255,.07);border-radius:28px;padding:2.5rem;position:relative;overflow:hidden;box-shadow:0 40px 80px #00000073,inset 0 1px #ffffff0a;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-sizing:border-box}.auth-shell-card:before{content:"";position:absolute;inset:0 0 auto;height:100px;background:linear-gradient(180deg,rgba(95,125,22,.06),transparent);pointer-events:none}.auth-shell-card>*{position:relative;z-index:1}.auth-shell-header{text-align:center;margin-bottom:2rem;display:flex;flex-direction:column;align-items:center}.auth-shell-badge{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .8rem;margin:0 auto 1rem;border-radius:999px;border:1px solid rgba(95,125,22,.2);background:#5f7d160f;color:var(--auth-shell-primary);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}.auth-shell-icon{width:48px;height:48px;background:var(--auth-shell-gradient);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:#08110d;font-weight:800;font-size:1.2rem;font-family:Inter,sans-serif;flex-shrink:0;overflow:hidden}.auth-shell-icon img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;padding:4px}.auth-shell-icon svg,.auth-shell-input-icon,.auth-shell-password-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}.auth-shell-icon svg{width:24px;height:24px}.auth-shell-title{font-family:Inter,sans-serif;font-size:2.2rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em;line-height:1;margin-bottom:.5rem}.auth-shell-title-gradient{color:var(--auth-shell-primary);-webkit-text-fill-color:var(--auth-shell-primary);background:none}.auth-shell-subtitle{color:var(--auth-shell-text-muted);font-size:.95rem;max-width:30ch;margin:0 auto}.auth-shell-alert{padding:1rem;border-radius:14px;margin-bottom:1.25rem;font-size:.9rem}.auth-shell-alert--success{background:#5f7d161a;border:1px solid rgba(95,125,22,.3);color:var(--auth-shell-primary)}.auth-shell-alert--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--auth-shell-error)}.auth-shell-alert ul{padding-left:1.25rem}.auth-shell-form{display:flex;flex-direction:column;gap:1.25rem}.auth-shell-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.auth-shell-form-group{margin-bottom:0}.auth-shell-label,.auth-shell-label-row{display:block;font-size:.9rem;font-weight:500;color:var(--auth-shell-text);margin-bottom:.5rem}.auth-shell-label-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.auth-shell-link{color:var(--auth-shell-primary);text-decoration:none;font-size:.85rem}.auth-shell-link:hover{text-decoration:underline}.auth-shell-input-wrap{position:relative}.auth-shell-input-wrap .auth-shell-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--auth-shell-text-muted);pointer-events:none}.auth-shell-input{width:100%;padding:.875rem 1rem .875rem 2.75rem;background:var(--auth-shell-elevated);border:1px solid var(--auth-shell-border);border-radius:12px;color:var(--auth-shell-text);font-size:.95rem;font-family:inherit;transition:all .3s;box-sizing:border-box}.auth-shell-input:hover{border-color:#5f7d1659}.auth-shell-input:focus{outline:none;border-color:var(--auth-shell-primary);box-shadow:0 0 0 3px var(--auth-shell-primary-glow)}.auth-shell-input.is-error{border-color:var(--auth-shell-error)}.auth-shell-password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--auth-shell-text-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.auth-shell-password-toggle svg{width:18px;height:18px}.auth-shell-password-toggle:hover{color:var(--auth-shell-text)}.auth-shell-checkbox{display:flex;align-items:flex-start;gap:.75rem;color:var(--auth-shell-text-muted);font-size:.9rem}.auth-shell-checkbox input{margin-top:.15rem}.auth-shell-submit{width:100%;padding:1rem;background:var(--auth-shell-gradient);border:none;border-radius:12px;color:#08110d;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .3s;box-shadow:0 18px 34px #5f7d162e;box-sizing:border-box}.auth-shell-submit:hover{transform:translateY(-2px);box-shadow:0 20px 48px #5f7d1647}.auth-shell-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--auth-shell-border);font-size:.9rem;color:var(--auth-shell-text-muted)}.auth-shell-footer a{color:var(--auth-shell-primary);text-decoration:none;font-weight:500;margin-left:.25rem}.auth-shell-footer a:hover{text-decoration:underline}.auth-shell-reset-link{width:100%;padding:.875rem 1rem;border:1px solid rgba(95,125,22,.15);border-radius:14px;background:#5f7d1608;box-sizing:border-box;overflow:auto;word-break:break-all;color:var(--auth-shell-text-muted);font-size:.85rem}.auth-shell-stack{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.auth-shell-note{margin:0;color:var(--auth-shell-text-muted);font-size:.85rem}@media(max-height:900px){.auth-shell-page.auth-shell-page--scrollable .auth-shell-container{align-items:flex-start;padding-top:5rem;padding-bottom:1.5rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-card{max-height:calc(100vh - 6.5rem);overflow-y:auto;padding:1.75rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-card::-webkit-scrollbar{width:6px}.auth-shell-page.auth-shell-page--scrollable .auth-shell-card::-webkit-scrollbar-track{background:transparent}.auth-shell-page.auth-shell-page--scrollable .auth-shell-card::-webkit-scrollbar-thumb{background:#5f7d1673;border-radius:999px}.auth-shell-page.auth-shell-page--scrollable .auth-shell-header{margin-bottom:1.5rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-icon{width:44px;height:44px;margin-bottom:1rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-title{font-size:1.5rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-subtitle{font-size:.9rem}.auth-shell-page.auth-shell-page--scrollable .auth-shell-form{gap:1rem}}@media(max-width:480px){.auth-shell-nav{padding:1rem;grid-template-columns:max-content 1fr max-content}.auth-shell-nav-actions{gap:.75rem}.auth-shell-nav-text{display:none}.auth-shell-card{padding:1.5rem;border-radius:18px}.auth-shell-title{font-size:1.5rem}.auth-shell-form-grid{grid-template-columns:1fr;gap:1rem}}body.welcome-page{background-color:#040506;overscroll-behavior-x:auto;overscroll-behavior-y:none;scroll-behavior:smooth}.welcome-btn--primary{background:linear-gradient(135deg,#7b9c29,#5f7d16 45%,#49610d);color:#07080a;box-shadow:0 16px 40px #5f7d1640}.welcome-brand-img{height:90px;width:auto;display:block}.welcome-page{background:radial-gradient(circle at top left,rgba(95,125,22,.12),transparent 28%),radial-gradient(circle at top right,rgba(249,115,22,.14),transparent 24%),linear-gradient(180deg,#040506,#090b0f 42%,#050607);color:#f4f7fb;font-family:"Inter",var(--font-family);min-height:100vh;-webkit-tap-highlight-color:transparent}.welcome-menu-open{overflow:hidden}.welcome-page::-moz-selection{background:#7b9c2947}.welcome-page::selection{background:#7b9c2947}.welcome-layout{overflow-x:hidden;overflow-y:visible}.welcome-section[id],.welcome-hero[id]{scroll-margin-top:7rem}.welcome-page:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:radial-gradient(circle at center,black 32%,transparent 78%);mask-image:radial-gradient(circle at center,black 32%,transparent 78%);opacity:.3}.welcome-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;padding:1rem 2rem;border-bottom:1px solid transparent;transition:background var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base)}.welcome-header.is-scrolled{background:#050607d1;border-color:#ffffff0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 20px 40px #0000002e}.welcome-brand{display:inline-flex;align-items:center;gap:.8rem;text-decoration:none}.welcome-brand-img{height:72px;width:auto;display:block}.welcome-brand-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#5f7d16,#7b9c29 42%,#f97316);color:#050607;font-family:Inter,sans-serif;font-size:1.35rem;font-weight:800;box-shadow:0 18px 40px #7b9c2933}.welcome-brand-text{color:#f7fbff;font-family:Inter,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.welcome-nav{justify-self:center;display:inline-flex;align-items:center;gap:1.5rem;padding:.55rem 1.1rem;border:1px solid rgba(255,255,255,.08);border-radius:999px;background:#12141bc7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.welcome-nav-link{color:#f4f7fbb8;text-decoration:none;font-size:.9rem;transition:color var(--transition-fast),opacity var(--transition-fast)}.welcome-nav-link:hover{color:#5f7d16}.welcome-actions{display:inline-flex;align-items:center;gap:.75rem}.welcome-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:.85rem 1.3rem;border-radius:999px;border:1px solid transparent;font-weight:600;text-decoration:none;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base),background var(--transition-base),color var(--transition-base)}.welcome-btn:hover{transform:translateY(-2px)}.welcome-btn--ghost,.welcome-btn--surface{background:#ffffff0a;border-color:#ffffff14;color:#f2f7fb}.welcome-btn--primary{background:#5f7d16;color:#07080a;box-shadow:0 22px 48px #5f7d1633}.welcome-btn--xl{min-height:54px;padding:1rem 1.6rem}.welcome-menu-toggle{display:none;justify-self:end;width:48px;height:48px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#ffffff0a;cursor:pointer}.welcome-mobile-backdrop,.welcome-mobile-panel{display:none}.welcome-mobile-backdrop[hidden],.welcome-mobile-panel[hidden]{display:none!important}.welcome-menu-toggle span{display:block;width:18px;height:2px;margin:0 auto;background:#f7fbff;transition:transform var(--transition-fast),opacity var(--transition-fast)}.welcome-menu-toggle span+span{margin-top:5px}.welcome-menu-toggle.is-open span:first-child{transform:translateY(3.5px) rotate(45deg)}.welcome-menu-toggle.is-open span:last-child{transform:translateY(-3.5px) rotate(-45deg)}.welcome-hero{position:relative;padding:8.5rem 2rem 3rem}.welcome-hero-noise{position:absolute;inset:0;background:radial-gradient(circle at 16% 18%,rgba(95,125,22,.18),transparent 20%),radial-gradient(circle at 76% 26%,rgba(249,115,22,.18),transparent 18%),radial-gradient(circle at 52% 78%,rgba(255,255,255,.06),transparent 22%);filter:blur(12px);pointer-events:none}.welcome-hero-grid{max-width:1380px;margin:0 auto;display:grid;grid-template-columns:minmax(0,.98fr) minmax(0,1.02fr);gap:3rem;align-items:center}.welcome-hero-copy{max-width:640px;position:relative;z-index:1}.welcome-hero-eyebrow{display:inline-flex;align-items:center;gap:.85rem;margin-bottom:1rem;color:#f4f7fb8a;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase}.welcome-hero-index{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.12);border-radius:50%;color:#f7fbff}.welcome-hero-badge,.welcome-section-tag{display:inline-flex;align-items:center;gap:.55rem;padding:.55rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#f4f7fbb8;font-size:.82rem;letter-spacing:.04em}.welcome-badge-dot{width:10px;height:10px;border-radius:50%;background:#5f7d16;box-shadow:0 0 0 6px #7b9c2924}.welcome-hero-title{margin:1.35rem 0 1rem;font-family:Inter,sans-serif;font-size:clamp(4.2rem,9vw,7rem);line-height:.9;letter-spacing:-.03em;text-transform:uppercase}.welcome-hero-title span{display:block;color:#5f7d16}.welcome-hero-title em{display:block;font-style:normal;color:#f7fbff;text-shadow:0 0 28px rgba(255,255,255,.06)}.welcome-hero-subtitle{max-width:58ch;font-size:1.05rem;color:#f4f7fbb8}.welcome-hero-proofline{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1.2rem}.welcome-hero-proofline span{display:inline-flex;align-items:center;min-height:38px;padding:.6rem .8rem;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#f4f7fba8;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.welcome-hero-cta-row{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2rem}.welcome-hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1.8rem}.welcome-hero-stat{position:relative;padding:1rem 1.05rem 1.1rem;border-radius:22px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0b,#ffffff05);box-shadow:inset 0 1px #ffffff08;overflow:hidden}.welcome-hero-stat:after{content:"";position:absolute;inset:auto -1.25rem -2.25rem auto;width:6rem;height:6rem;border-radius:50%;background:radial-gradient(circle,rgba(95,125,22,.18),transparent 72%);pointer-events:none}.welcome-hero-stat strong{display:block;color:#f7fbff;font-family:Inter,sans-serif;font-size:2.1rem;letter-spacing:.02em}.welcome-hero-stat span{color:#f4f7fb99;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}.welcome-stage{position:relative;min-height:640px;display:flex;align-items:center;justify-content:center;padding:1.5rem 4.5rem;z-index:1}.welcome-stage:before{content:"";position:absolute;inset:4% 8% 10%;border-radius:48px;background:radial-gradient(circle at 32% 36%,rgba(123,156,41,.18),transparent 36%),radial-gradient(circle at 72% 26%,rgba(249,115,22,.18),transparent 28%);filter:blur(20px)}.welcome-stage:after{content:"";position:absolute;inset:7% 4% 6% 10%;border:1px solid rgba(255,255,255,.06);border-radius:38px;transform:rotate(-1.5deg);opacity:.3}.welcome-stage-frame{position:absolute;inset:14% 12% 12%;border-radius:42px;background:linear-gradient(180deg,#ffffff0a,#ffffff03);border:1px solid rgba(255,255,255,.05);transform:rotate(2deg)}.welcome-stage-card{position:relative;z-index:1;width:min(100%,620px);padding:1.2rem;border-radius:36px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#0f121ae0,#07090dfa);box-shadow:0 42px 90px #0000006b;transform:none}.welcome-stage-topbar,.welcome-stage-main,.welcome-stage-grid,.welcome-footer-top,.welcome-system-grid,.welcome-section-heading--split,.welcome-community-panel,.welcome-board-column,.welcome-system-list div{display:flex;align-items:center;justify-content:space-between;gap:1rem}.welcome-stage-chip,.welcome-stage-caption,.welcome-board-label,.welcome-pill-column span,.welcome-avatar-row span{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.welcome-stage-chip{padding:.45rem .8rem;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.welcome-stage-caption{color:#f4f7fb75}.welcome-stage-main{align-items:stretch;margin-top:1rem;padding:1.35rem;border-radius:28px;background:linear-gradient(135deg,#141823f2,#090c11f0)}.welcome-stage-bars{display:flex;flex-direction:column;gap:.45rem;margin-top:1rem}.welcome-stage-bars span{display:block;width:100%;height:10px;border-radius:999px;background:#ffffff14;overflow:hidden}.welcome-stage-bars i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#5f7d16,#7b9c29 48%,#f97316)}.welcome-stage-copy p,.welcome-bento-card p,.welcome-result-card strong,.welcome-system-list strong,.welcome-footer-copy{color:#f4f7fbb8}.welcome-stage-copy h2{margin:.4rem 0;font-family:Inter,sans-serif;font-size:4.6rem;line-height:.9}.welcome-stage-copy h2 span{font-size:1.4rem}.welcome-stage-copy small{color:#f4f7fb80}.welcome-stage-ring{width:190px;height:190px;padding:14px;border-radius:50%;background:conic-gradient(from 140deg,#5f7d16 0 64%,#ffffff14 64% 100%)}.welcome-stage-ring-core{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at top,#ffffff14,#06070afa 60%)}.welcome-stage-ring-core span{font-family:Inter,sans-serif;font-size:2.2rem;color:#f7fbff}.welcome-stage-ring-core small{color:#f4f7fb7a;text-align:center;max-width:9ch}.welcome-stage-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.8rem;margin-top:1rem;align-items:stretch}.welcome-stage-footerband span{color:#f4f7fb85;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase}.welcome-mini-card--metric{background:#ffffff08;grid-column:span 2}.welcome-mini-card--metric strong{display:block;margin-top:.35rem;font-family:Inter,sans-serif;font-size:2.2rem;color:#f7fbff}.welcome-mini-card--metric small{color:#f4f7fb9e}.welcome-mini-card{flex:1;padding:1rem;border-radius:22px;border:1px solid rgba(255,255,255,.06);background:#ffffff08}.welcome-mini-card--wide{grid-column:span 2}.welcome-mini-card--split{grid-column:span 3}.welcome-mini-card span,.welcome-mini-card small,.welcome-result-card p,.welcome-system-text,.welcome-system-list span,.welcome-community-panel p,.welcome-footer-copy,.welcome-footer-bottom,.welcome-footer-links a{color:#f4f7fba3}.welcome-mini-card strong{display:block;margin:.5rem 0 .25rem;color:#f7fbff;font-size:1.2rem}.welcome-mini-card--accent{background:linear-gradient(180deg,#7b9c291f,#ffffff08)}.welcome-mini-card--orange{background:linear-gradient(180deg,#f973161f,#ffffff08)}.welcome-stage-footerband{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.welcome-stage-footerband span{padding:.65rem .75rem;border-radius:999px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.welcome-marquee{position:relative;overflow-x:hidden;overflow-y:visible;padding:1rem 0 .75rem}.welcome-marquee-track{display:flex;align-items:center;width:-moz-max-content;width:max-content;gap:0;white-space:nowrap;will-change:transform;animation:welcomeTicker 22s linear infinite}.welcome-marquee-group{display:flex;align-items:center;gap:1rem;flex-shrink:0;padding-right:1rem}.welcome-marquee-track span{display:inline-flex;align-items:center;min-height:44px;padding:.8rem 1.2rem;line-height:1;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#12151bf0;box-shadow:inset 0 1px #ffffff08;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:#f4f7fbb8}.welcome-section{max-width:1380px;margin:0 auto;padding:5rem 2rem}.welcome-section-heading{max-width:820px;margin-bottom:2rem}.welcome-section-heading h2,.welcome-system-copy h2,.welcome-community-panel h2{margin:1rem 0 0;font-family:Inter,sans-serif;font-size:clamp(2.8rem,6vw,4.5rem);line-height:.94;text-transform:uppercase}.welcome-section-heading p,.welcome-section-heading--split>p{color:#f4f7fbad;max-width:42ch}.welcome-bento-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.welcome-bento-card,.welcome-result-card,.welcome-system-board,.welcome-community-panel{border-radius:28px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#12151df5,#090b0ffa);box-shadow:0 26px 60px #00000038}.welcome-bento-card{min-height:220px;padding:1.4rem;display:flex;flex-direction:column;justify-content:space-between}.welcome-bento-card h3{font-family:Inter,sans-serif;font-size:2rem;line-height:.98;text-transform:uppercase}.welcome-bento-card span,.welcome-result-card p{display:block;max-width:34ch}.welcome-bento-card--xl{grid-column:span 2;min-height:360px}.welcome-bento-card--tall{grid-row:span 2}.welcome-bento-card--wide{grid-column:span 2}.welcome-bento-card--nutrition{grid-column:3;grid-row:1}.welcome-progress-stack{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.welcome-progress-line{position:relative;padding:.95rem 1rem 1rem;border-radius:24px;background:#ffffff09;border:1px solid rgba(255,255,255,.06)}.welcome-progress-line label{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.7rem;color:#f4f7fbb8;font-size:.84rem;letter-spacing:.04em}.welcome-progress-line label b{color:#f7fbff;font-family:Inter,sans-serif;font-size:1.3rem;letter-spacing:.02em}.welcome-progress-line span{display:block;max-width:none;height:16px;border-radius:999px;background:linear-gradient(90deg,#5f7d16,#7b9c29 44%,#f97316);box-shadow:0 10px 20px #5f7d1629}.welcome-progress-line:after{content:"";position:absolute;left:1rem;right:1rem;bottom:1rem;height:16px;border-radius:999px;background:#ffffff0f;z-index:-1}.welcome-progress-line--primary{transform:translate(0)}.welcome-progress-line--offset,.welcome-progress-line--accent{transform:none;max-width:100%}.welcome-progress-line--offset span{background:linear-gradient(90deg,#f97316,#fb923c 52%,#fde68a)}.welcome-progress-line--accent span{background:linear-gradient(90deg,#5f7d16,#7b9c29 44%,#f97316)}.welcome-pill-column{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.welcome-pill-column span{display:inline-flex;align-items:center;min-height:42px;padding:.7rem .9rem;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.welcome-avatar-row{display:flex;align-items:center;gap:.5rem;margin-top:1.4rem}.welcome-community-meta{margin-top:auto;padding-top:1.4rem}.welcome-community-meta strong{display:block;color:#f7fbff;font-family:Inter,sans-serif;font-size:2rem;text-transform:uppercase}.welcome-community-meta span{margin-top:.3rem;color:#f4f7fb9e}.welcome-bento-card--gallery{grid-column:1;grid-row:2;overflow:hidden;background:linear-gradient(180deg,#161a24fa,#0a0c11fa)}.welcome-gallery-stack{position:relative;min-height:140px;margin-top:1.5rem}.welcome-gallery-card{position:absolute;width:58%;height:132px;border-radius:22px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 40px #0000003d}.welcome-gallery-card--back{top:0;right:8%;background:linear-gradient(135deg,#f973163d,#ffffff08);transform:rotate(7deg)}.welcome-gallery-card--mid{top:14px;left:20%;background:linear-gradient(135deg,#7b9c2938,#ffffff08);transform:rotate(-5deg)}.welcome-gallery-card--front{bottom:0;left:0;background:linear-gradient(180deg,#ffffff14,#ffffff05);transform:rotate(2deg)}.welcome-bento-card--community{grid-column:2 / span 2;grid-row:2;background:linear-gradient(135deg,#131822fa,#0a0c11fa)}.welcome-bento-card--tall{grid-column:4;grid-row:1 / span 2}.welcome-avatar-row span{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.welcome-system-grid{align-items:stretch}.welcome-system-copy,.welcome-system-board{flex:1}.welcome-system-text{margin-top:1rem;max-width:52ch}.welcome-system-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.welcome-system-list div{align-items:flex-start;flex-direction:column;padding:1rem 1.1rem;border-radius:20px;border:1px solid rgba(255,255,255,.06);background:#ffffff08}.welcome-system-board{padding:1.2rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.welcome-board-column{min-height:160px;align-items:flex-start;flex-direction:column;justify-content:flex-start;padding:1.1rem;border-radius:24px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden}.welcome-board-column:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#ffffff14}.welcome-board-column strong{font-family:Inter,sans-serif;font-size:2rem;line-height:.95;text-transform:uppercase}.welcome-board-column small{margin-top:.25rem;color:#f4f7fbad}.welcome-board-column em{margin-top:auto;font-style:normal;color:#f4f7fb85;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}.welcome-board-column--wide{grid-column:span 3;min-height:200px;background:linear-gradient(135deg,#5f7d161f,#ffffff08)}.welcome-board-column--wide:before{background:linear-gradient(90deg,#5f7d16,#7b9c29)}.welcome-board-column--fuel{background:linear-gradient(180deg,#f9731629,#ffffff08)}.welcome-board-column--fuel:before{background:linear-gradient(90deg,#f97316,#fb923c)}.welcome-board-column--recover{background:linear-gradient(180deg,#7dd3fc1f,#ffffff08)}.welcome-board-column--recover:before{background:linear-gradient(90deg,#7dd3fc,#38bdf8)}.welcome-board-column--highlight{background:linear-gradient(180deg,#5f7d162e,#f973161f)}.welcome-board-column--highlight:before{background:linear-gradient(90deg,#5f7d16,#f97316)}.welcome-board-column--wide-end{min-height:204px}.welcome-results-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.welcome-result-card{padding:1.4rem}.welcome-result-card strong{display:block;color:#f7fbff;font-family:Inter,sans-serif;font-size:1.8rem;text-transform:uppercase}.welcome-result-card p{margin-top:.75rem}.welcome-community-panel{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:2rem}.welcome-community-panel p{margin-top:1rem;max-width:48ch}.welcome-community-actions{display:flex;flex-wrap:wrap;gap:.8rem}.welcome-footer{padding:0 2rem 2rem}.welcome-footer-shell{position:relative;max-width:1380px;margin:0 auto;padding:2rem;border-radius:32px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at top left,rgba(95,125,22,.14),transparent 24%),radial-gradient(circle at top right,rgba(249,115,22,.14),transparent 20%),linear-gradient(180deg,#0d1016fa,#07090dfa);box-shadow:0 30px 80px #00000047;overflow:hidden}.welcome-footer-shell:before,.welcome-footer-shell:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.welcome-footer-shell:before{top:-4.5rem;left:-4rem;width:14rem;height:14rem;background:radial-gradient(circle,rgba(95,125,22,.16),transparent 68%)}.welcome-footer-shell:after{right:-4rem;bottom:-5rem;width:16rem;height:16rem;background:radial-gradient(circle,rgba(249,115,22,.14),transparent 68%)}.welcome-footer-top{position:relative;z-index:1;padding:0 0 1.6rem;align-items:flex-start}.welcome-brand--footer{margin-bottom:.8rem}.welcome-footer-brandblock{flex:0 1 30rem}.welcome-footer-kicker,.welcome-footer-title{display:inline-flex;align-items:center;min-height:34px;padding:.45rem .75rem;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.07);color:#f4f7fbc2;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}.welcome-footer-copy{margin-top:1rem;max-width:34ch}.welcome-footer-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.4rem}.welcome-footer-grid{flex:1 1 0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;width:100%}.welcome-footer-column{position:relative;z-index:1;padding:1.15rem;border-radius:24px;border:1px solid rgba(255,255,255,.07);background:#ffffff08}.welcome-footer-column--stats{background:linear-gradient(180deg,#5f7d1614,#ffffff05)}.welcome-footer-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem .9rem;margin-top:1rem}.welcome-footer-links a{display:inline-flex;align-items:center;min-height:42px;padding:.8rem .9rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;text-decoration:none}.welcome-footer-links a:hover{color:#5f7d16}.welcome-footer-pillars{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.welcome-footer-pillars span{display:inline-flex;align-items:center;min-height:38px;padding:.65rem .8rem;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#f4f7fba8;font-size:.78rem;letter-spacing:.04em}.welcome-footer-stats-grid{display:grid;gap:.8rem;margin-top:1rem}.welcome-footer-stat{padding:.95rem 1rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#080a0e5c}.welcome-footer-stat strong{display:block;color:#f7fbff;font-family:Inter,sans-serif;font-size:1.7rem;line-height:1}.welcome-footer-stat span{display:block;margin-top:.45rem;color:#f4f7fb9e;font-size:.82rem;line-height:1.45}.welcome-hero-stats,.welcome-system-board,.welcome-results-grid{scrollbar-width:none}.welcome-hero-stats::-webkit-scrollbar,.welcome-system-board::-webkit-scrollbar,.welcome-results-grid::-webkit-scrollbar{display:none}.welcome-footer-bottom{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.06);font-size:.85rem}.welcome-footer-bottom-links{display:flex;flex-wrap:wrap;gap:.9rem}.welcome-footer-bottom-links a{color:#f4f7fbb3;text-decoration:none}.welcome-footer-bottom-links a:hover{color:#5f7d16}@keyframes welcomeTicker{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(max-width:1200px){.welcome-hero-grid,.welcome-system-grid,.welcome-community-panel,.welcome-footer-top{grid-template-columns:1fr;flex-direction:column}.welcome-footer-grid{grid-template-columns:1fr}.welcome-bento-grid,.welcome-results-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.welcome-bento-card--tall,.welcome-bento-card--xl,.welcome-bento-card--wide{grid-column:span 1;grid-row:span 1}.welcome-bento-card--nutrition,.welcome-bento-card--gallery,.welcome-bento-card--community{grid-column:auto;grid-row:auto}.welcome-stage{min-height:560px;padding:1rem 2rem}.welcome-stage-card{transform:none}.welcome-footer-links{justify-content:flex-start}.welcome-footer-bottom{flex-direction:column;align-items:flex-start}}@media(max-width:900px){.welcome-header{grid-template-columns:auto auto;gap:.85rem;padding:calc(1rem + env(safe-area-inset-top)) 1.35rem .4rem;margin:0;border:0;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.welcome-header.is-scrolled{background:linear-gradient(180deg,#040506f0,#040506ad);border-color:transparent;box-shadow:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.welcome-nav,.welcome-actions{display:none}.welcome-nav{position:absolute;top:calc(100% + 10px);left:1rem;right:1rem;flex-direction:column;align-items:stretch;padding:1rem;border-radius:24px}.welcome-nav.is-open{display:flex}.welcome-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:0;border-radius:0;background:transparent}.welcome-menu-toggle span{width:22px;height:1.5px;background:#f7fbffeb}.welcome-menu-toggle span+span{margin-top:6px}.welcome-mobile-backdrop{position:fixed;inset:0;z-index:990;background:#03040699;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;transition:opacity .24s ease}.welcome-mobile-backdrop.is-visible{display:block;opacity:1}.welcome-mobile-panel{position:fixed;top:calc(4.75rem + env(safe-area-inset-top));left:1rem;right:1rem;z-index:995;display:block;pointer-events:none;transform:translateY(-.85rem) scale(.98);opacity:0;transition:transform .26s ease,opacity .26s ease}.welcome-mobile-panel.is-open{pointer-events:auto;transform:translateY(0) scale(1);opacity:1}.welcome-mobile-panel-shell{padding:1rem;border-radius:28px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#0e1219fa,#07090dfa);box-shadow:0 32px 90px #0000006b}.welcome-mobile-panel-head{display:grid;gap:.35rem;margin-bottom:1rem}.welcome-mobile-panel-kicker{color:#f4f7fb80;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}.welcome-mobile-panel-head strong{color:#f7fbff;font-size:1.05rem;line-height:1.1;text-transform:uppercase}.welcome-mobile-nav{display:grid;gap:.65rem}.welcome-mobile-nav-link{display:grid;gap:.2rem;padding:.95rem 1rem;border-radius:20px;text-decoration:none;border:1px solid rgba(255,255,255,.07);background:#ffffff09}.welcome-mobile-nav-link span{color:#f7fbff;font-size:.96rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.welcome-mobile-nav-link small{color:#f4f7fb94;font-size:.8rem}.welcome-mobile-actions{display:grid;gap:.65rem;margin-top:1rem}.welcome-mobile-actions .welcome-btn{width:100%}.welcome-mobile-meta{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}.welcome-mobile-meta span{display:inline-flex;align-items:center;min-height:36px;padding:.55rem .75rem;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#f4f7fb9e;font-size:.73rem;letter-spacing:.08em;text-transform:uppercase}.welcome-brand-img{height:50px}.welcome-hero{padding:calc(7rem + env(safe-area-inset-top)) 1.35rem 1.5rem}.welcome-hero-title{margin-top:1.1rem;font-size:clamp(3.5rem,15vw,4.85rem);line-height:.88;letter-spacing:-.05em;max-width:7.2ch}.welcome-hero-copy{max-width:none}.welcome-hero-eyebrow{gap:.65rem;margin-bottom:.85rem;font-size:.72rem;letter-spacing:.12em}.welcome-hero-index{width:34px;height:34px;font-size:.72rem}.welcome-hero-badge{width:100%;justify-content:flex-start;padding:.78rem .95rem;border-radius:20px;line-height:1.4;font-size:.76rem}.welcome-hero-subtitle{max-width:28ch;font-size:.95rem;line-height:1.68;margin-top:1.15rem}.welcome-hero-proofline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;margin-top:1.35rem}.welcome-hero-proofline span{min-height:42px;justify-content:center;padding:.7rem .8rem;font-size:.69rem;text-align:center;letter-spacing:.1em}.welcome-hero-proofline span:last-child{grid-column:1 / -1}.welcome-section,.welcome-footer{padding-left:1rem;padding-right:1rem}.welcome-bento-grid,.welcome-results-grid,.welcome-system-board{grid-template-columns:1fr}.welcome-hero-stats{display:none}.welcome-stage{min-height:0;margin-top:1.1rem;padding:0}.welcome-stage:after,.welcome-stage-frame{display:none}.welcome-stage:before{inset:8% 2% 10%;filter:blur(22px)}.welcome-stage-card{width:100%;padding:1rem;border-radius:22px;border-color:#ffffff12;background:linear-gradient(180deg,#0c0f15f5,#07090dfc);box-shadow:0 20px 60px #00000057}.welcome-stage-topbar{align-items:center;gap:.55rem;margin-bottom:.8rem}.welcome-stage-chip,.welcome-stage-caption{font-size:.72rem;letter-spacing:.12em}.welcome-stage-main{flex-direction:row;align-items:stretch;padding:.95rem;border-radius:20px;gap:1rem;margin-top:0;background:linear-gradient(135deg,#121621fa,#0a0d12fa)}.welcome-stage-grid,.welcome-hero-cta-row,.welcome-community-actions{flex-direction:column;align-items:stretch}.welcome-stage-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:.75rem}.welcome-mini-card--metric,.welcome-board-column--wide,.welcome-board-column--wide-end,.welcome-mini-card--wide{grid-column:span 2}.welcome-mini-card--split{grid-column:span 3}.welcome-mini-card{min-height:104px;padding:.95rem;border-radius:18px}.welcome-mini-card strong{font-size:1rem}.welcome-mini-card--metric strong{font-size:1.9rem}.welcome-mini-card span,.welcome-mini-card small{font-size:.78rem;line-height:1.45}.welcome-progress-line,.welcome-progress-line--offset,.welcome-progress-line--accent{max-width:100%;transform:none}.welcome-stage-ring{width:154px;height:154px;margin:0}.welcome-stage-copy h2{font-size:3.3rem;letter-spacing:-.04em}.welcome-stage-copy p{font-size:.78rem}.welcome-stage-copy small{font-size:.8rem;line-height:1.45}.welcome-stage-bars{margin-top:.85rem}.welcome-stage-bars span{height:9px}.welcome-btn,.welcome-community-actions .welcome-btn{width:100%}.welcome-stage-footerband{display:flex;flex-direction:row;flex-wrap:wrap;gap:.6rem;margin-top:.9rem}.welcome-stage-footerband span{min-height:38px;padding:.58rem .75rem;font-size:.68rem}.welcome-section{padding-top:3.75rem;padding-bottom:3.75rem}.welcome-section-heading{margin-bottom:1.35rem}.welcome-section-heading--split{gap:.9rem;align-items:flex-start}.welcome-section-heading h2,.welcome-system-copy h2,.welcome-community-panel h2{font-size:clamp(2.2rem,10vw,3.2rem);line-height:.98}.welcome-bento-card,.welcome-result-card,.welcome-community-panel,.welcome-system-board{border-radius:24px}.welcome-bento-card{min-height:0;padding:1.15rem;gap:1rem}.welcome-bento-card h3{font-size:1.6rem;line-height:1}.welcome-gallery-stack{min-height:112px}.welcome-gallery-card{height:112px}.welcome-system-list{margin-top:1.35rem}.welcome-system-list div{padding:.95rem 1rem;border-radius:18px}.welcome-system-board{grid-auto-flow:column;grid-auto-columns:minmax(240px,82vw);grid-template-columns:none;overflow-x:auto;scroll-snap-type:x proximity;padding:.8rem}.welcome-board-column{min-height:176px;scroll-snap-align:start}.welcome-board-column--wide,.welcome-board-column--wide-end{min-height:176px}.welcome-results-grid{grid-auto-flow:column;grid-auto-columns:minmax(250px,82vw);overflow-x:auto;padding-bottom:.4rem;scroll-snap-type:x proximity}.welcome-result-card{scroll-snap-align:start;min-height:220px;padding:1.15rem}.welcome-result-card strong{font-size:1.45rem}.welcome-community-panel{align-items:flex-start;padding:1.3rem;gap:1.25rem}.welcome-footer{padding-bottom:calc(1.4rem + env(safe-area-inset-bottom))}.welcome-footer-shell{padding:1.2rem;border-radius:26px}.welcome-footer-top{gap:1.4rem}.welcome-footer-cta,.welcome-footer-bottom-links{width:100%}.welcome-footer-cta{flex-direction:column}.welcome-footer-cta .welcome-btn{width:100%}.welcome-footer-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem 1rem;width:100%}.welcome-footer-stat{padding:.9rem}}@media(max-width:560px){.welcome-header{top:0;left:0;right:0;margin:0;padding:calc(.9rem + env(safe-area-inset-top)) 1.05rem .35rem}.welcome-brand-img{height:46px}.welcome-menu-toggle{width:38px;height:38px}.welcome-menu-toggle span{width:20px}.welcome-mobile-panel{top:calc(4.35rem + env(safe-area-inset-top));left:.75rem;right:.75rem}.welcome-hero{padding:calc(6.45rem + env(safe-area-inset-top)) 1rem 1.2rem}.welcome-hero-title{font-size:clamp(3rem,15.8vw,4rem);max-width:7.4ch}.welcome-hero-badge,.welcome-section-tag{font-size:.76rem}.welcome-hero-proofline{grid-template-columns:1fr}.welcome-hero-proofline span:last-child{grid-column:auto}.welcome-stage-card{padding:.85rem;border-radius:20px}.welcome-stage-main{padding:.85rem;gap:.75rem}.welcome-stage-copy h2{font-size:2.7rem}.welcome-stage-ring{width:132px;height:132px;padding:11px}.welcome-stage-ring-core span{font-size:1.8rem}.welcome-stage-grid{gap:.6rem}.welcome-mini-card{min-height:96px;padding:.85rem}.welcome-mini-card--metric,.welcome-mini-card--wide{grid-column:span 2}.welcome-mini-card--split{grid-column:span 3}.welcome-stage-footerband span{font-size:.65rem}.welcome-bento-card h3,.welcome-result-card strong{font-size:1.35rem}.welcome-system-board{grid-auto-columns:minmax(220px,88vw)}.welcome-results-grid{grid-auto-columns:minmax(230px,88vw)}.welcome-footer-shell{padding:1rem;border-radius:22px}.welcome-footer-links,.welcome-footer-bottom-links{grid-template-columns:1fr}.welcome-footer-bottom-links{display:grid;gap:.65rem}.welcome-footer-links{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.welcome-marquee-track{animation-duration:60s}.welcome-mobile-panel,.welcome-mobile-backdrop,.welcome-btn,.welcome-menu-toggle span{transition:none}}.dashboard-page svg{width:1em;height:1em;flex-shrink:0;fill:currentColor}.dashboard-page{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:auto;gap:1rem;padding:0;width:100%;align-items:start;max-width:1520px;margin:0 auto;grid-template-areas:"header    header    header    header" "profile   profile   gallery   gallery" "cal       water     sleep     kgoals" "events    events    goallist  goallist"}.main-content.main-content--dashboard{max-width:none;margin:0;width:100%}.content-wrapper.content-wrapper--dashboard{max-width:none;margin:0;padding:1.5rem 2rem;width:100%}.dashboard-header{grid-area:header;margin-bottom:0}.stat-card.calories{grid-area:cal}.stat-card.water{grid-area:water}.stat-card.sleep{grid-area:sleep}.stat-card.goals{grid-area:kgoals}.profile-card{grid-area:profile;align-self:stretch}.dash-events{grid-area:events}.dash-goalslist{grid-area:goallist}.dash-gallery{grid-area:gallery;align-self:stretch;display:flex;flex-direction:column;max-height:440px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:.25rem}.dashboard-header>.dashboard-greeting{margin-bottom:0}.dashboard-greeting{font-family:Inter,sans-serif;font-size:2rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;line-height:1;color:var(--text-primary);margin-bottom:0}.dashboard-greeting span{color:#5f7d16;-webkit-text-fill-color:#5f7d16;background:none}.dashboard-date{font-size:.8125rem;color:#ffffff52;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.dashboard-hero,.dashboard-hero-left,.stats-grid,.dashboard-columns{display:contents}@media(max-width:1200px){.dashboard-page{grid-template-columns:1fr 1fr;grid-template-areas:"header   header" "profile  profile" "gallery  gallery" "cal      water" "sleep    kgoals" "events   events" "goallist goallist"}.content-wrapper.content-wrapper--dashboard{padding:1rem}}@media(max-width:640px){.dashboard-page{grid-template-columns:1fr 1fr;grid-template-areas:"header   header" "profile  profile" "gallery  gallery" "cal      water" "sleep    kgoals" "events   events" "goallist goallist"}.content-wrapper.content-wrapper--dashboard{padding:.75rem}}.stat-card{background:#0d0f13;border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:1.5rem;transition:border-color .2s ease,transform .2s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--stat-card-accent, #5f7d16)}.stat-card:after{content:"";position:absolute;bottom:-20px;right:-20px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--stat-card-glow, rgba(95, 125, 22, .1)) 0%,transparent 70%);pointer-events:none}.stat-card:hover{border-color:#ffffff1c;transform:translateY(-2px)}.stat-card.calories{--stat-card-accent: #f97316;--stat-card-glow: rgba(249,115,22,.08)}.stat-card.water{--stat-card-accent: #38bdf8;--stat-card-glow: rgba(56,189,248,.07)}.stat-card.sleep{--stat-card-accent: #a78bfa;--stat-card-glow: rgba(167,139,250,.08)}.stat-card.goals{--stat-card-accent: #5f7d16;--stat-card-glow: rgba(95, 125, 22, .1);display:block;padding:1.5rem}.stat-card.goals .stat-card-header{margin-bottom:1.25rem}.stat-card.goals .stat-card-value{font-size:3.5rem}.stat-card.goals .stat-card-label{margin-bottom:1.25rem;white-space:normal}.stat-card.goals .stat-card-progress{height:4px;margin-top:0}.stat-card.goals .stat-card-footer{margin-top:.6rem;white-space:normal}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.stat-card-icon{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-icon svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2}.stat-card-icon.calories{background:#f9731626;color:#f97316}.stat-card-icon.water{background:#38bdf81f;color:#38bdf8}.stat-card-icon.sleep{background:#a78bfa26;color:#a78bfa}.stat-card-icon.goals{background:#5f7d161f;color:#5f7d16}.stat-card-trend{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:6px}.stat-card-trend.up{background:#5f7d1626;color:var(--primary)}.stat-card-trend.down{background:#ef444426;color:var(--danger)}.stat-card-trend svg{width:12px;height:12px;fill:currentColor}.stat-card-value{font-family:Inter,sans-serif;font-size:3.5rem;font-weight:800;color:#fff;line-height:1;margin-bottom:.2rem;letter-spacing:-.02em;position:relative;z-index:1}.stat-card-label{font-size:.7rem;color:#ffffff61;margin-bottom:1.25rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;position:relative;z-index:1}.stat-card-progress{height:4px;background:#ffffff0f;border-radius:999px;overflow:hidden;position:relative;z-index:1}.stat-card-progress-fill{height:100%;transition:width .5s ease;border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}.stat-card-progress-fill.calories{background:linear-gradient(90deg,#ea580c,#f97316)}.stat-card-progress-fill.water{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.stat-card-progress-fill.sleep{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.stat-card-progress-fill.goals{background:linear-gradient(90deg,#49610d,#5f7d16)}.stat-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;font-size:.78rem;color:#ffffff59;font-weight:500}.dashboard-grid,.dashboard-main,.dashboard-sidebar{display:contents}.dash-card{background:#0d0f13;border:1px solid rgba(255,255,255,.06);border-radius:18px;overflow:hidden;transition:border-color .2s ease}.dash-card:hover{border-color:#ffffff1a}.dash-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05)}.dash-card-title{display:flex;align-items:center;gap:.5rem;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff8c}.dash-card-title svg{width:15px;height:15px;fill:none;stroke:#5f7d16;stroke-width:2;flex-shrink:0}.dash-card-action{font-size:.75rem;font-weight:600;color:var(--text-muted);text-decoration:none;padding:.4rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);transition:all .2s ease;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.dash-card-action:hover{background:var(--primary);color:#07080a;border-color:transparent;font-weight:700}.dash-events,.dash-goalslist{display:flex;flex-direction:column;align-self:stretch;min-height:0}.dash-events .dash-card-body,.dash-goalslist .dash-card-body{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.dash-events .dash-card-body::-webkit-scrollbar,.dash-goalslist .dash-card-body::-webkit-scrollbar{width:4px}.dash-events .dash-card-body::-webkit-scrollbar-track,.dash-goalslist .dash-card-body::-webkit-scrollbar-track{background:transparent}.dash-events .dash-card-body::-webkit-scrollbar-thumb,.dash-goalslist .dash-card-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:999px}.dash-card-body{padding:1rem 1.25rem}.events-list{display:flex;flex-direction:column;gap:.75rem}.event-item{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:#ffffff05;border-radius:12px;border-left:3px solid rgba(95,125,22,.5);border-top:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04);transition:background .2s ease,border-left-color .2s ease}.event-item:hover{background:#ffffff0a}.event-item.workout{border-left-color:#ef444499}.event-item.meal{border-left-color:#f9731699}.event-item.sleep{border-left-color:#a78bfa99}.event-item.measurement{border-left-color:#38bdf899}.event-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:48px;height:48px;background:#5f7d1614;border:1px solid rgba(95,125,22,.15);border-radius:12px;flex-shrink:0}.event-date-day{font-family:Inter,sans-serif;font-size:1.25rem;font-weight:800;color:var(--primary);line-height:1}.event-date-month{font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase;margin-top:2px}.event-info{flex:1;min-width:0}.event-type{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.event-desc{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-badge{font-size:.6875rem;font-weight:600;padding:.25rem .5rem;border-radius:6px;background:linear-gradient(135deg,#5f7d1626,#06b6d426);color:var(--primary)}.event-badge.today{background:linear-gradient(135deg,#5f7d1626,#06b6d426);color:var(--primary)}.event-badge.tomorrow{background:linear-gradient(135deg,#f9731626,#f59e0b26);color:var(--secondary)}.goals-search-wrap{display:flex;align-items:center;gap:.4rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.3rem .6rem;margin-left:.75rem;flex:1;max-width:160px;min-width:0;transition:border-color .2s ease}.goals-search-wrap:focus-within{border-color:#5f7d1659}.goals-search-icon{width:13px;height:13px;min-width:13px;color:#ffffff4d;flex-shrink:0}.goals-search-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.8125rem;width:100%;line-height:1}.goals-search-input::-moz-placeholder{color:#ffffff4d}.goals-search-input::placeholder{color:#ffffff4d}.goals-empty-search{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:#ffffff4d;font-size:.875rem}.goals-empty-search svg{width:16px;height:16px}.gallery-date-wrap{display:flex;align-items:center;gap:.4rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.3rem .6rem;margin-left:.75rem;min-width:0;transition:border-color .2s ease}.gallery-date-wrap:focus-within{border-color:#5f7d1659}.gallery-date-icon{width:13px;height:13px;min-width:13px;color:#ffffff4d;flex-shrink:0}.gallery-date-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.8125rem;width:120px;cursor:pointer;color-scheme:dark}.gallery-empty-search{display:flex;align-items:center;justify-content:center;gap:.5rem;grid-column:1 / -1;padding:1.5rem;color:#ffffff4d;font-size:.875rem}.gallery-empty-search svg{width:16px;height:16px}.goals-list{display:flex;flex-direction:column;gap:.75rem;max-height:calc(300px + 1.5rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent;padding-right:2px}.goals-list::-webkit-scrollbar{width:4px}.goals-list::-webkit-scrollbar-track{background:transparent}.goals-list::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}.goals-list::-webkit-scrollbar-thumb:hover{background:#ffffff38}.goal-item{padding:1rem;background:#ffffff06;border:1px solid rgba(255,255,255,.06);border-radius:14px;transition:all .2s ease}.goal-item:hover{border-color:#5f7d162e;background:#5f7d160a}.goal-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.goal-item-type{font-size:.875rem;font-weight:600;color:var(--text-primary)}.goal-item-percent{font-size:.875rem;font-weight:600;background:var(--primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.goal-item-percent.complete{background:linear-gradient(135deg,var(--primary) 0%,var(--success) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.goal-item-progress{height:6px;background:#27272acc;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.goal-item-progress-fill{height:100%;background:linear-gradient(90deg,#49610d,#5f7d16);border-radius:999px;transition:width .5s ease}.goal-item-progress-fill.complete{background:linear-gradient(135deg,var(--primary) 0%,var(--success) 100%)}.goal-item-progress-fill.warning{background:linear-gradient(135deg,var(--secondary) 0%,var(--warning) 100%)}.goal-item-footer{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary)}.goal-item-footer span{color:var(--text-secondary)}.dash-gallery .dash-card-body{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.dash-gallery .dash-card-body::-webkit-scrollbar{width:4px}.dash-gallery .dash-card-body::-webkit-scrollbar-track{background:transparent}.dash-gallery .dash-card-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:999px}.photos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:1px solid var(--border-default);transition:all var(--transition-base)}.photo-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.photo-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--transition-base)}.photo-item:hover img{transform:scale(1.05)}.photo-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.8) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base);display:flex;align-items:flex-end;padding:.75rem}.photo-item:hover .photo-item-overlay{opacity:1}.photo-item-date{font-size:.75rem;color:#fff;font-weight:500}.profile-card{display:flex;flex-direction:column;align-items:center;gap:0;padding:0;background:#0d0f13;border:1px solid rgba(255,255,255,.06);border-radius:18px;overflow:hidden;position:relative;height:100%}.profile-card:before{display:none}.profile-card-banner{flex-shrink:0;width:100%;height:130px;background-size:cover;background-position:center;background-color:#5f7d1614}.profile-card-avatar{width:72px;height:72px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:3px solid #0d0f13;box-shadow:0 0 0 2px #5f7d164d;display:block;margin:-38px auto .6rem;position:relative;z-index:1}.profile-card-name{font-family:Inter,sans-serif;font-size:1.25rem;font-weight:800;color:#fff;margin-bottom:.1rem;letter-spacing:.01em;text-align:center;padding:0 1rem}.profile-card-username{font-size:.75rem;color:#ffffff61;margin-bottom:1rem;text-align:center;padding:0 1rem}.profile-stats-grid{display:flex;flex-direction:row;gap:.5rem;width:calc(100% - 2rem);margin-bottom:0;padding:0;align-items:stretch;justify-content:center}.profile-stat-item{flex:1;padding:.6rem .4rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;text-align:center;transition:all .2s ease}.profile-stat-item:hover{border-color:#5f7d162e;background:#5f7d160a}.profile-stat-value{font-family:Inter,sans-serif;font-size:1.15rem;font-weight:800;color:#5f7d16;margin-bottom:.1rem;line-height:1}.profile-stat-label{font-size:.62rem;color:#ffffff59;text-transform:uppercase;letter-spacing:.05em}.profile-card-btn{display:block;margin:.875rem 1rem 1rem;padding:.7rem 1rem;background:linear-gradient(135deg,#7b9c29,#5f7d16 45%,#49610d);border:none;border-radius:999px;color:#07080a!important;font-family:Inter,sans-serif;font-size:.875rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;text-align:center;transition:all .2s ease;box-shadow:0 6px 20px #5f7d1633}.profile-card-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px #5f7d164d;color:#07080a!important}.subscriptions-list{display:flex;flex-direction:column;gap:.5rem}.subscription-item{display:flex;align-items:center;gap:.875rem;padding:.75rem;border-radius:var(--radius-sm);text-decoration:none;transition:all var(--transition-base);border:1px solid transparent}.subscription-item:hover{background:#5f7d160d;border-color:var(--border-default)}.subscription-avatar{width:40px;height:40px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;border:1px solid var(--border-default)}.subscription-info{flex:1;min-width:0}.subscription-name{font-size:.875rem;font-weight:600;color:var(--text-primary);display:block}.subscription-username{font-size:.8125rem;color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1rem;text-align:center}.empty-state-icon{width:56px;height:56px;background:#5f7d1612;border:1px solid rgba(95,125,22,.15);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.empty-state-icon svg{width:28px;height:28px;fill:var(--primary)}.empty-state-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.empty-state-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#7b9c29,#5f7d16,#49610d);color:#07080a;font-size:.8125rem;font-weight:700;border-radius:999px;text-decoration:none;transition:all .2s ease;box-shadow:0 6px 20px #5f7d1633}.empty-state-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #5f7d164d}.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--transition-base)}.lightbox.active{opacity:1;visibility:visible}.lightbox-backdrop{position:absolute;inset:0;background:#0a0a0af2}.lightbox-content{position:relative;max-width:90vw;max-height:90vh}.lightbox-content img{max-width:100%;max-height:85vh;border-radius:var(--radius-lg);-o-object-fit:contain;object-fit:contain;border:1px solid var(--border-default)}.lightbox-close{position:absolute;top:-48px;right:0;width:40px;height:40px;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.lightbox-close:hover{background:var(--bg-glass-light);border-color:var(--primary)}.lightbox-close svg{width:20px;height:20px;fill:currentColor}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.lightbox-nav:hover{background:var(--bg-glass-light);border-color:var(--primary)}.lightbox-nav.prev{left:-64px}.lightbox-nav.next{right:-64px}.lightbox-nav svg{width:24px;height:24px;fill:currentColor}.lightbox-info{margin-top:1rem;text-align:center;color:var(--text-secondary);font-size:.875rem}@media(max-width:768px){.lightbox-nav.prev{left:1rem}.lightbox-nav.next{right:1rem}}@media(max-width:992px){.dashboard-page{gap:.75rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:.35rem;margin-bottom:.5rem;padding-bottom:.85rem}.dashboard-greeting{font-size:1.3rem;line-height:1.15}.dashboard-date{font-size:.74rem;letter-spacing:.06em}.stat-card{padding:1rem;min-height:212px;display:flex;flex-direction:column;border-radius:16px}.stat-card:hover{transform:none}.stat-card-icon{width:36px;height:36px;min-width:36px;min-height:36px}.stat-card-icon svg{width:20px;height:20px;min-width:20px;min-height:20px;max-width:20px;max-height:20px}.stat-card-header{margin-bottom:.85rem}.stat-card-value{font-size:clamp(2rem,7vw,2.75rem);margin-bottom:.35rem}.stat-card-label{font-size:.72rem;margin-bottom:.9rem}.stat-card-progress{margin-top:auto}.stat-card-footer{margin-top:.5rem;font-size:.72rem;line-height:1.3}.stat-card.goals{padding:1rem}.stat-card.goals .stat-card-header{margin-bottom:.85rem}.stat-card.goals .stat-card-value{font-size:clamp(2.3rem,9vw,3rem)}.stat-card.goals .stat-card-label{margin-bottom:.9rem;font-size:.72rem}.profile-card{display:grid;grid-template-columns:72px minmax(0,1fr);grid-template-areas:"banner banner" "avatar name" "avatar username" "stats stats" "button button";gap:.65rem .9rem;text-align:left;align-items:center;justify-items:stretch;padding:0 0 1rem}.profile-card-banner{grid-area:banner;height:96px;border-radius:0 0 20px 20px}.profile-card-avatar{grid-area:avatar;width:72px;height:72px;margin:-36px 0 0 1rem}.profile-card-name{grid-area:name;font-size:1.15rem;align-self:end;margin:0;padding:0 1rem 0 0;text-align:left}.profile-card-username{grid-area:username;font-size:.8125rem;margin:0;align-self:start;padding:0 1rem 0 0;text-align:left}.profile-stats-grid{grid-area:stats;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:auto;margin:0 1rem;gap:.65rem}.profile-stat-item{padding:.7rem .6rem;min-width:0}.profile-stat-value{font-size:1rem;line-height:1.1}.profile-stat-label{font-size:.6rem;letter-spacing:.08em}.profile-card-btn{grid-area:button;margin:0 1rem;padding:.78rem 1rem;font-size:.78rem}.dash-card{border-radius:16px}.dash-card-header{flex-wrap:wrap;gap:.75rem;padding:.9rem 1rem}.dash-card-title{font-size:.875rem;gap:.5rem}.dash-card-title svg{width:18px;height:18px}.dash-card-action{font-size:.72rem;padding:.5rem .85rem}.dash-card-body{padding:.95rem 1rem}.dash-gallery .dash-card-header,.dash-goalslist .dash-card-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center}.dash-gallery .dash-card-title,.dash-goalslist .dash-card-title{grid-column:1 / -1}.gallery-date-wrap,.goals-search-wrap{width:100%;max-width:none;margin-left:0}.gallery-date-input,.goals-search-input{width:100%;min-width:0}.dash-gallery .dash-card-action,.dash-goalslist .dash-card-action{justify-self:end}.event-item{padding:.75rem;gap:.75rem}.event-date{width:40px;height:40px}.event-date-day{font-size:.9375rem}.event-date-month{font-size:.5625rem}.event-desc{font-size:.8125rem}.event-badge{font-size:.5625rem;padding:.1875rem .375rem}.goal-item{padding:.75rem}.goal-item-type,.goal-item-percent{font-size:.8125rem}.goal-item-footer{font-size:.75rem}.photos-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.empty-state{padding:1.5rem .75rem}.empty-state-icon{width:44px;height:44px;border-radius:12px}.empty-state-icon svg{width:22px;height:22px}.empty-state-text{font-size:.8125rem}.empty-state-btn{font-size:.75rem;padding:.5rem .875rem}.lightbox-content{max-width:100vw;max-height:100vh;padding:.5rem}.lightbox-content img{border-radius:var(--radius-md)}.lightbox-close{top:-40px;width:36px;height:36px}.lightbox-nav{width:40px;height:40px}.lightbox-nav.prev{left:.5rem}.lightbox-nav.next{right:.5rem}}@media(max-width:360px){.dashboard-page{grid-template-columns:1fr;grid-template-areas:"header" "profile" "gallery" "cal" "water" "sleep" "kgoals" "events" "goallist"}.stat-card{padding:.75rem;min-height:0}.stat-card-value{font-size:1.25rem}.dash-gallery .dash-card-header,.dash-goalslist .dash-card-header{grid-template-columns:1fr}.dash-gallery .dash-card-action,.dash-goalslist .dash-card-action{justify-self:start}.profile-stats-grid,.photos-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=light] .dashboard-header{border-bottom-color:var(--border-subtle)}[data-theme=light] .dashboard-date{color:var(--text-muted)}[data-theme=light] .stat-card,[data-theme=light] .dash-card,[data-theme=light] .profile-card{background:var(--bg-surface);border-color:var(--border-default);box-shadow:var(--shadow-sm)}[data-theme=light] .stat-card:hover,[data-theme=light] .dash-card:hover,[data-theme=light] .profile-card:hover{border-color:var(--border-strong)}[data-theme=light] .stat-card-value,[data-theme=light] .profile-card-name{color:var(--text-primary)}[data-theme=light] .stat-card-label,[data-theme=light] .profile-card-username,[data-theme=light] .profile-stat-label,[data-theme=light] .goals-empty-search,[data-theme=light] .gallery-empty-search{color:var(--text-muted)}[data-theme=light] .stat-card-footer,[data-theme=light] .dash-card-title{color:var(--text-secondary)}[data-theme=light] .stat-card-progress,[data-theme=light] .goal-item-progress,[data-theme=light] .goals-search-wrap,[data-theme=light] .gallery-date-wrap,[data-theme=light] .goal-item,[data-theme=light] .profile-stat-item{background:var(--bg-elevated)}[data-theme=light] .dash-card-header{border-bottom-color:var(--border-subtle)}[data-theme=light] .dash-card-action,[data-theme=light] .goals-search-wrap,[data-theme=light] .gallery-date-wrap,[data-theme=light] .goal-item,[data-theme=light] .profile-stat-item{border-color:var(--border-default)}[data-theme=light] .event-item{background:var(--bg-glass-light);border-top-color:var(--border-subtle);border-right-color:var(--border-subtle);border-bottom-color:var(--border-subtle)}[data-theme=light] .event-item:hover{background:var(--bg-elevated)}[data-theme=light] .profile-card-avatar{border-color:var(--bg-surface)}[data-theme=light] .goals-search-input::-moz-placeholder{color:var(--text-muted)}[data-theme=light] .goals-search-icon,[data-theme=light] .gallery-date-icon,[data-theme=light] .goals-search-input::placeholder{color:var(--text-muted)}[data-theme=light] .gallery-date-input{color-scheme:light}[data-theme=light] .dash-events .dash-card-body,[data-theme=light] .dash-goalslist .dash-card-body,[data-theme=light] .dash-gallery .dash-card-body,[data-theme=light] .goals-list{scrollbar-color:var(--border-default) transparent}[data-theme=light] .dash-events .dash-card-body::-webkit-scrollbar-thumb,[data-theme=light] .dash-goalslist .dash-card-body::-webkit-scrollbar-thumb,[data-theme=light] .dash-gallery .dash-card-body::-webkit-scrollbar-thumb,[data-theme=light] .goals-list::-webkit-scrollbar-thumb{background:var(--border-default)}.profile-container{max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.profile-header{position:relative;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-2xl);overflow:hidden;margin-bottom:var(--space-6)}.profile-banner{height:180px;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%);position:relative;border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);overflow:visible}.profile-banner img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(10,10,10,.8) 100%)}.profile-info{position:relative;padding:var(--space-6);padding-top:var(--space-16)}.profile-avatar{position:absolute;left:var(--space-6);bottom:-50px;width:120px;height:120px;border-radius:var(--radius-full);border:4px solid var(--bg-base);background:var(--bg-surface);overflow:hidden;box-shadow:var(--shadow-accent-md)}.profile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted);font-size:var(--text-3xl);font-weight:var(--font-bold)}.profile-details{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-4)}.profile-name-section{flex:1;min-width:200px}.profile-name{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.profile-username{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--space-3)}.profile-bio{font-size:var(--text-sm);color:var(--text-secondary);max-width:500px}.profile-actions{display:flex;gap:var(--space-3)}.btn-edit-profile{padding:var(--space-2) var(--space-5);background:var(--bg-elevated);color:var(--text-primary);font-weight:var(--font-medium);font-size:var(--text-sm);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-edit-profile:hover{background:var(--primary);color:var(--bg-base);border-color:var(--primary)}.btn-follow,.btn-message{padding:var(--space-2) var(--space-5);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-follow{background:var(--primary);color:var(--bg-base)}.btn-save,.btn-cancel,.btn-delete{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;border:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-save{background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);box-shadow:var(--shadow-accent-md)}.btn-cancel{background:var(--bg-elevated);color:var(--text-primary);font-weight:var(--font-medium);border:1px solid var(--border-default);box-shadow:var(--shadow-sm)}.btn-delete{background:var(--danger);color:#fff;font-weight:var(--font-semibold);box-shadow:0 6px 18px #ef44442e}.btn-save:hover,.btn-cancel:hover,.btn-delete:hover{background-color:unset;box-shadow:inherit;transform:none}.stat-item{text-align:center}.stat-item .value{display:block;font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.stat-item .label{font-size:var(--text-sm);color:var(--text-muted)}.profile-tabs{display:flex;gap:var(--space-2);padding:0 var(--space-6);border-bottom:1px solid var(--border-subtle);overflow-x:auto}.tab-btn{padding:var(--space-3) var(--space-5);background:transparent;color:var(--text-muted);font-weight:var(--font-medium);font-size:var(--text-sm);border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-content{display:none}.tab-content.active{display:block}.profile-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5);margin-top:var(--space-6)}.profile-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5)}.profile-card h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.bio-item{display:flex;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle)}.bio-item:last-child{border-bottom:none}.bio-item .label{color:var(--text-muted);font-size:var(--text-sm)}.bio-item .value{color:var(--text-primary);font-weight:var(--font-medium);font-size:var(--text-sm)}.goals-list{display:flex;flex-direction:column;gap:var(--space-3)}.goal-item{padding:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-md)}.goal-item .goal-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.goal-item .goal-progress{height:6px;background:var(--bg-base);border-radius:var(--radius-full);overflow:hidden}.goal-item .goal-progress-bar{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width var(--transition-base)}.edit-profile-form{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);padding-bottom:calc(var(--space-6) + 40px);margin-bottom:var(--space-6)}.edit-profile-form h2{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-5)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4)}.edit-profile-form .form-grid{margin-top:var(--space-8)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.form-group input,.form-group textarea,.form-group select{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.form-group textarea{resize:vertical;min-height:100px}.form-actions{margin-top:var(--space-5);display:flex;gap:var(--space-3);justify-content:flex-end}.btn-save{padding:var(--space-3) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-save:hover{background:var(--primary-light)}.btn-delete{padding:var(--space-3) var(--space-6);background:var(--danger);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-delete:hover{background:var(--danger-light)}.btn-cancel{padding:var(--space-3) var(--space-6);background:var(--bg-elevated);color:var(--text-primary);font-weight:var(--font-medium);font-size:var(--text-sm);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{border-color:var(--danger);color:var(--danger)}.subscriptions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-4)}.subscription-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;transition:all var(--transition-fast)}.subscription-card:hover{border-color:var(--primary)}.subscription-card .avatar{width:60px;height:60px;border-radius:var(--radius-full);margin:0 auto var(--space-3);overflow:hidden;background:var(--bg-elevated)}.subscription-card .avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.subscription-card .name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.subscription-card .username{font-size:var(--text-xs);color:var(--text-muted)}header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.alert{padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm)}.alert-success{background:#5f7d1626;border:1px solid var(--primary);color:var(--primary-light)}.profile-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-5)}.profile-card h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.profile-banner{margin-bottom:var(--space-6)}.banner-bg{position:relative;width:100%;height:200px;background-size:cover;background-position:center;background-color:var(--bg-elevated);border-radius:var(--radius-lg);overflow:hidden}.avatar-wrapper{position:absolute;left:var(--space-6);top:50%;transform:translateY(-50%);text-align:center;z-index:5}.banner-avatar{width:120px;height:120px;border-radius:var(--radius-full);border:4px solid var(--bg-surface);-o-object-fit:cover;object-fit:cover;background:var(--bg-elevated);box-shadow:var(--shadow-accent-md)}.change-avatar-label{display:block;margin-top:var(--space-2);padding:var(--space-1) var(--space-3);background:#0009;color:var(--text-primary);font-size:var(--text-xs);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.change-avatar-label:hover{background:var(--primary);color:var(--bg-base)}.change-banner-label{position:absolute;bottom:var(--space-4);right:var(--space-4);padding:var(--space-2) var(--space-4);background:#0009;color:var(--text-primary);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.change-banner-label:hover{background:var(--primary);color:var(--bg-base)}.profile-form{display:flex;flex-direction:column;gap:var(--space-4)}.profile-form .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4)}.profile-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.profile-form .form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.profile-form .form-group input,.profile-form .form-group textarea,.profile-form .form-group select{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--transition-fast)}.profile-form .form-group input:focus,.profile-form .form-group textarea:focus,.profile-form .form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.profile-form .form-group input::-moz-placeholder,.profile-form .form-group textarea::-moz-placeholder{color:var(--text-muted)}.profile-form .form-group input::placeholder,.profile-form .form-group textarea::placeholder{color:var(--text-muted)}.error-text{color:var(--danger);font-size:var(--text-xs);margin-top:var(--space-1)}.save-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-2)}.delete-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--danger);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.delete-btn:hover{background:var(--danger);transform:translateY(-1px)}.muted{color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--space-4)}@media(max-width:768px){.profile-banner,.banner-bg{height:150px}.banner-avatar{width:80px;height:80px}.profile-avatar{width:100px;height:100px;top:-50px}.profile-info{padding-top:var(--space-14)}.profile-details{flex-direction:column}.profile-actions{width:100%}.profile-actions button{flex:1}.profile-stats{justify-content:space-around}.profile-tabs{padding:0 var(--space-4)}.profile-cards,.profile-form .form-grid{grid-template-columns:1fr}}.fl-page{max-width:560px;margin:0 auto}.fl-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.fl-back{color:var(--text-muted);transition:color .2s;display:flex}.fl-back:hover{color:var(--primary)}.fl-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.fl-subtitle{font-size:.875rem;color:var(--text-muted)}.fl-list{display:flex;flex-direction:column;gap:2px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.fl-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.fl-item__left{display:flex;align-items:center;gap:12px;text-decoration:none}.fl-item__avatar{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.fl-item__name{display:block;font-weight:600;color:var(--text-primary);font-size:.9375rem}.fl-item__username{display:block;font-size:.8125rem;color:var(--text-muted)}.fl-btn{padding:6px 18px;border-radius:8px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .2s}.fl-btn--primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#000}.fl-btn--outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-default)}.fl-btn--outline:hover{border-color:var(--primary);color:var(--primary)}.fl-empty{padding:48px 24px;text-align:center;color:var(--text-muted)}.fl-pagination{margin-top:16px}[data-theme=light] .fl-list{background:#fff;border-color:#00000014}@media(max-width:768px){.fl-page{padding:0}.fl-header{gap:10px;margin-bottom:14px}.fl-title{font-size:1.125rem}.fl-subtitle{font-size:.8125rem}.fl-item{padding:10px 12px}.fl-item__avatar{width:40px;height:40px}.fl-item__left{gap:10px}.fl-item__name{font-size:.875rem}.fl-item__username{font-size:.75rem}.fl-btn{padding:5px 14px;font-size:12px}.fl-empty{padding:32px 16px;font-size:.875rem}}@media(max-width:480px){.fl-header{gap:8px;margin-bottom:10px}.fl-back svg{width:18px;height:18px}.fl-title{font-size:1rem}.fl-subtitle{font-size:.75rem}.fl-item{padding:8px 10px}.fl-item__avatar{width:36px;height:36px}.fl-item__left{gap:8px}.fl-item__name{font-size:.8125rem}.fl-item__username{font-size:.6875rem}.fl-btn{padding:4px 12px;font-size:11px;border-radius:6px}.fl-empty{padding:24px 12px;font-size:.8125rem}}@media(max-width:640px){.profile-name{font-size:var(--text-xl)}.form-grid{grid-template-columns:1fr}}.form-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:all var(--transition-fast)}.form-input:hover{border-color:var(--border-strong)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.form-input::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{background:var(--bg-base);color:var(--text-disabled);cursor:not-allowed;opacity:.6}.form-input[type=textarea],textarea.form-input{resize:vertical;min-height:100px;font-family:inherit}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-subtle)}.save-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.save-btn:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 12px #5f7d164d}.save-btn svg{width:18px;height:18px}.save-btn:disabled{background:var(--text-disabled);cursor:not-allowed;transform:none}.btn-cancel{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--bg-elevated);color:var(--text-primary);font-weight:var(--font-medium);font-size:var(--text-sm);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.btn-cancel:hover{border-color:var(--border-strong);background:var(--bg-hover)}.btn-cancel:active{transform:translateY(0)}.btn-cancel svg{width:18px;height:18px}.delete-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--danger);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.delete-btn:hover{background:var(--danger-light);transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.delete-btn:active{transform:translateY(0)}.delete-btn svg{width:18px;height:18px}.profile-card-danger{border-left:4px solid var(--danger)}.profile-card-danger h3{color:var(--danger-light)}.section-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-5);padding:var(--space-4);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-left:3px solid var(--danger);border-radius:var(--radius-md);line-height:1.6}.section-description strong{color:var(--text-primary);font-weight:var(--font-semibold)}.form-group-full{grid-column:1 / -1}@media(max-width:768px){.form-actions{flex-direction:column-reverse}.save-btn,.btn-cancel,.delete-btn{width:100%}.profile-card{padding:var(--space-4)}.profile-card h3{font-size:var(--text-base)}}@media(max-width:640px){.form-input{font-size:16px}.profile-banner{margin-bottom:var(--space-4)}.banner-avatar{width:80px;height:80px;border-width:3px}.change-avatar-label{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.section-description{padding:var(--space-3);font-size:var(--text-xs)}}.profile-edit-page{max-width:1100px;margin:0 auto;padding:0;overflow:hidden;box-sizing:border-box;width:100%}.pe-back-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-muted);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-6);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.pe-back-link:hover{color:var(--text-primary);background:#ffffff0d}.pe-back-link:hover svg{transform:translate(-3px)}.pe-back-link svg{transition:transform var(--transition-fast)}.pe-header{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-8)}.pe-header__icon{width:56px;height:56px;background:var(--primary-100);border:1px solid var(--primary-200);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pe-header__icon svg{color:var(--primary)}.pe-header__text h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0;background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pe-header__text p{font-size:var(--text-sm);color:var(--text-muted);margin:0}.pe-alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-6);font-size:var(--text-sm);font-weight:var(--font-medium);animation:peSlideDown .3s var(--ease-out)}.pe-alert__icon{flex-shrink:0;display:flex}.pe-alert--success{background:var(--success-bg);border:1px solid rgba(16,185,129,.3);color:var(--success-light)}.pe-alert--success .pe-alert__icon svg{color:var(--success)}.pe-alert--error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:var(--danger-light)}.pe-alert--error .pe-alert__icon svg{color:var(--danger)}@keyframes peSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pe-layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-6);align-items:start;min-width:0}.pe-sidebar__card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);position:sticky;top:calc(var(--header-height) + var(--space-6));overflow:hidden}.pe-sidebar__user{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4)}.pe-sidebar__avatar{width:44px;height:44px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-subtle);flex-shrink:0}.pe-sidebar__info{display:flex;flex-direction:column;min-width:0}.pe-sidebar__name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pe-sidebar__username{font-size:var(--text-xs);color:var(--text-muted)}.pe-sidebar__divider{height:1px;background:var(--border-subtle);margin-bottom:var(--space-4)}.pe-sidebar__nav{display:flex;flex-direction:column;gap:var(--space-1)}.pe-sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;transition:all var(--transition-fast);position:relative}.pe-sidebar__link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;background:var(--primary);border-radius:0 var(--radius-xs) var(--radius-xs) 0;transition:transform var(--transition-fast)}.pe-sidebar__link:hover{color:var(--text-primary);background:var(--bg-glass-light)}.pe-sidebar__link.active{color:var(--text-primary);background:var(--primary-100)}.pe-sidebar__link.active:before{transform:translateY(-50%) scaleY(1)}.pe-sidebar__link.active svg{color:var(--primary)}.pe-sidebar__link svg{flex-shrink:0;color:var(--text-muted);transition:color var(--transition-fast)}.pe-sidebar__link--danger{color:var(--text-muted)}.pe-sidebar__link--danger:hover{color:var(--danger-light);background:#ef444414}.pe-sidebar__link--danger.active{color:var(--danger-light);background:#ef44441a}.pe-sidebar__link--danger.active:before{background:var(--danger)}.pe-sidebar__link--danger.active svg{color:var(--danger)}.pe-content{display:flex;flex-direction:column;gap:var(--space-6);min-width:0;overflow:hidden}.pe-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);scroll-margin-top:calc(var(--header-height) + var(--space-4));overflow:hidden;box-sizing:border-box}.pe-card--danger{border-left:4px solid var(--danger)}.pe-card__header{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle)}.pe-card__header-icon{width:44px;height:44px;background:var(--primary-100);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pe-card__header-icon svg{color:var(--primary)}.pe-card__header-icon--accent{background:var(--info-bg)}.pe-card__header-icon--accent svg{color:var(--info)}.pe-card__header-icon--danger{background:var(--danger-bg)}.pe-card__header-icon--danger svg{color:var(--danger)}.pe-card__header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.pe-card__header p{font-size:var(--text-sm);color:var(--text-muted);margin:0}.pe-card__hint{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--text-muted);word-break:break-word}.pe-card__hint svg{flex-shrink:0;color:var(--text-muted)}.pe-banner-preview__bg{position:relative;width:100%;height:200px;background-size:cover;background-position:center;background-color:var(--bg-elevated);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);box-sizing:border-box}.pe-banner-preview__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,10,10,.8) 100%)}.pe-banner-preview__avatar-wrap{position:absolute;left:var(--space-6);bottom:var(--space-5);z-index:5}.pe-banner-preview__avatar{width:100px;height:100px;border-radius:var(--radius-full);border:4px solid var(--bg-surface);-o-object-fit:cover;object-fit:cover;background:var(--bg-elevated);box-shadow:var(--shadow-accent-md);display:block}.pe-banner-preview__avatar-btn{position:absolute;bottom:4px;right:4px;width:32px;height:32px;background:var(--primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.pe-banner-preview__avatar-btn svg{color:var(--bg-base)}.pe-banner-preview__avatar-btn:hover{background:var(--primary-light);transform:scale(1.1)}.pe-banner-preview__change-btn{position:absolute;bottom:var(--space-4);right:var(--space-4);display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#0009;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);z-index:5}.pe-banner-preview__change-btn:hover{background:var(--primary);color:var(--bg-base)}.pe-form{display:flex;flex-direction:column}.pe-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.pe-form__stack{display:flex;flex-direction:column;gap:var(--space-5)}.pe-form__group{display:flex;flex-direction:column;gap:var(--space-2)}.pe-form__group--full{grid-column:1 / -1}.pe-form__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.pe-form__required{color:var(--danger)}.pe-form__input-wrap{position:relative;display:flex;align-items:center;min-width:0}.pe-form__input-icon{position:absolute;left:var(--space-4);color:var(--text-muted);pointer-events:none;z-index:1;transition:color var(--transition-fast)}.pe-form__input-prefix{position:absolute;left:var(--space-4);color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-semibold);pointer-events:none;z-index:1}.pe-form__input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) calc(var(--space-4) + 26px);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:all var(--transition-fast);box-sizing:border-box;min-width:0}.pe-form__input--prefixed{padding-left:calc(var(--space-4) + 16px)}.pe-form__select{padding-left:calc(var(--space-4) + 26px);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;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='rgba(255,255,255,0.4)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.pe-form__select option{background:#1a1d22;color:var(--text-primary)}.pe-form__input:hover{border-color:var(--border-strong)}.pe-form__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.pe-form__input:focus~.pe-form__input-icon,.pe-form__input:focus~.pe-form__input-prefix{color:var(--primary)}.pe-form__input-wrap:focus-within .pe-form__input-icon{color:var(--primary)}.pe-form__input-wrap:focus-within .pe-form__input-prefix{color:var(--primary)}.pe-form__input::-moz-placeholder{color:var(--text-muted)}.pe-form__input::placeholder{color:var(--text-muted)}.pe-form__textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;resize:vertical;min-height:100px;transition:all var(--transition-fast)}.pe-form__textarea:hover{border-color:var(--border-strong)}.pe-form__textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.pe-form__textarea::-moz-placeholder{color:var(--text-muted)}.pe-form__textarea::placeholder{color:var(--text-muted)}.pe-form__error{display:flex;align-items:center;gap:var(--space-1);color:var(--danger);font-size:var(--text-xs);margin-top:var(--space-1)}.pe-form__actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border-subtle)}.pe-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:inherit;border:none;border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.pe-btn svg{width:18px;height:18px;flex-shrink:0}.pe-btn--primary{background:var(--primary);color:var(--bg-base);box-shadow:var(--shadow-accent-sm)}.pe-btn--primary:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-accent-md)}.pe-btn--primary:active{transform:translateY(0)}.pe-btn--secondary{background:var(--bg-elevated);color:var(--text-primary);font-weight:var(--font-medium);border:1px solid var(--border-default)}.pe-btn--secondary:hover{border-color:var(--border-strong);background:var(--bg-hover)}.pe-btn--danger{background:var(--danger);color:#fff;box-shadow:0 4px 12px #ef444433}.pe-btn--danger:hover{background:var(--danger-light);transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.pe-btn--danger:active{transform:translateY(0)}.pe-danger-box{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);padding:var(--space-5);background:#ef44440f;border:1px solid rgba(239,68,68,.15);border-radius:var(--radius-md)}.pe-danger-box__info h3{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.pe-danger-box__info p{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:var(--leading-relaxed)}.pe-danger-box__info strong{color:var(--text-secondary);font-weight:var(--font-semibold)}@media(max-width:1024px){.pe-layout{grid-template-columns:220px 1fr;gap:var(--space-5)}}@media(max-width:768px){.profile-edit-page{padding:0}.pe-layout{grid-template-columns:1fr;gap:var(--space-4)}.pe-sidebar{order:-1}.pe-sidebar__card{position:static;padding:var(--space-3);border-radius:var(--radius-lg)}.pe-sidebar__nav{flex-direction:row;overflow-x:auto;gap:var(--space-2);padding-bottom:var(--space-1);-webkit-overflow-scrolling:touch;scrollbar-width:none}.pe-sidebar__nav::-webkit-scrollbar{display:none}.pe-sidebar__link{white-space:nowrap;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full)}.pe-sidebar__link:before{display:none}.pe-sidebar__link svg{width:16px;height:16px}.pe-sidebar__user,.pe-sidebar__divider{display:none}.pe-back-link{font-size:var(--text-sm);gap:var(--space-1);margin-bottom:var(--space-3);padding:var(--space-1) var(--space-2)}.pe-back-link svg{width:18px;height:18px}.pe-header{margin-bottom:var(--space-4);gap:var(--space-3)}.pe-header__icon{display:none}.pe-header__text h1{font-size:var(--text-xl)}.pe-header__text p{font-size:var(--text-sm)}.pe-alert{padding:var(--space-3);font-size:var(--text-xs);margin-bottom:var(--space-4)}.pe-content{gap:var(--space-4)}.pe-card{padding:var(--space-4);border-radius:var(--radius-lg)}.pe-card__header{gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.pe-card__header-icon{width:38px;height:38px}.pe-card__header-icon svg{width:18px;height:18px}.pe-card__header h2{font-size:var(--text-base)}.pe-card__header p{font-size:var(--text-xs)}.pe-card__hint{font-size:.6875rem;padding:var(--space-2) var(--space-3)}.pe-banner-preview__bg{height:150px;border-radius:var(--radius-md)}.pe-banner-preview__avatar{width:72px;height:72px;border-width:3px}.pe-banner-preview__avatar-wrap{left:var(--space-4);bottom:var(--space-3)}.pe-banner-preview__avatar-btn{width:28px;height:28px}.pe-banner-preview__avatar-btn svg{width:14px;height:14px}.pe-banner-preview__change-btn{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);bottom:var(--space-3);right:var(--space-3)}.pe-form__grid{grid-template-columns:1fr;gap:var(--space-3)}.pe-form__label{font-size:var(--text-xs)}.pe-form__input{font-size:var(--text-sm);padding:var(--space-2) var(--space-3) var(--space-2) calc(var(--space-3) + 22px)}.pe-form__input--prefixed{padding-left:calc(var(--space-3) + 14px)}.pe-form__textarea{min-height:80px;font-size:var(--text-sm)}.pe-form__actions{flex-direction:column-reverse;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4)}.pe-btn{width:100%;justify-content:center;padding:var(--space-3) var(--space-4)}.pe-danger-box{flex-direction:column;align-items:stretch;gap:var(--space-3);padding:var(--space-4)}.pe-danger-box__info h3{font-size:var(--text-sm)}.pe-danger-box__info p{font-size:var(--text-xs)}}@media(max-width:480px){.pe-back-link{font-size:var(--text-xs);margin-bottom:var(--space-2)}.pe-header{margin-bottom:var(--space-3)}.pe-header__text h1{font-size:var(--text-lg)}.pe-header__text p{font-size:var(--text-xs)}.pe-sidebar__card{padding:var(--space-2)}.pe-sidebar__link{font-size:.625rem;padding:var(--space-1) var(--space-2)}.pe-sidebar__link svg{width:14px;height:14px}.pe-card{padding:var(--space-3);border-radius:var(--radius-md)}.pe-card__header{gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-2)}.pe-card__header-icon{width:32px;height:32px}.pe-card__header-icon svg{width:16px;height:16px}.pe-card__header h2{font-size:var(--text-sm)}.pe-card__header p{font-size:.625rem}.pe-banner-preview__bg{height:120px}.pe-banner-preview__avatar{width:56px;height:56px;border-width:2px}.pe-banner-preview__avatar-btn{width:24px;height:24px}.pe-banner-preview__change-btn{font-size:.625rem;padding:var(--space-1) var(--space-2)}.pe-form__grid{gap:var(--space-2)}.pe-form__input{font-size:16px;padding:var(--space-2) var(--space-3) var(--space-2) calc(var(--space-3) + 20px)}.pe-form__textarea{font-size:16px;min-height:70px}.pe-form__actions{margin-top:var(--space-3);padding-top:var(--space-3)}.pe-btn{font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.pe-danger-box{padding:var(--space-3)}.pe-danger-box__info h3{font-size:var(--text-xs)}.pe-danger-box__info p{font-size:.625rem}}.sp-page{max-width:680px;margin:0 auto}.sp-header-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:0}.sp-banner{height:200px;position:relative;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%)}.sp-banner__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sp-banner__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.6) 100%)}.sp-header-body{padding:0 24px 24px;position:relative}.sp-avatar{width:120px;height:120px;border-radius:50%;border:4px solid var(--bg-surface);overflow:hidden;margin-top:-60px;margin-bottom:12px;background:var(--bg-elevated)}.sp-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sp-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sp-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.sp-username{font-size:.9375rem;color:var(--text-muted);display:block;margin:2px 0 14px}.sp-bio{color:var(--text-secondary);font-size:.9375rem;line-height:1.5;margin-top:8px}.sp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.sp-btn--primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#000;box-shadow:0 4px 16px #5f7d1640}.sp-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5f7d1659}.sp-btn--outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-default)}.sp-btn--outline:hover{border-color:var(--primary);color:var(--primary)}.sp-stats-row{display:flex;gap:24px}.sp-stat{display:flex;flex-direction:column;align-items:center;text-decoration:none}.sp-stat--link:hover .sp-stat__value{color:var(--primary)}.sp-stat__value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.sp-stat__label{font-size:.8125rem;color:var(--text-muted)}.sp-tabs{display:flex;border-bottom:1px solid var(--border-subtle);margin-top:16px}.sp-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;font-size:14px;font-weight:600;font-family:inherit;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s}.sp-tab:hover{color:var(--text-secondary)}.sp-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.sp-tab svg{opacity:.7}.sp-tab.active svg{opacity:1;stroke:var(--primary)}.sp-tab-content{display:none;padding-top:16px}.sp-tab-content.active{display:block}.sp-empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.sp-empty svg{margin:0 auto 12px;opacity:.4}.sp-about-grid{display:grid;gap:16px}.sp-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.sp-card__header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.sp-card__header h3{font-size:.9375rem;font-weight:600;margin:0}.sp-detail-list{padding:8px 0}.sp-detail{display:flex;justify-content:space-between;padding:10px 20px}.sp-detail__label{font-size:14px;color:var(--text-muted)}.sp-detail__value{font-size:14px;font-weight:500;color:var(--text-primary)}.sp-mini-stats{display:grid;grid-template-columns:repeat(3,1fr);padding:20px 0}.sp-mini-stat{text-align:center}.sp-mini-stat__value{display:block;font-size:1.25rem;font-weight:700;color:var(--primary)}.sp-mini-stat__label{font-size:.8125rem;color:var(--text-muted)}@media(max-width:768px){.main-content{padding:80px 12px 16px!important}.content-wrapper{padding:0!important;max-width:100%!important;overflow-x:hidden!important}.profile-edit-page{max-width:100%!important;width:100%!important;overflow:hidden!important;padding:0!important}.sp-page{padding:0}.sp-banner{height:150px}.sp-avatar{width:96px;height:96px;margin-top:-48px;margin-bottom:8px;border-width:3px}.sp-name{font-size:1.25rem}.sp-header-body{padding:0 16px 16px}.sp-name-row{gap:8px}.sp-username{font-size:.8125rem;margin-bottom:10px}.sp-bio{font-size:.8125rem}.sp-stats-row{gap:16px}.sp-stat__value{font-size:1rem}.sp-stat__label{font-size:.75rem}.sp-btn{padding:6px 14px;font-size:13px;border-radius:8px}.sp-tabs{margin-top:12px}.sp-tab{padding:10px 8px;font-size:13px;gap:6px}.sp-tab svg{width:16px;height:16px}.sp-tab-content{padding-top:12px}.sp-empty{padding:32px 16px}.sp-empty svg{width:40px;height:40px}.sp-card__header{padding:12px 16px;gap:8px}.sp-card__header h3{font-size:.875rem}.sp-card__header svg{width:16px;height:16px}.sp-detail{padding:8px 16px}.sp-detail__label,.sp-detail__value{font-size:13px}.sp-mini-stats{padding:16px 0}.sp-mini-stat__value{font-size:1.125rem}.sp-mini-stat__label{font-size:.75rem}.pe-back-link{display:inline-flex!important;font-size:13px!important;margin-bottom:12px!important}.pe-header{margin-bottom:16px!important;gap:12px!important}.pe-header__icon{display:none!important}.pe-header__text h1{font-size:1.25rem!important}.pe-header__text p{font-size:.8125rem!important}.pe-layout{display:flex!important;flex-direction:column!important;gap:16px!important;min-width:0!important}.pe-sidebar{order:-1!important;width:100%!important}.pe-sidebar__card{position:static!important;padding:8px!important;border-radius:12px!important}.pe-sidebar__user,.pe-sidebar__divider{display:none!important}.pe-sidebar__nav{display:flex!important;flex-direction:row!important;overflow-x:auto!important;gap:8px!important;scrollbar-width:none!important;-webkit-overflow-scrolling:touch!important}.pe-sidebar__nav::-webkit-scrollbar{display:none!important}.pe-sidebar__link{white-space:nowrap!important;padding:6px 12px!important;font-size:.75rem!important;border-radius:999px!important;flex-shrink:0!important}.pe-sidebar__link:before{display:none!important}.pe-sidebar__link svg{width:16px!important;height:16px!important}.pe-content{min-width:0!important;overflow:hidden!important;gap:16px!important;width:100%!important}.pe-card{padding:16px!important;border-radius:12px!important;overflow:hidden!important;width:100%!important;box-sizing:border-box!important}.pe-card__header{gap:12px!important;margin-bottom:16px!important;padding-bottom:12px!important}.pe-card__header-icon{width:36px!important;height:36px!important}.pe-card__header-icon svg{width:18px!important;height:18px!important}.pe-card__header h2{font-size:.9375rem!important}.pe-card__header p{font-size:.75rem!important}.pe-card__hint{font-size:.6875rem!important;padding:8px 12px!important;word-break:break-word!important;overflow-wrap:break-word!important;white-space:normal!important}.pe-banner-preview__bg{height:140px!important;max-width:100%!important;border-radius:8px!important}.pe-banner-preview__avatar{width:64px!important;height:64px!important;border-width:3px!important}.pe-banner-preview__avatar-wrap{left:12px!important;bottom:10px!important}.pe-banner-preview__avatar-btn{width:26px!important;height:26px!important}.pe-banner-preview__change-btn{font-size:.75rem!important;padding:4px 10px!important;bottom:10px!important;right:10px!important}.pe-form__grid{display:flex!important;flex-direction:column!important;gap:12px!important}.pe-form__label{font-size:.75rem!important}.pe-form__input-wrap{min-width:0!important}.pe-form__input{min-width:0!important;width:100%!important;box-sizing:border-box!important;font-size:16px!important}.pe-form__input--prefixed{padding-left:28px!important}.pe-form__textarea{width:100%!important;box-sizing:border-box!important;font-size:16px!important;min-height:80px!important}.pe-form__actions{flex-direction:column-reverse!important;gap:8px!important;margin-top:16px!important;padding-top:16px!important}.pe-btn{width:100%!important;justify-content:center!important;padding:10px 16px!important;box-sizing:border-box!important}.pe-danger-box{flex-direction:column!important;align-items:stretch!important;gap:12px!important;padding:14px!important}.pe-danger-box__info h3{font-size:.8125rem!important}.pe-danger-box__info p{font-size:.75rem!important}.pe-alert{padding:10px!important;font-size:.75rem!important}}@media(max-width:480px){.sp-banner{height:120px}.sp-avatar{width:76px;height:76px;margin-top:-38px;margin-bottom:6px}.sp-header-body{padding:0 12px 12px}.sp-name{font-size:1.125rem}.sp-name-row{gap:6px}.sp-username{font-size:.75rem;margin-bottom:8px}.sp-bio{font-size:.75rem;line-height:1.4}.sp-stats-row{gap:12px}.sp-stat__value{font-size:.9375rem}.sp-stat__label{font-size:.6875rem}.sp-btn{padding:5px 12px;font-size:12px}.sp-btn svg{width:14px;height:14px}.sp-tab{padding:8px 6px;font-size:12px;gap:4px}.sp-tab svg{width:14px;height:14px}.sp-tab-content{padding-top:8px}.sp-about-grid{gap:12px}.sp-card__header{padding:10px 12px}.sp-card__header h3{font-size:.8125rem}.sp-detail{padding:6px 12px}.sp-detail__label,.sp-detail__value{font-size:12px}.sp-detail-list{padding:4px 0}.sp-mini-stats{padding:12px 0}.sp-mini-stat__value{font-size:1rem}.sp-mini-stat__label{font-size:.6875rem}.sp-empty{padding:24px 12px}.sp-empty svg{width:36px;height:36px}.sp-empty p{font-size:.8125rem}}[data-theme=light] .sp-header-card,[data-theme=light] .sp-card{background:#fff;border-color:#00000014}[data-theme=light] .sp-tabs{border-bottom-color:#00000014}[data-theme=light] .sp-card__header{border-bottom-color:#0000000f}.settings-page{max-width:1100px;margin:0 auto;padding:0}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted, #71717a);text-decoration:none;font-size:14px;font-weight:500;margin-bottom:24px;padding:8px 12px;border-radius:8px;transition:all .2s ease}.back-link:hover{color:var(--text-primary, #f4f4f5);background:#ffffff0d}.back-link svg{transition:transform .2s ease}.back-link:hover svg{transform:translate(-3px)}.settings-header{margin-bottom:32px}.settings-header h1{font-size:2rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#f4f4f5,#a1a1aa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-header p{color:var(--text-secondary, #a1a1aa);margin:0;font-size:15px}.settings-alert{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:12px;margin-bottom:24px;animation:slideDown .3s ease}.settings-alert.success{background:#5f7d161a;border:1px solid rgba(95,125,22,.2);color:#5f7d16}.alert-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#5f7d1626;flex-shrink:0}.settings-layout{display:grid;grid-template-columns:280px 1fr;gap:24px}.settings-sidebar{position:sticky;top:24px;height:-moz-fit-content;height:fit-content}.sidebar-card{background:linear-gradient(165deg,rgba(255,255,255,.03) 0%,transparent 50%),#111114;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:16px}.sidebar-section{padding:8px 0}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted, #71717a);padding:8px 12px;margin-bottom:4px}.sidebar-nav{display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px;color:var(--text-secondary, #a1a1aa);text-decoration:none;border-radius:10px;font-size:14px;font-weight:500;transition:all .2s ease;position:relative}.sidebar-link:hover{background:#ffffff0d;color:var(--text-primary, #f4f4f5)}.sidebar-link.active{background:#5f7d161a;color:var(--text-primary, #f4f4f5)}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:linear-gradient(135deg,#5f7d16,#49610d);border-radius:0 4px 4px 0}.link-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;flex-shrink:0;transition:all .2s ease}.sidebar-link:hover .link-icon,.sidebar-link.active .link-icon{background:#5f7d1626}.sidebar-link.active .link-icon svg{stroke:#5f7d16}.sidebar-divider{height:1px;background:#ffffff0f;margin:8px 0}.settings-content{min-width:0}.content-card{background:linear-gradient(165deg,rgba(255,255,255,.03) 0%,transparent 50%),#111114;border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden}.card-header{display:flex;align-items:flex-start;gap:16px;padding:24px;border-bottom:1px solid rgba(255,255,255,.06)}.header-icon{width:48px;height:48px;background:linear-gradient(135deg,#5f7d16,#49610d);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 24px #5f7d1640}.header-icon svg{stroke:#000}.header-text h2{font-size:1.125rem;font-weight:600;margin:0 0 4px;color:var(--text-primary, #f4f4f5)}.header-text p{font-size:14px;color:var(--text-muted, #71717a);margin:0}.language-form,.appearance-form{padding:24px}.form-group{margin-bottom:24px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-secondary, #a1a1aa);margin-bottom:8px}.select-wrapper{position:relative}.form-select{width:100%;padding:14px 48px 14px 16px;background:#0a0a0ccc;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text-primary, #f4f4f5);font-size:15px;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:all .2s ease}.form-select:hover{border-color:#ffffff26}.form-select:focus{outline:none;border-color:#5f7d16;box-shadow:0 0 0 3px #5f7d1626}.form-select option{background:#111114;color:var(--text-primary, #f4f4f5);padding:12px}.select-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted, #71717a);pointer-events:none}.form-actions{display:flex;justify-content:flex-start}.btn-save{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#5f7d16,#49610d);color:#000;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 24px #5f7d1640}.btn-save:hover{transform:translateY(-2px);box-shadow:0 12px 32px #5f7d1659}.btn-save:active{transform:translateY(0)}.theme-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.theme-card{background:#ffffff08;border:2px solid rgba(255,255,255,.08);border-radius:14px;padding:16px;cursor:pointer;transition:all .25s ease;display:flex;flex-direction:column;gap:14px;text-align:center}.theme-card:hover{border-color:#5f7d164d;background:#ffffff0d}.theme-card.selected{border-color:#5f7d16;background:#5f7d1614;box-shadow:0 0 24px #5f7d1626}.theme-card.selected .theme-card-label{color:#5f7d16;font-weight:600}.theme-preview{border-radius:10px;overflow:hidden;aspect-ratio:16 / 10;border:1px solid rgba(255,255,255,.06)}.theme-preview-dark{background:#0a0a0a}.theme-preview-dark .preview-header{height:14%;background:#141414;border-bottom:1px solid rgba(95,125,22,.15)}.theme-preview-dark .preview-body{display:flex;height:86%}.theme-preview-dark .preview-sidebar{width:25%;background:#111114;border-right:1px solid rgba(255,255,255,.06)}.theme-preview-dark .preview-content{flex:1;padding:10%;display:flex;flex-direction:column;gap:8%}.theme-preview-dark .preview-line{height:8px;background:#ffffff1a;border-radius:4px}.theme-preview-dark .preview-line.short{width:60%}.theme-preview-light{background:#f4f6f8}.theme-preview-light .preview-header{height:14%;background:#fff;border-bottom:1px solid rgba(0,0,0,.08)}.theme-preview-light .preview-body{display:flex;height:86%}.theme-preview-light .preview-sidebar{width:25%;background:#fff;border-right:1px solid rgba(0,0,0,.06)}.theme-preview-light .preview-content{flex:1;padding:10%;display:flex;flex-direction:column;gap:8%}.theme-preview-light .preview-line{height:8px;background:#0000001a;border-radius:4px}.theme-preview-light .preview-line.short{width:60%}.theme-card-label{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-secondary, #a1a1aa);transition:color .2s ease}[data-theme=light] .sidebar-card{background:linear-gradient(165deg,rgba(0,0,0,.01) 0%,transparent 50%),#fff;border-color:#00000014}[data-theme=light] .sidebar-link:hover{background:#0000000a}[data-theme=light] .sidebar-link.active{background:#5f7d1614}[data-theme=light] .sidebar-divider{background:#0000000f}[data-theme=light] .content-card{background:linear-gradient(165deg,rgba(0,0,0,.01) 0%,transparent 50%),#fff;border-color:#00000014}[data-theme=light] .card-header{border-bottom-color:#0000000f}[data-theme=light] .form-select{background:#00000005;border-color:#0000001f;color:var(--text-primary)}[data-theme=light] .form-select option{background:#fff;color:var(--text-primary)}[data-theme=light] .settings-header h1{background:linear-gradient(135deg,#111827,#6b7280);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .theme-card{background:#00000005;border-color:#0000001a}[data-theme=light] .theme-card:hover{background:#0000000a;border-color:#5f7d164d}[data-theme=light] .theme-card.selected{background:#5f7d160f}[data-theme=light] .theme-preview{border-color:#00000014}[data-theme=light] .back-link:hover{background:#0000000a}[data-theme=light] .settings-alert.success{background:#5f7d1614;border-color:#5f7d1626}@media(max-width:900px){.main-content{padding:80px 12px 16px!important}.content-wrapper{padding:0!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box!important}.settings-page{max-width:100vw!important;width:100%!important;overflow:hidden!important;box-sizing:border-box!important}.back-link{font-size:13px!important;margin-bottom:12px!important;padding:6px 10px!important}.settings-header{margin-bottom:16px!important}.settings-header h1{font-size:1.35rem!important}.settings-header p{font-size:13px!important}.settings-alert{padding:12px 14px!important;gap:10px!important;margin-bottom:12px!important}.alert-icon{width:28px!important;height:28px!important}.settings-layout{display:flex!important;flex-direction:column!important;gap:16px!important;width:100%!important}.settings-sidebar{position:static!important;width:100%!important}.sidebar-card{display:flex!important;flex-direction:row!important;gap:6px!important;overflow-x:auto!important;padding:10px!important;border-radius:12px!important;scrollbar-width:none!important;-webkit-overflow-scrolling:touch!important;width:100%!important;box-sizing:border-box!important}.sidebar-card::-webkit-scrollbar{display:none!important}.sidebar-section{flex-shrink:0!important;padding:0!important;display:flex!important;gap:6px!important}.section-label{display:none!important}.sidebar-nav{flex-direction:row!important;gap:6px!important;display:flex!important}.sidebar-link{padding:8px 14px!important;white-space:nowrap!important;font-size:13px!important;gap:8px!important;border-radius:10px!important;flex-shrink:0!important}.sidebar-link.active:before{display:none!important}.sidebar-link.active{border-bottom:2px solid #5f7d16!important;border-radius:10px 10px 0 0!important}.link-icon{width:28px!important;height:28px!important;flex-shrink:0!important}.link-icon svg{width:14px!important;height:14px!important}.sidebar-divider{width:1px!important;height:auto!important;margin:0 4px!important;flex-shrink:0!important}.settings-content{min-width:0!important;width:100%!important;box-sizing:border-box!important}.content-card{border-radius:12px!important;overflow:hidden!important;width:100%!important;box-sizing:border-box!important}.card-header{padding:16px!important;gap:12px!important;flex-direction:column!important}.header-icon{width:36px!important;height:36px!important;border-radius:10px!important}.header-icon svg{width:18px!important;height:18px!important}.header-text h2{font-size:.9375rem!important}.header-text p{font-size:12px!important}.language-form{padding:16px!important}.form-group{margin-bottom:16px!important}.form-label{font-size:13px!important}.form-select{padding:12px 44px 12px 14px!important;font-size:16px!important;border-radius:10px!important;width:100%!important;box-sizing:border-box!important}.select-wrapper{width:100%!important;box-sizing:border-box!important}.btn-save{width:100%!important;justify-content:center!important;padding:12px 20px!important;border-radius:10px!important;box-sizing:border-box!important}.form-actions{display:flex!important}.appearance-form{padding:16px!important}.theme-cards{grid-template-columns:1fr 1fr!important;gap:12px!important;margin-top:10px!important}.theme-card{padding:12px!important;border-radius:12px!important;gap:10px!important;box-sizing:border-box!important}.theme-card-label{font-size:12px!important;gap:6px!important}}@media(max-width:480px){.main-content{padding:72px 8px 12px!important}.settings-header h1{font-size:1.2rem!important}.card-header{padding:14px!important}.header-icon{width:32px!important;height:32px!important}.language-form,.appearance-form{padding:12px!important}.theme-cards{grid-template-columns:1fr!important}.theme-card{padding:10px!important}.sidebar-link{padding:6px 10px!important;font-size:12px!important}.link-icon{width:24px!important;height:24px!important}}.mt-page{max-width:960px;margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-12);display:flex;flex-direction:column;gap:var(--space-6)}.mt-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-2)}.mt-header__icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#f59e0b1f;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-xl);color:var(--warning);flex-shrink:0}.mt-header__text h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.2}.mt-header__text p{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.mt-notification{padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);display:none}.mt-notification.success{display:block;background:#5f7d161a;border:1px solid var(--border-default);color:var(--primary)}.mt-notification.error{display:block;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger)}.mt-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6)}.mt-card__header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-6)}.mt-card__header-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-muted);flex-shrink:0}.mt-card__header-icon--warning{background:#f59e0b1a;border-color:#f59e0b33;color:var(--warning)}.mt-card__header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);line-height:1.3}.mt-card__header p{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.mt-summary-section{border-color:#f59e0b40;background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(245,158,11,.04) 100%)}.mt-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.mt-summary-item{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;display:flex;flex-direction:column;gap:var(--space-1);position:relative;overflow:hidden}.mt-summary-item:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--warning)}.mt-summary-item--protein:before{background:#3b82f6}.mt-summary-item--fat:before{background:#ef4444}.mt-summary-item--carbs:before{background:#5f7d16}.mt-summary-item__value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--warning);font-variant-numeric:tabular-nums}.mt-summary-item--protein .mt-summary-item__value{color:#3b82f6}.mt-summary-item--fat .mt-summary-item__value{color:#ef4444}.mt-summary-item--carbs .mt-summary-item__value{color:#5f7d16}.mt-summary-item__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.mt-meal-selector{display:flex;gap:var(--space-2);margin-bottom:var(--space-5);flex-wrap:wrap}.mt-meal-tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.mt-meal-tab:hover{border-color:var(--warning);color:var(--text-primary)}.mt-meal-tab.active{background:#f59e0b1f;border-color:var(--warning);color:var(--warning);font-weight:var(--font-semibold)}.mt-meal-tab__icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.mt-meal-tab__icon--breakfast{background:#fbbf241f;color:#fbbf24}.mt-meal-tab__icon--lunch{background:#5f7d161f;color:#5f7d16}.mt-meal-tab__icon--dinner{background:#6366f11f;color:#6366f1}.mt-meal-tab__icon--snack{background:#f59e0b1f;color:#f59e0b}.mt-food-form{display:flex;flex-direction:column;gap:var(--space-4)}.mt-form__actions{display:flex;justify-content:flex-end;margin-top:var(--space-2)}.mt-items-list{display:flex;flex-direction:column;gap:var(--space-4)}.mt-food-item{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);transition:border-color var(--transition-fast)}.mt-food-item:hover{border-color:var(--border-default)}.mt-food-item__row{display:flex;align-items:center;gap:var(--space-3)}.mt-food-item__input-group{flex:1;position:relative;min-width:0}.mt-input{padding:var(--space-3);background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--transition-fast);-moz-appearance:textfield}.mt-input::-webkit-outer-spin-button,.mt-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mt-input:focus{outline:none;border-color:var(--warning);box-shadow:0 0 0 3px #f59e0b1a}.mt-input--food{width:100%;text-align:left}.mt-input--qty{width:90px;text-align:center;flex-shrink:0}.mt-lookup-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-md);color:var(--warning);cursor:pointer;transition:all var(--transition-fast);padding:0;flex-shrink:0}.mt-lookup-btn:hover{background:var(--warning);border-color:var(--warning);color:var(--bg-base)}.mt-suggestions{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:var(--space-1);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000004d;max-height:240px;overflow-y:auto}.mt-suggestions__item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.mt-suggestions__item:last-child{border-bottom:none}.mt-suggestions__item:hover{background:#f59e0b14}.mt-suggestions__name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);text-transform:capitalize}.mt-suggestions__meta{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;margin-left:var(--space-3)}.mt-suggestions__loading,.mt-suggestions__empty{padding:var(--space-4);text-align:center;font-size:var(--text-sm);color:var(--text-muted)}.mt-suggestions__loading{color:var(--warning)}.mt-food-item__info{display:flex;gap:var(--space-2);flex-wrap:wrap;padding-top:var(--space-2);border-top:1px solid var(--border-subtle)}.mt-info-tag{display:inline-flex;align-items:center;gap:4px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);font-variant-numeric:tabular-nums}.mt-info-tag--cal{background:#f59e0b1f;color:#f59e0b}.mt-info-tag--protein{background:#3b82f61f;color:#3b82f6}.mt-info-tag--fat{background:#ef44441f;color:#ef4444}.mt-info-tag--carbs{background:#5f7d161f;color:#5f7d16}.mt-info-tag .val{font-weight:var(--font-bold)}.mt-remove-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);padding:0;flex-shrink:0}.mt-remove-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff}.mt-add-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3);background:transparent;border:1px dashed var(--border-default);border-radius:var(--radius-md);color:var(--text-muted);font-size:var(--text-sm);font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.mt-add-btn:hover{border-color:var(--warning);color:var(--warning);background:#f59e0b0f}.error-message{font-size:var(--text-xs);color:var(--danger);margin-top:var(--space-2)}.mt-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:inherit;font-size:var(--text-base);font-weight:var(--font-bold);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);padding:var(--space-4) var(--space-8)}.mt-btn--primary{background:var(--warning);color:var(--bg-base)}.mt-btn--primary:hover{background:var(--warning);transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.mt-btn--primary:active{transform:translateY(0)}.mt-btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.mt-delete-log{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);padding:0}.mt-delete-log:hover{background:var(--danger);border-color:var(--danger);color:#fff}.history-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-lg);overflow:hidden}.history-table thead th{background:var(--bg-elevated);color:var(--text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-default)}.history-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.history-table tbody tr{transition:background var(--transition-fast)}.history-table .no-data{text-align:center;color:var(--text-muted);padding:var(--space-8)}.mt-macros{display:flex;gap:var(--space-1);flex-wrap:wrap}.mt-macros__tag{display:inline-flex;padding:2px 6px;border-radius:var(--radius-sm);font-size:11px;font-weight:var(--font-semibold);font-variant-numeric:tabular-nums}.mt-macros__tag--p{background:#3b82f61f;color:#3b82f6}.mt-macros__tag--f{background:#ef44441f;color:#ef4444}.mt-macros__tag--c{background:#5f7d161f;color:#5f7d16}.pagination{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-5)}.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-sm);text-decoration:none;border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.pagination a:hover:not(.disabled){background:var(--warning);color:var(--bg-base);border-color:var(--warning)}.pagination .current,.pagination span[aria-current=page]{background:var(--warning);color:var(--bg-base);border-color:var(--warning);font-weight:var(--font-semibold)}.pagination .disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.mt-page{padding:var(--space-4) var(--space-3) var(--space-8);gap:var(--space-4)}.mt-header{gap:var(--space-3)}.mt-header__icon{width:44px;height:44px}.mt-header__icon svg{width:22px;height:22px}.mt-header__text h1{font-size:var(--text-xl)}.mt-header__text p{font-size:var(--text-xs)}.mt-card{padding:var(--space-4);border-radius:var(--radius-lg)}.mt-card__header{gap:var(--space-2);margin-bottom:var(--space-4)}.mt-card__header-icon{width:36px;height:36px}.mt-card__header-icon svg{width:18px;height:18px}.mt-card__header h2{font-size:var(--text-base)}.mt-card__header p{font-size:var(--text-xs)}.mt-summary-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.mt-summary-item{padding:var(--space-3)}.mt-summary-item__value{font-size:var(--text-xl)}.mt-summary-item__label{font-size:.625rem}.mt-meal-selector{gap:var(--space-1)}.mt-meal-tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);flex:1;justify-content:center}.mt-food-item{padding:var(--space-3)}.mt-food-item__row{flex-wrap:wrap;gap:var(--space-2)}.mt-food-item__input-group{flex:1 1 100%}.mt-input--qty{flex:1;width:auto}.mt-input{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.mt-lookup-btn{width:36px;height:36px}.mt-btn--primary{width:100%;padding:var(--space-3) var(--space-6);font-size:var(--text-sm)}.mt-form__actions{justify-content:stretch}.mt-add-btn{padding:var(--space-2);font-size:var(--text-xs)}.mt-info-tag{padding:2px var(--space-2);font-size:.6875rem}.history-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}#history-section{overflow:hidden}.history-table{font-size:var(--text-xs);min-width:580px}.history-table thead th,.history-table tbody td{padding:var(--space-2) var(--space-3);white-space:nowrap}.mt-delete-log{width:26px;height:26px}.pagination{gap:var(--space-1);flex-wrap:wrap}.pagination a,.pagination span{min-width:32px;height:32px;font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}}@media(max-width:480px){.mt-page{padding:var(--space-3) var(--space-2) var(--space-6);gap:var(--space-3)}.mt-header__icon{width:38px;height:38px}.mt-header__icon svg{width:20px;height:20px}.mt-header__text h1{font-size:var(--text-lg)}.mt-card{padding:var(--space-3);border-radius:var(--radius-md)}.mt-card__header{margin-bottom:var(--space-3)}.mt-card__header-icon{width:32px;height:32px}.mt-card__header-icon svg{width:16px;height:16px}.mt-card__header h2{font-size:var(--text-sm)}.mt-summary-grid{gap:var(--space-2)}.mt-summary-item{padding:var(--space-2) var(--space-3)}.mt-summary-item__value{font-size:var(--text-lg)}.mt-meal-tab{padding:var(--space-2);gap:var(--space-1)}.mt-meal-tab__icon{width:20px;height:20px}.mt-meal-tab__icon svg{width:12px;height:12px}.mt-food-item{padding:var(--space-2);gap:var(--space-2)}.mt-food-item__row{gap:var(--space-2)}.mt-input{padding:var(--space-2);font-size:var(--text-xs)}.mt-lookup-btn{width:34px;height:34px}.mt-btn--primary{padding:var(--space-3) var(--space-4)}.history-table{min-width:520px}.mt-macros{gap:2px}.mt-macros__tag{font-size:10px;padding:1px 4px}}@media(max-width:360px){.mt-meal-tab__icon{display:none}.mt-summary-item__value{font-size:var(--text-base)}.mt-summary-item__label{font-size:.5625rem}}.calorie-page #mobile-toggle{display:none}.calorie-page main{display:flex;flex-direction:column;gap:var(--space-6)}.calorie-page .calorie-hero,.calorie-page .calorie-card,.calorie-page .calorie-results{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.calorie-page .calorie-hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.95fr);gap:var(--space-6);padding:var(--space-6)}.calorie-page .calorie-hero__eyebrow{display:inline-flex;align-items:center;padding:.35rem .75rem;margin-bottom:var(--space-3);border-radius:var(--radius-full);background:#5f7d161f;color:var(--primary);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.08em;text-transform:uppercase}.calorie-page .calorie-hero h1{margin:0;color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);line-height:1.1}.calorie-page .calorie-hero p{margin:var(--space-3) 0 0;color:var(--text-muted);font-size:var(--text-base);line-height:1.7;max-width:38rem}.calorie-page .calorie-hero__panel{display:grid;gap:var(--space-4)}.calorie-page .calorie-hero__metric,.calorie-page .calorie-snapshot-card,.calorie-page .calorie-metric-card,.calorie-page .calorie-status-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.calorie-page .calorie-hero__metric{padding:var(--space-4)}.calorie-page .calorie-hero__metric span,.calorie-page .calorie-metric-card span,.calorie-page .calorie-snapshot-card span,.calorie-page .calorie-status-card span{display:block;margin-bottom:var(--space-2);color:var(--text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.08em;text-transform:uppercase}.calorie-page .calorie-hero__metric strong{display:block;color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-bold);line-height:1.2}.calorie-page .calorie-hero__metric--accent{border-color:#f59e0b59}.calorie-page .calorie-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(290px,.95fr);gap:var(--space-5)}.calorie-page .calorie-card,.calorie-page .calorie-results{padding:var(--space-6)}.calorie-page .calorie-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5)}.calorie-page .calorie-card__header--stacked{margin-bottom:var(--space-4)}.calorie-page .calorie-card__header h2,.calorie-page .calorie-results__header h2{margin:0;color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-bold)}.calorie-page .calorie-card__header p,.calorie-page .calorie-results__header p{margin:var(--space-2) 0 0;color:var(--text-muted);font-size:var(--text-sm);line-height:1.6}.calorie-page .calorie-card__badge{display:inline-flex;align-items:center;justify-content:center;padding:.45rem .85rem;border-radius:var(--radius-full);background:#0ea5e91f;color:var(--accent);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.06em;text-transform:uppercase}.calorie-page .calorie-form{display:flex;flex-direction:column;gap:var(--space-5)}.calorie-page .calorie-form__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4)}.calorie-page .calorie-field{display:flex;flex-direction:column;gap:var(--space-2)}.calorie-page .calorie-field--full{grid-column:1 / -1}.calorie-page .calorie-field label{color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium)}.calorie-page .calorie-field input,.calorie-page .calorie-field select{width:100%;height:44px;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.calorie-page .calorie-field input:hover,.calorie-page .calorie-field select:hover{border-color:var(--border-strong)}.calorie-page .calorie-field input:focus,.calorie-page .calorie-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-200)}.calorie-page .calorie-field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%2394a3b8' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.calorie-page .calorie-submit-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:var(--space-3) var(--space-6);background:var(--primary);border:none;border-radius:var(--radius-md);color:var(--bg-base);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.calorie-page .calorie-submit-btn:hover{background:var(--primary-light);transform:translateY(-1px)}.calorie-page .calorie-snapshot-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.calorie-page .calorie-snapshot-card,.calorie-page .calorie-metric-card,.calorie-page .calorie-status-card{padding:var(--space-4)}.calorie-page .calorie-snapshot-card strong{display:block;color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:1.5}.calorie-page .calorie-results{display:flex;flex-direction:column;gap:var(--space-5)}.calorie-page .calorie-results__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-4)}.calorie-page .calorie-metric-card strong{display:block;color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-bold);line-height:1.15}.calorie-page .calorie-metric-card small{display:inline-block;margin-top:var(--space-2);color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-medium)}.calorie-page .calorie-metric-card--primary{border-color:#f59e0b59}.calorie-page .calorie-metric-card--protein{border-color:#0ea5e959}.calorie-page .calorie-metric-card--fats{border-color:#f9731659}.calorie-page .calorie-metric-card--carbs{border-color:#5f7d1659}.calorie-page .calorie-status-card p{margin:0;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1.7}.calorie-page .calorie-status-card--under{border-color:#5f7d164d}.calorie-page .calorie-status-card--over{border-color:#ef44444d}.calorie-page .calorie-status-card--balanced{border-color:#f59e0b4d}@media(max-width:1100px){.calorie-page .calorie-layout,.calorie-page .calorie-hero{grid-template-columns:1fr}.calorie-page .calorie-results__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.calorie-page main{gap:var(--space-4)}.calorie-page .calorie-hero,.calorie-page .calorie-card,.calorie-page .calorie-results{padding:var(--space-5)}.calorie-page .calorie-card__header{flex-direction:column}.calorie-page .calorie-form__grid,.calorie-page .calorie-snapshot-grid,.calorie-page .calorie-results__grid{grid-template-columns:1fr}}@media(max-width:480px){.calorie-page .calorie-hero h1{font-size:var(--text-2xl)}.calorie-page .calorie-hero,.calorie-page .calorie-card,.calorie-page .calorie-results{padding:var(--space-4);border-radius:var(--radius-lg)}.calorie-page .calorie-hero p,.calorie-page .calorie-card__header p,.calorie-page .calorie-results__header p,.calorie-page .calorie-status-card p{font-size:var(--text-xs)}}.notif-btn--read-all{background:transparent;border:1px solid var(--border-color, #e5e7eb);color:var(--text-secondary, #6b7280);padding:6px 14px;border-radius:8px;font-size:.8125rem;cursor:pointer;transition:all .15s}.notif-btn--read-all:hover{background:var(--bg-elevated, #f3f4f6);color:var(--text-primary, #111)}.notif-item{text-decoration:none;color:inherit;display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);transition:background .15s}.notif-item:hover{background:var(--bg-elevated, #f9fafb)}.notif-item--unread{background:#6366f10a}.notif-item--unread:hover{background:#6366f114}.notif-item__avatar{position:relative;flex-shrink:0;width:44px;height:44px}.notif-avatar-img{width:44px;height:44px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.notif-type-icon{position:absolute;bottom:-2px;right:-4px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary, #fff)}.notif-type-icon--like{background:#fee2e2;color:#ef4444}.notif-type-icon--comment{background:#dbeafe;color:#3b82f6}.notif-type-icon--mention{background:#ede9fe;color:#8b5cf6}.notif-type-icon svg{width:12px;height:12px}.notif-item__text{margin:0;font-size:.875rem;color:var(--text-primary, #111);line-height:1.4}.notif-item__preview{margin:4px 0 0;font-size:.8125rem;color:var(--text-secondary, #6b7280);line-height:1.3;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:400px}.notif-item__dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:#6366f1;margin-top:6px}.msg-header{display:flex;align-items:center;justify-content:space-between;gap:12px}#fitlife-container main>header h1 span{color:var(--accent)}.water-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.water-progress-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.water-ring-wrap{position:relative;width:160px;height:160px}.water-ring{width:100%;height:100%;transform:rotate(-90deg)}.water-ring__bg{fill:none;stroke:var(--bg-elevated);stroke-width:10}.water-ring__fill{fill:none;stroke:var(--accent);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.water-ring-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;align-items:center}.water-ring-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--accent);line-height:1}.water-ring-unit{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:var(--space-1)}.water-progress-info{width:100%;display:flex;flex-direction:column;gap:var(--space-3)}.water-progress-row{display:flex;justify-content:space-between;align-items:center}.water-progress-label{font-size:var(--text-sm);color:var(--text-muted)}.water-progress-val{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.water-progress-val.goal-done{color:var(--primary)}.water-progress-bar-wrap{width:100%;height:6px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.water-progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--primary));border-radius:var(--radius-full);transition:width .8s ease}.water-add-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column}.water-add-card h3{margin-bottom:var(--space-5)}.water-presets{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}.water-preset-form{display:contents}.water-preset-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-4) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary)}.water-preset-btn:hover{background:#0ea5e91a;border-color:var(--accent);transform:translateY(-2px)}.water-preset-btn:active{transform:translateY(0)}.water-preset-icon{width:24px;height:24px;stroke:var(--accent);opacity:.7}.water-preset-btn:hover .water-preset-icon{opacity:1}.water-preset-amount{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);line-height:1}.water-preset-unit{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase}.water-divider{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.water-divider:before,.water-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.water-divider span{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.water-custom-form{display:flex;gap:var(--space-3);align-items:stretch}.water-custom-input-wrap{flex:1;position:relative}.water-custom-input-wrap input{width:100%;padding:var(--space-3) var(--space-10) var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--transition-fast);height:44px;box-sizing:border-box}.water-custom-input-wrap input:focus{outline:none;border-color:var(--accent)}.water-custom-input-wrap input::-moz-placeholder{color:var(--text-muted)}.water-custom-input-wrap input::placeholder{color:var(--text-muted)}.water-custom-suffix{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);font-size:var(--text-sm);color:var(--text-muted);pointer-events:none}.water-custom-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--accent);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;height:44px}.water-custom-btn svg{width:16px;height:16px}.water-custom-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.water-today-section{margin-bottom:var(--space-6)}.water-today-pills{display:flex;flex-wrap:wrap;gap:var(--space-3)}.water-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full);transition:border-color var(--transition-fast)}.water-pill:hover{border-color:#0ea5e94d}.water-pill-icon{width:16px;height:16px;stroke:var(--accent);flex-shrink:0}.water-pill-amount{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.water-pill-time{font-size:var(--text-xs);color:var(--text-muted)}.water-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);text-align:center}.water-empty svg{width:48px;height:48px;stroke:var(--accent);opacity:.4}.water-empty p{font-size:var(--text-sm);color:var(--text-muted);max-width:280px}.water-amount-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:#0ea5e91a;color:var(--accent);font-weight:var(--font-semibold);font-size:var(--text-xs);border-radius:var(--radius-full)}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}.water-top-grid{grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.water-progress-card{padding:var(--space-4);border-radius:var(--radius-lg);gap:var(--space-4)}.water-ring-wrap{width:130px;height:130px}.water-ring-value{font-size:var(--text-xl)}.water-progress-label,.water-progress-val{font-size:var(--text-xs)}.water-add-card{padding:var(--space-4);border-radius:var(--radius-lg)}.water-add-card h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.water-presets{grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.water-preset-btn{padding:var(--space-2) var(--space-1)}.water-preset-amount{font-size:var(--text-sm)}.water-preset-unit{font-size:.625rem}.water-preset-icon{width:20px;height:20px}.water-custom-form{gap:var(--space-2)}.water-custom-input-wrap input{font-size:var(--text-sm)}.water-custom-btn{font-size:var(--text-sm);padding:var(--space-2) var(--space-4)}.water-today-section{margin-bottom:var(--space-4)}.water-today-pills{gap:var(--space-2)}.water-pill{padding:var(--space-2) var(--space-3)}.water-pill-amount{font-size:var(--text-xs)}.water-pill-time{font-size:.625rem}#fitlife-container section h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.history-table{font-size:var(--text-xs);border-radius:var(--radius-lg)}.history-table th{padding:var(--space-2) var(--space-3);font-size:.625rem}.history-table td{padding:var(--space-2) var(--space-3)}.water-empty{padding:var(--space-8);border-radius:var(--radius-lg)}.water-empty svg{width:36px;height:36px}.water-empty p{font-size:var(--text-sm)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.water-progress-card{padding:var(--space-3);gap:var(--space-3)}.water-ring-wrap{width:110px;height:110px}.water-ring-value{font-size:var(--text-lg)}.water-add-card{padding:var(--space-3)}.water-presets{grid-template-columns:repeat(2,1fr)}.water-custom-form{flex-direction:column}.water-custom-btn{width:100%;justify-content:center}.water-pill{padding:var(--space-1) var(--space-2);gap:var(--space-1)}.water-pill-icon{width:14px;height:14px}.history-table th,.history-table td{padding:var(--space-2)}.water-empty{padding:var(--space-6)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sleep-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.sleep-progress-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.sleep-ring-wrap{position:relative;width:160px;height:160px}.sleep-ring{width:100%;height:100%;transform:rotate(-90deg)}.sleep-ring__bg{fill:none;stroke:var(--bg-elevated);stroke-width:10}.sleep-ring__fill{fill:none;stroke:var(--secondary);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.sleep-ring-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;align-items:center}.sleep-ring-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--secondary);line-height:1}.sleep-ring-unit{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:var(--space-1)}.sleep-progress-info{width:100%;display:flex;flex-direction:column;gap:var(--space-3)}.sleep-progress-row{display:flex;justify-content:space-between;align-items:center}.sleep-progress-label{font-size:var(--text-sm);color:var(--text-muted)}.sleep-progress-val{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.sleep-progress-val.sleep-goal-done{color:var(--primary)}.sleep-progress-bar-wrap{width:100%;height:6px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.sleep-progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--secondary),var(--warning));border-radius:var(--radius-full);transition:width .8s ease}.sleep-add-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column}.sleep-add-card h3{margin-bottom:var(--space-5)}.sleep-form{display:flex;flex-direction:column;gap:var(--space-4);flex:1}.sleep-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.sleep-form .form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.sleep-form .form-group input{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);height:44px}.sleep-form .form-group input:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px #f9731626}.sleep-submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--secondary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);height:44px;margin-top:auto}.sleep-submit-btn svg{width:18px;height:18px}.sleep-submit-btn:hover{background:var(--warning);transform:translateY(-1px)}.sleep-today-section{margin-bottom:var(--space-6)}.sleep-today-pills{display:flex;flex-wrap:wrap;gap:var(--space-3)}.sleep-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full)}.sleep-pill-icon{width:16px;height:16px;stroke:var(--secondary)}.sleep-pill-duration{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--secondary)}.sleep-pill-time{font-size:var(--text-xs);color:var(--text-muted)}.sleep-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);text-align:center;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl)}.sleep-empty svg{width:48px;height:48px;stroke:var(--text-muted);opacity:.5}.sleep-empty p{color:var(--text-muted);font-size:var(--text-base)}.history-table{width:100%;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden}.history-table thead{background:var(--bg-elevated)}.history-table th{padding:var(--space-4);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle)}.history-table td{padding:var(--space-4);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-subtle)}.history-table tbody tr:last-child td{border-bottom:none}.history-table tbody tr:hover{background:var(--bg-elevated)}.sleep-duration-badge{display:inline-flex;align-items:center;padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.sleep-duration-badge--good{background:#5f7d1626;color:var(--primary)}.sleep-duration-badge--ok{background:#f9731626;color:var(--secondary)}.sleep-duration-badge--low{background:#ef444426;color:var(--danger)}.sleep-summary-card{display:flex;align-items:center;gap:var(--space-5);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6)}.sleep-summary-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#f9731626;border-radius:var(--radius-lg);flex-shrink:0}.sleep-summary-icon svg{width:32px;height:32px;stroke:var(--secondary)}.sleep-summary-body{display:flex;flex-direction:column}.sleep-summary-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.sleep-summary-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--secondary);line-height:1.2}.sleep-summary-unit{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}.sleep-top-grid{grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.sleep-progress-card{padding:var(--space-4);border-radius:var(--radius-lg);gap:var(--space-4)}.sleep-ring-wrap{width:130px;height:130px}.sleep-ring-value{font-size:var(--text-xl)}.sleep-progress-label,.sleep-progress-val{font-size:var(--text-xs)}.sleep-add-card{padding:var(--space-4);border-radius:var(--radius-lg)}.sleep-add-card h3{margin-bottom:var(--space-3);font-size:var(--text-base)}.sleep-form{gap:var(--space-3)}.sleep-form .form-group input{height:40px;padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.sleep-form .form-group label{font-size:var(--text-xs)}.sleep-submit-btn{height:40px;font-size:var(--text-sm);padding:var(--space-2) var(--space-4)}.sleep-today-section{margin-bottom:var(--space-4)}.sleep-today-pills{gap:var(--space-2)}.sleep-pill{padding:var(--space-2) var(--space-3)}.sleep-pill-duration{font-size:var(--text-xs)}.sleep-pill-time{font-size:.625rem}#fitlife-container section h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.history-table{font-size:var(--text-xs);border-radius:var(--radius-lg)}.history-table th{padding:var(--space-2) var(--space-3);font-size:.625rem}.history-table td{padding:var(--space-2) var(--space-3)}.sleep-summary-card{flex-direction:column;text-align:center;padding:var(--space-4);gap:var(--space-3);border-radius:var(--radius-lg)}.sleep-summary-icon{width:48px;height:48px}.sleep-summary-icon svg{width:24px;height:24px}.sleep-summary-value{font-size:var(--text-2xl)}.sleep-empty{padding:var(--space-8);border-radius:var(--radius-lg)}.sleep-empty svg{width:36px;height:36px}.sleep-empty p{font-size:var(--text-sm)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.sleep-progress-card{padding:var(--space-3);gap:var(--space-3)}.sleep-ring-wrap{width:110px;height:110px}.sleep-ring-value{font-size:var(--text-lg)}.sleep-add-card{padding:var(--space-3)}.sleep-form .form-group input,.sleep-submit-btn{height:38px}.sleep-pill{padding:var(--space-1) var(--space-2);gap:var(--space-1)}.sleep-pill-icon{width:14px;height:14px}.history-table th,.history-table td{padding:var(--space-2)}.sleep-summary-card{padding:var(--space-3)}.sleep-summary-value{font-size:var(--text-xl)}.sleep-empty{padding:var(--space-6)}}.progress-top-grid{display:grid;grid-template-columns:280px 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.progress-stats-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center}.progress-stats-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#5f7d1626;border-radius:var(--radius-lg)}.progress-stats-icon svg{width:28px;height:28px;stroke:var(--primary)}.progress-stats-body{display:flex;flex-direction:column;align-items:center}.progress-stats-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--primary);line-height:1.2}.progress-stats-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.progress-stats-date{font-size:var(--text-xs);color:var(--text-muted);padding-top:var(--space-3);border-top:1px solid var(--border-subtle);width:100%;text-align:center}.progress-upload-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6)}.progress-upload-form{display:flex;flex-direction:column;gap:var(--space-4)}.progress-file-drop{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--bg-elevated);border:2px dashed var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.progress-file-drop:hover{border-color:var(--primary);background:#5f7d160d}.progress-file-drop svg{width:32px;height:32px;stroke:var(--text-muted);transition:stroke var(--transition-fast)}.progress-file-drop:hover svg{stroke:var(--primary)}.progress-file-drop-text{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary)}.progress-file-drop-hint{font-size:var(--text-xs);color:var(--text-muted)}[data-theme=light] .progress-page .progress-stats-icon{background:#5f7d161f}[data-theme=light] .progress-page .progress-stats-icon svg{stroke:#5f7d16}[data-theme=light] .progress-page .progress-stats-value,[data-theme=light] .progress-page .progress-file-drop-text{color:#5f7d16}.progress-file-drop input[type=file]{position:absolute;width:0;height:0;opacity:0;overflow:hidden}.progress-upload-bottom{display:flex;align-items:flex-end;gap:var(--space-4)}.progress-upload-bottom .form-group{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.progress-upload-bottom .form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.progress-upload-bottom .form-group input[type=text]{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--transition-fast);height:44px}.progress-upload-bottom .form-group input[type=text]:focus{outline:none;border-color:var(--primary)}.progress-upload-bottom .form-group input[type=text]::-moz-placeholder{color:var(--text-muted)}.progress-upload-bottom .form-group input[type=text]::placeholder{color:var(--text-muted)}.calculate-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;height:44px;flex-shrink:0}.calculate-btn svg{width:16px;height:16px}.calculate-btn:hover{background:var(--primary-light)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.photo-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--transition-fast);display:flex;flex-direction:column}.photo-item:hover{border-color:var(--primary)}.photo-img-wrap{position:relative;overflow:hidden}.photo-img-wrap .photo-img{width:100%;height:240px;-o-object-fit:cover;object-fit:cover;cursor:pointer;transition:transform var(--transition-fast);display:block}.photo-item:hover .photo-img{transform:scale(1.03)}.photo-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity var(--transition-fast);cursor:pointer}.photo-overlay svg{width:32px;height:32px;stroke:#fff}.photo-item:hover .photo-overlay{opacity:1}.photo-info{padding:var(--space-4);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border-subtle)}.photo-description{font-size:var(--text-sm);color:var(--text-primary);flex:1}.photo-date{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.photo-actions{padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-2);background:var(--bg-elevated)}.photo-edit-form{flex:1;display:flex;align-items:center;gap:var(--space-2)}.photo-edit-form input[type=text]{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-xs);transition:border-color var(--transition-fast);height:34px}.photo-edit-form input[type=text]:focus{outline:none;border-color:var(--primary)}.photo-action-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;background:var(--bg-surface)}.photo-action-btn svg{width:16px;height:16px}.photo-action-btn--update{color:var(--primary)}.photo-action-btn--update:hover{background:var(--primary);color:var(--bg-base);border-color:var(--primary)}.photo-action-btn--delete{color:var(--danger)}.photo-action-btn--delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.progress-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);text-align:center}.progress-empty svg{width:48px;height:48px;stroke:var(--text-muted);opacity:.5}.progress-empty p{color:var(--text-muted);font-size:var(--text-base)}#lightbox{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:#000000f2;opacity:0;visibility:hidden;transition:all var(--transition-base)}#lightbox[aria-hidden=false]{opacity:1;visibility:visible}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:70vh;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}.lightbox-close{position:absolute;top:-50px;right:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-xl);cursor:pointer;transition:all var(--transition-fast)}.lightbox-close:hover{background:var(--danger);border-color:var(--danger);color:#fff}.lightbox-info{margin-top:var(--space-4);text-align:center}.lightbox-info p{color:var(--text-secondary);font-size:var(--text-sm)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-xl);cursor:pointer;transition:all var(--transition-fast)}.lightbox-nav:hover{background:var(--primary);border-color:var(--primary);color:var(--bg-base)}.lightbox-nav.prev{left:-70px}.lightbox-nav.next{right:-70px}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}.progress-top-grid{grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.progress-stats-card{flex-direction:row;text-align:left;padding:var(--space-4);border-radius:var(--radius-lg);gap:var(--space-3)}.progress-stats-icon{width:44px;height:44px}.progress-stats-icon svg{width:22px;height:22px}.progress-stats-body{align-items:flex-start;flex:1}.progress-stats-value{font-size:var(--text-2xl)}.progress-stats-date{display:none}.progress-upload-card{padding:var(--space-4);border-radius:var(--radius-lg)}.progress-upload-card h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.progress-file-drop{padding:var(--space-4)}.progress-file-drop svg{width:28px;height:28px}.progress-upload-bottom{flex-direction:column;gap:var(--space-3)}.progress-upload-bottom .form-group input[type=text]{height:40px}.calculate-btn{width:100%;height:40px}#fitlife-container section h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.photo-img-wrap .photo-img{height:180px}.photo-overlay{display:none}.photo-info{padding:var(--space-3);flex-direction:column;align-items:flex-start;gap:var(--space-1)}.photo-description{font-size:var(--text-xs)}.photo-date{font-size:.625rem}.photo-actions{padding:var(--space-2) var(--space-3)}.photo-edit-form input[type=text]{font-size:.625rem;height:30px;padding:var(--space-1) var(--space-2)}.photo-action-btn{width:30px;height:30px}.photo-action-btn svg{width:14px;height:14px}.lightbox-nav.prev{left:var(--space-3)}.lightbox-nav.next{right:var(--space-3)}.lightbox-nav{width:40px;height:40px;font-size:var(--text-lg)}.lightbox-close{top:var(--space-3);right:var(--space-3);width:36px;height:36px}.progress-empty{padding:var(--space-8)}.progress-empty svg{width:36px;height:36px}.progress-empty p{font-size:var(--text-sm)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.progress-stats-card{padding:var(--space-3)}.progress-stats-icon{width:38px;height:38px}.progress-stats-value{font-size:var(--text-xl)}.progress-upload-card,.progress-file-drop{padding:var(--space-3)}.gallery-grid{grid-template-columns:1fr 1fr;gap:var(--space-2)}.photo-img-wrap .photo-img{height:140px}.photo-info,.photo-actions{padding:var(--space-2)}.lightbox-content img{max-height:60vh}.progress-empty{padding:var(--space-6)}}.goals-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.goals-stat-card{display:flex;align-items:center;gap:var(--space-4);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5)}.goals-stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.goals-stat-icon svg{width:24px;height:24px}.goals-stat-icon--total{background:#0ea5e926}.goals-stat-icon--total svg{stroke:var(--accent)}.goals-stat-icon--active{background:#f9731626}.goals-stat-icon--active svg{stroke:var(--secondary)}.goals-stat-icon--done{background:#5f7d1626}.goals-stat-icon--done svg{stroke:var(--primary)}.goals-stat-body{display:flex;flex-direction:column}.goals-stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.2}.goals-stat-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.goals-header-section{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.goals-header-section h3{margin-bottom:0!important}.create-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-sm);text-decoration:none;border:none;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;font-family:inherit}.create-btn:hover{background:var(--primary-light);transform:translateY(-1px)}.create-btn svg{width:18px;height:18px}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-5)}.goal-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-fast);display:flex;flex-direction:column;gap:var(--space-4)}.goal-card:hover{border-color:var(--primary);transform:translateY(-2px)}.goal-card--done{border-color:var(--border-strong)}.goal-card-header{display:flex;align-items:flex-start;gap:var(--space-4)}.goal-type-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.goal-type-icon svg{width:22px;height:22px}.goal-type-icon--steps{background:#0ea5e926}.goal-type-icon--steps svg{stroke:var(--accent)}.goal-type-icon--calories{background:#f9731626}.goal-type-icon--calories svg{stroke:var(--secondary)}.goal-type-icon--sleep{background:#a855f726}.goal-type-icon--sleep svg{stroke:var(--purple)}.goal-type-icon--weight{background:#f59e0b26}.goal-type-icon--weight svg{stroke:var(--warning)}.goal-card-title{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.goal-card-title h4{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.3}.goal-badge{display:inline-flex;align-items:center;gap:6px;padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);width:-moz-fit-content;width:fit-content;letter-spacing:.02em}.goal-badge svg{width:12px;height:12px}.goal-badge--active{background:#0ea5e926;color:var(--accent)}.goal-badge--done{background:#5f7d1626;color:var(--primary)}.goal-description-block{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-left:3px solid rgba(95,125,22,.35);border-radius:var(--radius-md)}.goal-description-block svg{width:16px;height:16px;stroke:var(--text-muted);flex-shrink:0;margin-top:2px}.goal-description-block p{margin:0;font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.goal-metrics{display:flex;align-items:stretch;gap:var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4)}.goal-metric{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);flex:1;min-width:0}.goal-metric-divider{width:1px;background:var(--border-subtle);flex-shrink:0}.goal-metric-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.goal-metric-value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);line-height:1.5}.goal-progress-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.goal-progress-label-text{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-medium)}.goal-progress-bar{width:100%;height:10px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--border-subtle)}.goal-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:var(--radius-full);transition:width var(--transition-base)}.goal-card--done .goal-progress-fill{background:var(--primary)}.goal-progress-pct{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--primary);min-width:40px;text-align:right}.goal-progress-pct--done{color:var(--primary)}.log-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);color:var(--primary);font-weight:var(--font-medium);font-size:var(--text-sm);text-decoration:none;border:1px solid var(--primary);border-radius:var(--radius-md);transition:all var(--transition-fast);width:100%;cursor:pointer;font-family:inherit}.log-btn svg{width:16px;height:16px}.log-btn:hover{background:var(--primary);color:var(--bg-base)}.goal-done-label{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);background:#5f7d1614;border:1px solid rgba(95,125,22,.2);border-radius:var(--radius-md);color:var(--primary);font-size:var(--text-sm);font-weight:var(--font-semibold)}.goal-done-label svg{width:18px;height:18px}.gm-backdrop{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:#03060aa3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,visibility .22s ease}.gm-backdrop.gm-open{opacity:1;visibility:visible;pointer-events:auto}.gm-modal{width:min(100%,560px);max-height:min(90vh,760px);overflow-y:auto;background:#0c0f14f5;border:1px solid rgba(95,125,22,.12);border-radius:var(--radius-2xl);box-shadow:0 28px 80px #00000085;opacity:0;transform:translateY(18px) scale(.96);transition:transform .22s ease,opacity .22s ease}.gm-backdrop.gm-open .gm-modal{opacity:1;transform:translateY(0) scale(1)}.gm-modal--sm{width:min(100%,420px)}.gm-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:var(--space-6) var(--space-6) 0}.gm-header-info{display:flex;align-items:center;gap:var(--space-4)}.gm-header-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#5f7d1629}.gm-header-icon svg{width:22px;height:22px;stroke:var(--primary)}.gm-header-icon--log{background:#0ea5e929}.gm-header-icon--log svg{stroke:var(--accent)}.gm-header-info h3{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 2px}.gm-header-info p,.gm-subtitle{margin:0;font-size:var(--text-sm);color:var(--text-muted)}.gm-close{width:34px;height:34px;border:none;border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.gm-close:hover{background:var(--border-subtle);color:var(--text-primary);transform:translateY(-1px)}.gm-close svg{width:16px;height:16px;stroke:currentColor}.gm-body{padding:var(--space-6)}.gm-form{display:flex;flex-direction:column;gap:var(--space-5)}.gm-field{display:flex;flex-direction:column;gap:var(--space-2)}.gm-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary)}.gm-input{width:100%;box-sizing:border-box;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.gm-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #5f7d1626}.gm-input--error{border-color:var(--danger)}.gm-input--error:focus{box-shadow:0 0 0 3px #ef444429}.gm-error{font-size:var(--text-xs);color:var(--danger)}.gm-input--lg{font-size:var(--text-2xl);font-weight:var(--font-bold);text-align:center;padding:var(--space-5) var(--space-4)}.gm-log-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.gm-log-stat{padding:var(--space-4);border-radius:var(--radius-xl);background:linear-gradient(180deg,#ffffff08,#ffffff04);border:1px solid var(--border-subtle);box-shadow:inset 0 1px #ffffff08}.gm-log-stat--accent{border-color:#5f7d162e;background:linear-gradient(180deg,#5f7d161a,#5f7d1608)}.gm-log-stat-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.gm-log-stat-value{display:block;font-size:clamp(1.25rem,3vw,1.9rem);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.1}.gm-log-note{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:#0ea5e914;border:1px solid rgba(14,165,233,.16);color:var(--text-secondary);font-size:var(--text-sm)}.gm-log-note svg{width:16px;height:16px;stroke:var(--accent);flex-shrink:0}.gm-log-input-shell{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-4);border-radius:var(--radius-xl);background:linear-gradient(180deg,#5f7d1614,#5f7d1605);border:1px solid rgba(95,125,22,.14);box-shadow:0 18px 40px #0000002e}.gm-log-input-shell:focus-within{border-color:#5f7d1659;box-shadow:0 18px 40px #0000002e,0 0 0 3px #5f7d1614}.gm-log-input-shell--error{border-color:#ef444459}.gm-log-input-prefix{font-size:clamp(1.25rem,3vw,1.8rem);font-weight:var(--font-bold);color:var(--primary);flex-shrink:0}.gm-log-input{border:none;background:transparent;box-shadow:none!important;padding-left:0;padding-right:0}.gm-log-input::-moz-placeholder{color:#ffffff52}.gm-log-input::placeholder{color:#ffffff52}.gm-submit-btn--log{background:linear-gradient(135deg,#0ea5e9,#38bdf8);box-shadow:0 14px 30px #0ea5e93d}.gm-textarea{min-height:88px;resize:vertical}.gm-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.gm-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.gm-type-tile input{display:none}.gm-type-tile-inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast);text-align:center}.gm-type-tile-inner:hover{border-color:var(--border-strong);background:var(--bg-elevated);transform:translateY(-1px)}.gm-type-tile input:checked+.gm-type-tile-inner{border-color:var(--primary);background:#5f7d1614}.gm-type-tile-inner span{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary)}.gm-type-tile input:checked+.gm-type-tile-inner span{color:var(--primary)}.gm-type-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.gm-type-icon svg{width:18px;height:18px}.gm-type-icon--steps{background:#0ea5e926}.gm-type-icon--steps svg{stroke:var(--accent)}.gm-type-icon--calories{background:#f9731626}.gm-type-icon--calories svg{stroke:var(--secondary)}.gm-type-icon--sleep{background:#a855f726}.gm-type-icon--sleep svg{stroke:var(--purple)}.gm-type-icon--weight{background:#f59e0b26}.gm-type-icon--weight svg{stroke:var(--warning)}.gm-submit-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-4);background:var(--primary);color:var(--bg-base);border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-semibold);font-family:inherit;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast)}.gm-submit-btn:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px)}.gm-submit-btn:disabled{opacity:.6;cursor:not-allowed}.gm-submit-btn svg{width:18px;height:18px}.gm-submit-btn--log{background:var(--accent)}.gm-submit-btn--log:hover:not(:disabled){background:#38bdf8}.goals-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);text-align:center}.goals-empty svg{width:48px;height:48px;stroke:var(--text-muted);opacity:.5}.goals-empty p{color:var(--text-muted);font-size:var(--text-base)}.no-data{grid-column:1 / -1;text-align:center;padding:var(--space-10);color:var(--text-muted);font-size:var(--text-base);background:var(--bg-surface);border:1px dashed var(--border-subtle);border-radius:var(--radius-xl)}.delete-btn{background:transparent;color:var(--danger);border:1px solid var(--danger);cursor:pointer}.delete-btn:hover{background:var(--danger);color:#fff}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}.goals-stats{grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-4)}.goals-stat-card{flex-direction:column;text-align:center;padding:var(--space-3);gap:var(--space-2);border-radius:var(--radius-lg)}.goals-stat-icon{width:36px;height:36px}.goals-stat-icon svg{width:18px;height:18px}.goals-stat-value{font-size:var(--text-lg)}.goals-stat-label{font-size:.625rem}.goals-header-section{flex-direction:row;align-items:center;margin-bottom:var(--space-3)}.goals-header-section h3{font-size:var(--text-base)}.create-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.create-btn svg{width:14px;height:14px}.goals-grid{grid-template-columns:1fr;gap:var(--space-3)}.goal-card{padding:var(--space-4);gap:var(--space-3);border-radius:var(--radius-lg)}.goal-card:hover{transform:none}.goal-card-header{gap:var(--space-3)}.goal-type-icon{width:38px;height:38px}.goal-type-icon svg{width:18px;height:18px}.goal-card-title h4{font-size:var(--text-base)}.goal-description-block{padding:var(--space-3)}.goal-description-block p{font-size:var(--text-xs)}.goal-metrics{flex-direction:column;gap:var(--space-3);padding:var(--space-3)}.goal-metric-divider{display:none}.goal-metric-label{font-size:.625rem}.goal-metric-value,.goal-progress-pct{font-size:var(--text-xs)}.log-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.goal-done-label{font-size:var(--text-xs)}.gm-type-grid{grid-template-columns:repeat(2,1fr)}.gm-log-summary,.gm-row{grid-template-columns:1fr}.gm-modal{width:min(100%,100vw - 24px);max-height:95vh;border-radius:var(--radius-xl)}.gm-header{padding:var(--space-4) var(--space-4) 0}.gm-header-info{align-items:flex-start;gap:var(--space-3)}.gm-header-icon{width:40px;height:40px}.gm-body{padding:var(--space-4)}.gm-log-input-shell{padding:0 var(--space-3)}.goals-empty{padding:var(--space-8)}.goals-empty svg{width:36px;height:36px}.goals-empty p{font-size:var(--text-sm)}.no-data{padding:var(--space-6);font-size:var(--text-sm);border-radius:var(--radius-lg)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.goals-stats{gap:var(--space-1)}.goals-stat-card{padding:var(--space-2)}.goals-stat-icon{width:32px;height:32px}.goals-stat-value{font-size:var(--text-base)}.goals-stat-label{font-size:.5625rem}.goal-card{padding:var(--space-3);gap:var(--space-2)}.goal-type-icon{width:34px;height:34px}.goal-card-title h4{font-size:var(--text-sm)}.goal-metrics{padding:var(--space-2) var(--space-3)}.gm-backdrop{padding:12px}.gm-input--lg{font-size:var(--text-xl);padding:var(--space-4) var(--space-3)}.gm-log-note{font-size:var(--text-xs)}}.back-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;margin-bottom:var(--space-5);transition:color var(--transition-fast)}.back-link svg{width:16px;height:16px}.back-link:hover{color:var(--primary)}.goal-form-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);max-width:640px}.goal-form{display:flex;flex-direction:column;gap:var(--space-5)}.goal-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.goal-form .form-group>label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.goal-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.goal-type-option{cursor:pointer}.goal-type-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.goal-type-option-inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);background:var(--bg-elevated);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast);text-align:center}.goal-type-option-inner span{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);transition:color var(--transition-fast)}.goal-type-option-inner:hover{border-color:var(--text-muted)}.goal-type-option input[type=radio]:checked+.goal-type-option-inner{border-color:var(--primary);background:#5f7d1614}.goal-type-option input[type=radio]:checked+.goal-type-option-inner span{color:var(--primary);font-weight:var(--font-semibold)}.goal-type-option-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.goal-type-option-icon svg{width:20px;height:20px}.goal-type-option-icon--steps{background:#0ea5e926}.goal-type-option-icon--steps svg{stroke:var(--accent)}.goal-type-option-icon--calories{background:#f9731626}.goal-type-option-icon--calories svg{stroke:var(--secondary)}.goal-type-option-icon--sleep{background:#a855f726}.goal-type-option-icon--sleep svg{stroke:var(--purple)}.goal-type-option-icon--weight{background:#f59e0b26}.goal-type-option-icon--weight svg{stroke:var(--warning)}.goal-form .form-group input[type=text],.goal-form .form-group input[type=number],.goal-form .form-group input[type=date],.goal-form .form-group select,.goal-form .form-group textarea{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);height:48px}.goal-form .form-group input:focus,.goal-form .form-group select:focus,.goal-form .form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.goal-form .form-group input::-moz-placeholder,.goal-form .form-group textarea::-moz-placeholder{color:var(--text-muted)}.goal-form .form-group input::placeholder,.goal-form .form-group textarea::placeholder{color:var(--text-muted)}.goal-form .form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a3a3a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer}.goal-form .form-group select option{background:var(--bg-elevated);color:var(--text-primary);padding:var(--space-2)}.goal-form .form-group textarea{min-height:100px;resize:vertical;line-height:1.6;height:auto}.calculate-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-semibold);font-size:var(--text-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:48px}.calculate-btn svg{width:18px;height:18px}.calculate-btn:active{transform:translateY(0)}.form-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.form-actions .calculate-btn{flex:1;min-width:120px}.form-actions a.calculate-btn{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border:1px solid var(--border-default);text-decoration:none!important}.form-actions a.calculate-btn:hover{background:var(--bg-surface)!important;border-color:var(--text-muted)}.goal-form-card form[onsubmit*=confirm] .calculate-btn,button.calculate-btn[style*=dc3545]{background:var(--danger)!important;color:#fff!important;margin-top:var(--space-5)!important}.goal-form-card form[onsubmit*=confirm] .calculate-btn:hover,button.calculate-btn[style*=dc3545]:hover{background:var(--danger)!important}.error-message,.form-group .error{color:var(--danger);font-size:var(--text-sm);margin-top:var(--space-1)}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--danger)}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}#fitlife-container section h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.back-link{font-size:var(--text-xs);margin-bottom:var(--space-3)}.goal-form-card{padding:var(--space-4);border-radius:var(--radius-lg)}.goal-form{gap:var(--space-4)}.goal-type-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.goal-type-option-inner{padding:var(--space-3) var(--space-2);gap:var(--space-1)}.goal-type-option-icon{width:34px;height:34px}.goal-type-option-icon svg{width:16px;height:16px}.goal-type-option-inner span{font-size:.625rem}.form-row{grid-template-columns:1fr;gap:var(--space-3)}.goal-form .form-group input[type=text],.goal-form .form-group input[type=number],.goal-form .form-group input[type=date],.goal-form .form-group select,.goal-form .form-group textarea{height:42px;font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.goal-form .form-group textarea{height:auto;min-height:80px}.goal-form .form-group>label{font-size:var(--text-xs)}.calculate-btn{width:100%;min-height:42px;font-size:var(--text-sm)}.form-actions{flex-direction:column}.form-actions .calculate-btn{width:100%}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.goal-form-card{padding:var(--space-3)}.goal-form{gap:var(--space-3)}.goal-type-option-inner{padding:var(--space-2) var(--space-1)}.goal-type-option-icon{width:30px;height:30px}}#fitlife-container section h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.log-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);max-width:500px}.log-form{display:flex;flex-direction:column;gap:var(--space-5)}.log-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.log-form .form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.log-form .form-group input[type=number]{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.log-form .form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.log-form .form-group input::-moz-placeholder{color:var(--text-muted)}.log-form .form-group input::placeholder{color:var(--text-muted)}.calculate-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-4) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-bold);font-size:var(--text-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.calculate-btn:hover{background:var(--primary-light);transform:translateY(-1px)}@media(max-width:768px){#fitlife-container main>header{margin-bottom:var(--space-4)}#fitlife-container main>header h1{font-size:var(--text-xl)}#fitlife-container main>header p.muted{font-size:var(--text-sm)}#fitlife-container section h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.log-card{padding:var(--space-4);border-radius:var(--radius-lg)}.log-form{gap:var(--space-4)}.log-form .form-group label{font-size:var(--text-xs)}.log-form .form-group input[type=number]{height:42px;font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.calculate-btn{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-lg)}#fitlife-container main>header p.muted{font-size:var(--text-xs)}.log-card{padding:var(--space-3)}.log-form{gap:var(--space-3)}}.community-page{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;max-width:1200px;margin:0 auto;padding:0}@media(max-width:1024px){.community-page{grid-template-columns:1fr}.community-sidebar{display:none}}.community-main{min-width:0}.create-post-box{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem;margin-bottom:1rem;display:flex;align-items:center;gap:1rem;transition:all var(--transition-base)}.create-post-box:hover{border-color:var(--border-strong)}.create-post-avatar{width:40px;height:40px;border-radius:var(--radius-md);-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:2px solid transparent;background:linear-gradient(var(--bg-glass-dark),var(--bg-glass-dark)) padding-box,}.create-post-input{flex:1;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-base)}.create-post-input:hover{border-color:var(--border-strong);background:var(--bg-elevated)}.create-post-actions{display:flex;gap:.5rem}.create-post-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.create-post-btn:hover{background:#5f7d161a;color:var(--primary);border-color:var(--border-strong)}.create-post-btn svg{width:20px;height:20px}.create-post-expanded{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:1rem;overflow:hidden;display:none}.create-post-expanded.active{display:block}.create-post-expanded .create-post-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-default)}.create-post .create-post-header{display:flex;align-items:flex-start;gap:1rem;padding:0;border-bottom:none}.create-post .create-post-header .create-post-avatar{width:48px;height:48px;border-radius:14px;-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:2px solid transparent;background:linear-gradient(var(--bg-glass-dark),var(--bg-glass-dark)) padding-box,}.create-post .create-post-header textarea{flex:1;min-height:80px;padding:.75rem 1rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;outline:none;transition:border-color var(--transition-base)}.create-post .create-post-header textarea:focus{border-color:var(--primary)}.create-post .create-post-header textarea::-moz-placeholder{color:var(--text-muted)}.create-post .create-post-header textarea::placeholder{color:var(--text-muted)}.create-post-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.create-post-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.create-post-close:hover{background:#5f7d161a;color:var(--primary)}.create-post-close svg{width:20px;height:20px}.create-post-body{padding:1.25rem}.create-post-body textarea{width:100%;min-height:120px;background:transparent;border:none;color:var(--text-primary);font-size:1rem;font-family:inherit;line-height:1.5;resize:none;outline:none}.create-post-body textarea::-moz-placeholder{color:var(--text-muted)}.create-post-body textarea::placeholder{color:var(--text-muted)}.create-post-preview{margin-top:1rem;position:relative}.create-post-preview img,.create-post-preview video{max-width:100%;max-height:300px;border-radius:var(--radius-sm);-o-object-fit:contain;object-fit:contain}.create-post-preview .remove-btn{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#000c;border:none;border-radius:var(--radius-full);color:#fff;font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast)}.create-post-preview .remove-btn:hover{background:var(--danger)}.create-post-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-top:1px solid var(--border-default)}.create-post-tools{display:flex;gap:.25rem}.create-post-tool{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.create-post-tool:hover{background:#5f7d161a;color:var(--primary)}.create-post-tool svg{width:20px;height:20px}.create-post-tool input[type=file]{display:none}.create-post-meta{display:flex;align-items:center;gap:1rem}.char-counter{font-size:.75rem;color:var(--text-muted)}.char-counter.warning{color:var(--warning)}.char-counter.danger{color:var(--danger)}.submit-post-btn{padding:.5rem 1.25rem;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#000;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 15px #5f7d164d}.submit-post-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5f7d1666}.submit-post-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.sort-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:1rem}.sort-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.sort-btn:hover{background:#5f7d161a;color:var(--primary)}.sort-btn.active{background:linear-gradient(135deg,#5f7d1626,#06b6d426);color:var(--primary)}.sort-btn svg{width:18px;height:18px}.posts-feed{display:flex;flex-direction:column;gap:.75rem}.post-card{display:flex;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.post-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.post-votes{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;background:#11111180;min-width:44px;border-right:1px solid var(--border-default)}.vote-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base)}.vote-btn:hover{background:#5f7d161a}.vote-btn svg{width:20px;height:20px}.vote-btn.upvote:hover,.vote-btn.upvote.active{color:var(--primary)}.vote-btn.upvote.active svg{fill:var(--primary)}.vote-btn.downvote:hover,.vote-btn.downvote.active{color:var(--danger)}.vote-btn.downvote.active svg{fill:var(--danger)}.vote-count{font-size:.75rem;font-weight:700;background:var(--primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding:.25rem 0}.post-content{flex:1;min-width:0;padding:.75rem 1rem .75rem .75rem}.post-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.75rem}.post-author-avatar{width:24px;height:24px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;border:1px solid var(--border-default)}.post-author{color:var(--text-primary);font-weight:500;text-decoration:none;transition:color var(--transition-base)}.post-author:hover{color:var(--primary)}.post-dot,.post-username,.post-time{color:var(--text-muted)}.post-text{margin-bottom:.75rem;border:none}.post-text p{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;word-wrap:break-word}.post-media{margin-bottom:.75rem;max-width:100%;border:none!important;box-shadow:none;outline:none;background:transparent}.post-media img,.post-media video{width:auto;max-width:100%;max-height:280px;-o-object-fit:contain;object-fit:contain;display:block;border-radius:var(--radius-sm);border:none!important;border-bottom:none!important;box-shadow:none;outline:none}.post-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.post-action{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background:none;border:none;border-radius:0;color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;transition:color var(--transition-base)}.post-action:hover{background:none;color:var(--text-secondary)}.post-action svg{width:18px;height:18px;fill:currentColor}.post-action.comments{color:var(--primary)}.post-action.comments:hover{color:var(--primary-light)}.post-action.comments,.comment-toggle{border-top:none!important;border:none!important}.post-action.share{color:var(--accent)}.post-action.share:hover{color:var(--accent-light)}.post-action.share.shared{color:var(--primary)}.post-action.edit{color:var(--warning)}.post-action.edit:hover{color:var(--warning-light)}.post-action.delete{color:var(--danger)}.post-action.delete:hover{color:var(--danger-light)}.comments-section{padding:1.25rem;display:none;background:#11111180}.comments-section.open{display:block}.comment-form{display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-default)}.comment-form-avatar{width:40px;height:40px;border-radius:var(--radius-md);-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:1px solid var(--border-default)}.comment-form-input{flex:1;display:flex;flex-direction:column;gap:.75rem}.comment-form textarea{width:100%;min-height:80px;padding:.875rem 1rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:none;outline:none;transition:border-color var(--transition-base)}.comment-form-actions{display:flex;justify-content:flex-end}.comment-submit{padding:.625rem 1.5rem;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#000;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 15px #5f7d164d}.comment-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5f7d1666}.comments-list{display:flex;flex-direction:column;gap:0}.comment-item{display:flex;gap:.875rem;padding:1rem 0;border-bottom:1px solid var(--border-default)}.comment-item.is-reply{padding-left:2.5rem;border-bottom:none}.comment-item .comment-avatar{width:36px;height:36px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:1px solid var(--border-default)}.comment-item .comment-content{flex:1;min-width:0}.comment-item .comment-header{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.375rem}.comment-item .comment-author{font-size:.875rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:color var(--transition-base)}.comment-item .comment-author:hover{color:var(--primary)}.comment-item .comment-username{font-size:.8125rem;color:var(--text-muted)}.comment-item .comment-mention{color:var(--primary);font-weight:600}.comment-quote{background:var(--bg-elevated, #f3f4f6);border-left:3px solid var(--primary, #6366f1);border-radius:0 8px 8px 0;padding:6px 10px;margin-bottom:6px;cursor:pointer;transition:background .15s;display:flex;flex-direction:column;gap:2px}.comment-quote:hover{background:#f0f0f0}.comment-quote-author{font-size:.75rem;font-weight:600;color:var(--primary, #6366f1);line-height:1.3}.comment-quote-username{font-weight:400;color:var(--text-muted, #6b7280)}.comment-quote-text{font-size:.8rem;color:var(--text-muted, #6b7280);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.comment-item .comment-text{margin-bottom:.75rem}.comment-item .comment-text p{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;margin:0}.comment-item .comment-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.comment-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.comment-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.comment-btn svg{width:18px;height:18px;fill:currentColor}.comment-btn.like:hover,.comment-btn.like.active{background:#f43f5e1a;color:#f43f5e}.comment-btn.like.active svg{fill:#f43f5e}.comment-btn.dislike:hover,.comment-btn.dislike.active{background:#6366f11a;color:#6366f1}.comment-btn.dislike.active svg{fill:#6366f1}.comment-btn.reply:hover{background:#5f7d161a;color:var(--primary)}.comment-btn.edit:hover{background:#f59e0b1a;color:var(--warning)}.comment-btn.delete:hover{background:#ef44441a;color:var(--danger)}.comment-btn.show-replies{color:var(--accent)}.comment-btn.show-replies:hover{background:#06b6d41a}.inline-delete{display:inline}.comment-edit-form{margin:.75rem 0;padding:1rem;background:#11111180;border:1px solid var(--border-default);border-radius:var(--radius-md)}.comment-edit-form textarea{width:100%;min-height:70px;padding:.75rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:none;outline:none;margin-bottom:.75rem;transition:border-color var(--transition-base)}.comment-edit-form textarea:focus{border-color:var(--primary)}.comment-edit-btns{display:flex;gap:.5rem}.btn-save{padding:.5rem 1rem;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#000;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-save:hover{transform:translateY(-1px)}.btn-cancel{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.btn-cancel:hover{background:#5f7d161a;border-color:var(--border-strong);color:var(--text-primary)}.comment-reply-form{margin-top:.75rem;padding:1rem;background:#11111180;border:1px solid var(--border-default);border-radius:var(--radius-md)}.comment-reply-form textarea{width:100%;min-height:60px;padding:.75rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:none;outline:none;margin-bottom:.75rem;transition:border-color var(--transition-base)}.comment-reply-form textarea:focus{border-color:var(--primary)}.comment-reply-form textarea::-moz-placeholder{color:var(--text-muted)}.comment-reply-form textarea::placeholder{color:var(--text-muted)}.comment-reply-btns{display:flex;gap:.5rem}.btn-reply{padding:.5rem 1rem;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#000;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-reply:hover{background:var(--primary-light)}.comment-replies{margin-top:.5rem}.comment{display:flex;gap:.75rem;padding:.75rem 0}.comment-avatar{width:36px;height:36px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.comment-body{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.comment-author{font-size:.875rem;font-weight:600;color:var(--text-primary);text-decoration:none}.comment-author:hover{text-decoration:underline}.comment-time{font-size:.75rem;color:var(--text-muted)}.comment-text{font-size:.875rem;color:var(--text-secondary);line-height:1.4;margin-bottom:.5rem}.comment-actions{display:flex;align-items:center;gap:.75rem}.comment-action{display:inline-flex;align-items:center;gap:.25rem;background:transparent;border:none;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast)}.comment-action:hover{color:var(--text-primary)}.comment-action svg{width:16px;height:16px}.comment-action.like:hover,.comment-action.like.active{color:#ff4500}.comment-action.dislike:hover,.comment-action.dislike.active{color:#7193ff}.comment-action.reply:hover{color:var(--primary)}.comment-replies{margin-left:2rem;padding-left:1rem;border-left:2px solid rgba(255,255,255,.06)}.reply-form{display:flex;gap:.5rem;margin-top:.75rem;padding:.75rem;background:#ffffff05;border-radius:var(--radius-sm)}.reply-form textarea{flex:1;min-height:40px;padding:.5rem .75rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-primary);font-size:.8125rem;font-family:inherit;resize:none;outline:none}.reply-form-btns{display:flex;flex-direction:column;gap:.25rem}.reply-submit,.reply-cancel{padding:.375rem .75rem;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.reply-submit{background:var(--primary);color:#000}.reply-submit:hover{background:var(--primary-light)}.reply-cancel{background:transparent;color:var(--text-muted)}.reply-cancel:hover{color:var(--text-primary)}.edit-post-form{padding:1rem;background:#11111180;display:none}.edit-post-form.active{display:block}.edit-post-form textarea{width:100%;min-height:100px;padding:.75rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;outline:none;margin-bottom:.75rem;transition:border-color var(--transition-base)}.edit-post-form textarea:focus{border-color:var(--primary)}.edit-post-tools{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.edit-post-btns{display:flex;gap:.5rem}.edit-save-btn,.edit-cancel-btn{padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.edit-save-btn{background:var(--primary);color:#000}.edit-save-btn:hover{transform:translateY(-1px)}.edit-cancel-btn{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary)}.edit-cancel-btn:hover{background:#5f7d161a;border-color:var(--border-strong);color:var(--text-primary)}.community-sidebar{display:flex;flex-direction:column;gap:1rem}.sidebar-card{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.sidebar-card:hover{border-color:var(--border-strong)}.sidebar-card-header{padding:.875rem 1rem;background:var(--primary);color:#000;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.sidebar-card-body{padding:1rem}.sidebar-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.sidebar-card-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.sidebar-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem 0;border-top:1px solid var(--border-default);border-bottom:1px solid var(--border-default)}.sidebar-stat{text-align:center}.sidebar-stat-value{font-size:1.25rem;font-weight:700;background:var(--primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-stat-label{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.sidebar-created{display:flex;align-items:center;gap:.5rem;margin-top:1rem;font-size:.8125rem;color:var(--text-muted)}.sidebar-created svg{width:16px;height:16px;fill:var(--primary)}.community-rules{list-style:none;padding:0;margin:0}.community-rule{display:flex;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border-default)}.community-rule:last-child{border-bottom:none}.rule-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5f7d1626,#06b6d426);border-radius:var(--radius-full);color:var(--primary);font-size:.75rem;font-weight:700;flex-shrink:0}.rule-text{font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.top-users{display:flex;flex-direction:column}.top-user{display:flex;align-items:center;gap:.75rem;padding:.625rem 0;text-decoration:none;transition:all var(--transition-base)}.top-user:hover{opacity:.8}.top-user-rank{width:20px;font-size:.75rem;font-weight:700;color:var(--text-muted)}.top-user-rank.gold{color:var(--warning-light)}.top-user-rank.silver{color:#9ca3af}.top-user-rank.bronze{color:#cd7f32}.top-user-avatar{width:32px;height:32px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;border:1px solid var(--border-default)}.top-user-info{flex:1;min-width:0}.top-user-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-user-posts{font-size:.75rem;color:var(--text-muted)}.alert{padding:.875rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem}.alert-success{background:#5f7d1626;border:1px solid var(--border-default);color:var(--primary)}.alert-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:var(--danger)}.empty-posts{text-align:center;padding:4rem 2rem;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.empty-posts-icon{width:64px;height:64px;margin:0 auto 1rem;background:linear-gradient(135deg,#5f7d161a,#06b6d41a);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.empty-posts-icon svg{width:32px;height:32px;fill:var(--primary)}.empty-posts-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-posts-text{font-size:.875rem;color:var(--text-secondary)}.pagination-wrapper{display:flex;justify-content:center;margin-top:1.5rem}.pagination{display:flex;align-items:center;gap:.25rem}.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .75rem;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;text-decoration:none;transition:all var(--transition-base)}.pagination a:hover{background:#5f7d161a;border-color:var(--border-strong);color:var(--primary)}.pagination span.current{background:var(--primary);border-color:transparent;color:#000;font-weight:600}.pagination span.disabled{opacity:.4;cursor:not-allowed}@media(max-width:640px){.post-card{flex-direction:column}.post-votes{flex-direction:row;justify-content:flex-start;padding:.5rem .75rem;gap:.5rem;border-right:none;border-bottom:1px solid var(--border-default)}.post-content{padding:.75rem}.post-meta{flex-wrap:wrap}.comment-replies{margin-left:1rem;padding-left:.75rem}}.create-post{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem;margin-bottom:1rem;transition:all var(--transition-base)}.create-post:hover{border-color:var(--border-strong)}.create-post textarea{width:100%;min-height:80px;padding:.75rem;background:var(--bg-glass-light);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;outline:none;transition:border-color var(--transition-base)}.create-post textarea:focus{border-color:var(--primary)}.create-post textarea::-moz-placeholder{color:var(--text-muted)}.create-post textarea::placeholder{color:var(--text-muted)}.create-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-default)}.left-controls{display:flex;align-items:center;gap:.5rem}.file-label{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.file-label:hover{background:#5f7d161a;border-color:var(--border-strong)}.file-label input[type=file]{display:none}.file-label svg{width:20px;height:20px;fill:var(--text-secondary)}.file-label:hover svg{fill:var(--primary)}.char-count{font-size:.75rem;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#000;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 15px #5f7d164d}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5f7d1666}.preview-container{margin-top:.75rem;position:relative}.preview-container img,.preview-container video{max-width:100%;max-height:300px;border-radius:var(--radius-md);-o-object-fit:contain;object-fit:contain;border:1px solid var(--border-default)}#remove-media,.remove-media{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0a0a0ae6;border:1px solid var(--border-default);border-radius:var(--radius-sm);color:#fff;font-size:1.25rem;cursor:pointer;transition:all var(--transition-base)}#remove-media:hover,.remove-media:hover{background:var(--danger);border-color:var(--danger)}.post-top{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem}.post-top .avatar{width:40px;height:40px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;border:1px solid var(--border-default)}.post-top .avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.post-top .meta{flex:1}.post-top .name{font-size:.9375rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:color var(--transition-base)}.post-top .name:hover{color:var(--primary)}.post-top .username{font-size:.8125rem;color:var(--text-muted)}.post-top .time{font-size:.75rem;color:var(--text-muted)}.post-body{padding:0 1rem .75rem}.post-body p{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.75rem}.post-body .post-img,.post-body .post-video{width:100%;max-height:400px;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);background:var(--bg-base)}.post-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.5rem 1rem}.action-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:transparent;border:none;border-radius:4px;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:#ffffff0d}.action-btn svg{width:18px;height:18px}.like-btn:hover,.like-btn.active{color:#ff4500}.like-btn.active svg{fill:#ff4500}.dislike-btn:hover,.dislike-btn.active{color:#7193ff}.dislike-btn.active svg{fill:#7193ff}.comment-toggle:hover{color:var(--primary)}.view-count{display:inline-flex;align-items:center;gap:.25rem;margin-left:auto;color:var(--text-muted);font-size:.75rem}.view-count svg{width:18px;height:18px}.edit-post-btn:hover{color:var(--warning)}.delete-btn:hover{color:var(--danger)}[id^=edit-post-form-]{padding:1rem;background:#0003;border-top:1px solid rgba(255,255,255,.06)}[id^=edit-post-form-] textarea{width:100%;min-height:80px;padding:.75rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;outline:none;margin-bottom:.75rem}[id^=edit-post-form-] textarea:focus{border-color:var(--primary)}.cancel-edit{background:#ffffff0d;color:var(--text-muted)}.cancel-edit:hover{background:#ffffff1a;color:var(--text-primary)}.comments{padding:1rem;border-top:1px solid rgba(255,255,255,.06)}.comment-form{display:flex;gap:.5rem;margin-bottom:1rem}.comment-form textarea{flex:1;min-height:40px;padding:.5rem .75rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:none;outline:none}.comment-form textarea:focus{border-color:var(--primary)}.comment-form textarea::-moz-placeholder{color:var(--text-muted)}.comment-form textarea::placeholder{color:var(--text-muted)}.comment-form .btn{padding:.5rem .75rem}.comment-form .btn svg{width:18px;height:18px;fill:#000}.comment-item{display:flex;gap:.75rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.comment-item:last-child{border-bottom:none}.comment-item .avatar{width:28px;height:28px;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.comment-item .avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.comment-item .comment-content{flex:1}.comment-item .comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.comment-item .comment-author{font-size:.8125rem;font-weight:600;color:var(--text-primary);text-decoration:none}.comment-item .comment-author:hover{text-decoration:underline}.comment-item .comment-time{font-size:.75rem;color:var(--text-muted)}.comment-item .comment-text{font-size:.875rem;color:var(--text-secondary);line-height:1.4;margin-bottom:.5rem}.comment-item .comment-actions{display:flex;align-items:center;gap:.75rem}.nested-comments{margin-left:2rem;padding-left:.75rem;border-left:2px solid rgba(255,255,255,.06)}.reply-form{display:flex;gap:.5rem;margin-top:.5rem;padding:.5rem;background:#ffffff05;border-radius:6px}.reply-form textarea{flex:1;min-height:36px;padding:.375rem .625rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-primary);font-size:.8125rem;font-family:inherit;resize:none;outline:none}.reply-form textarea:focus{border-color:var(--primary)}#main-content{max-width:none;padding:0}.comment{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.comment:last-child{border-bottom:none}.comment.reply{margin-left:1.5rem;padding-left:1rem;border-left:2px solid rgba(255,255,255,.08);border-bottom:none}.comment-head{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.375rem}.comment-head strong{font-size:.875rem;font-weight:600;color:var(--text-primary)}.comment-head .username,.comment-head .time{font-size:.75rem;color:var(--text-muted)}.comment-head .in-reply-to{font-size:.75rem}.comment-head .in-reply-to a{color:var(--primary);text-decoration:none}.comment-head .in-reply-to a:hover{text-decoration:underline}.comment-body{margin-bottom:.5rem}.comment-body p{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin:0}.comment .comment-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.comment .comment-actions .action-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:6px;color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.comment .comment-actions .action-btn:hover{background:#ffffff14;border-color:#ffffff1f;color:var(--text-primary)}.comment .comment-actions .action-btn svg{width:18px;height:18px;fill:currentColor}.comment .comment-actions .like-btn:hover,.comment .comment-actions .like-btn.active{color:#ff4500}.comment .comment-actions .like-btn.active svg{fill:#ff4500}.comment .comment-actions .dislike-btn:hover,.comment .comment-actions .dislike-btn.active{color:#7193ff}.comment .comment-actions .dislike-btn.active svg{fill:#7193ff}.comment .comment-actions .reply-btn:hover{color:var(--primary)}.comment .comment-actions .edit-comment-btn:hover{color:var(--warning)}.comment .comment-actions .delete-btn:hover{color:var(--danger)}.comment .comment-actions .show-replies-btn{color:var(--info)}.comment .comment-actions .show-replies-btn:hover{background:#3b82f61a}.comment [id^=edit-comment-form-]{margin-top:.5rem;padding:.75rem;background:#ffffff05;border-radius:var(--radius-sm)}.comment [id^=edit-comment-form-] textarea{width:100%;min-height:60px;padding:.5rem .75rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:none;outline:none;margin-bottom:.5rem}.comment [id^=edit-comment-form-] textarea:focus{border-color:var(--primary)}.comment [id^=edit-comment-form-] .btn{padding:.375rem .75rem;font-size:.75rem}.comment [id^=edit-comment-form-] .cancel-edit-comment{background:#ffffff0d;color:var(--text-muted)}.comment .reply-form{margin-top:.75rem;padding:.75rem;background:#ffffff05;border-radius:var(--radius-sm)}.comment .reply-form textarea{width:100%;min-height:50px;padding:.5rem .75rem;background:var(--bg-glass-light);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-primary);font-size:.8125rem;font-family:inherit;resize:none;outline:none;margin-bottom:.5rem}.comment .reply-form textarea:focus{border-color:var(--primary)}.comment .reply-form .btn{padding:.375rem .75rem;font-size:.75rem}.comment .reply-form .cancel-reply{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary)}.replies-container{margin-top:.5rem}.fs-sm{font-size:.75rem}.text-accent{color:var(--primary)}.inline-form{display:inline}.emoji-picker-wrapper{position:relative}.emoji-trigger{cursor:pointer}.emoji-panel{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:.75rem;box-shadow:0 10px 40px #00000080;z-index:100;min-width:220px}.emoji-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.25rem}.emoji-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:20px;cursor:pointer;transition:all var(--transition-base)}.emoji-btn:hover{background:#5f7d161a;transform:scale(1.15)}.feed-page{min-height:100vh;padding-bottom:120px}.feed-grid{display:grid;grid-template-columns:220px 1fr 220px;gap:1rem;max-width:1400px;margin:0 auto;padding:0;align-items:start}@media(max-width:1100px){.feed-grid{grid-template-columns:1fr}.sidebar-left,.sidebar-right{display:none}}.feed-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:.875rem;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:1rem}.feed-header h1{font-family:Inter,sans-serif;font-size:1.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#fff;margin:0}.feed-tabs{display:flex;gap:.25rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:999px;padding:3px}.feed-tab{padding:.35rem .9rem;border-radius:999px;border:none;background:transparent;color:#ffffff73;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all .2s ease}.feed-tab.active,.feed-tab:hover{background:#5f7d16;color:#07080a}.sidebar{position:sticky;top:88px;display:flex;flex-direction:column;gap:.75rem;max-height:calc(100vh - 100px);overflow-y:auto;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar-card{background:#0d0f13!important;border:1px solid rgba(255,255,255,.06)!important;border-radius:16px!important;padding:1rem!important}.sidebar-title{display:flex!important;align-items:center!important;gap:.5rem!important;font-family:Inter,sans-serif!important;font-size:.78rem!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.1em!important;color:#fff6!important;margin:0 0 .875rem!important}.sidebar-title svg{stroke:#5f7d16!important}.search-box input{width:100%;padding:.6rem .875rem!important;background:#ffffff0a!important;border:1px solid rgba(255,255,255,.07)!important;border-radius:10px!important;color:#f4f7fb!important;font-size:.875rem;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.search-box input:focus{border-color:#5f7d1666!important}.search-box input::-moz-placeholder{color:#ffffff40!important}.search-box input::placeholder{color:#ffffff40!important}.trending-item{display:flex!important;align-items:center!important;gap:.625rem!important;padding:.5rem .375rem!important;border-radius:10px!important;text-decoration:none!important;transition:background .15s!important;cursor:pointer!important}.trending-item:hover{background:#ffffff0a!important}.trending-info{flex:1;min-width:0}.trending-author{display:block!important;font-size:.78rem!important;font-weight:600!important;color:#f4f7fb!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.1rem}.trending-text{font-size:.72rem!important;color:#ffffff59!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.trending-likes{display:flex!important;align-items:center!important;gap:.25rem!important;font-size:.72rem!important;font-weight:700!important;color:#f97316!important;flex-shrink:0}.trending-likes svg{fill:#f97316!important}.stats-grid{display:grid!important;grid-template-columns:1fr 1fr!important;gap:.5rem!important}.stat-item{display:flex!important;flex-direction:column!important;align-items:center!important;padding:.6rem .4rem!important;background:#ffffff08!important;border:1px solid rgba(255,255,255,.05)!important;border-radius:10px!important;text-align:center!important;gap:.15rem!important}.stat-label{font-size:.62rem!important;color:#ffffff59!important;text-transform:uppercase!important;letter-spacing:.06em!important}.stat-value{font-family:Inter,sans-serif!important;font-size:1.4rem!important;font-weight:800!important;color:#5f7d16!important;-webkit-text-fill-color:#5f7d16!important;line-height:1!important}.post{background:#0d0f13!important;border:1px solid rgba(255,255,255,.06)!important;border-radius:16px!important;overflow:hidden;margin-bottom:.75rem;transition:border-color .2s ease}.post:hover{border-color:#ffffff1a!important}.post-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem .625rem;border-bottom:none!important;background:transparent!important}.post-avatar{width:36px!important;height:36px!important;border-radius:50%!important;-o-object-fit:cover;object-fit:cover;border:2px solid rgba(255,255,255,.08)!important;flex-shrink:0}.post-author{display:flex;align-items:center;gap:.625rem;text-decoration:none}.post-author-name{font-size:.875rem!important;font-weight:600!important;color:#f4f7fb!important;line-height:1.2}.post-meta{font-size:.73rem!important;color:#ffffff4d!important;margin-bottom:0!important}.post-text{padding:0 1rem .75rem!important;border:none!important;background:transparent!important}.post-text p{font-size:.9375rem;color:#ffffffb8!important;line-height:1.55;margin:0}.post-media{padding:0 1rem .75rem!important;border:none!important;background:transparent!important;box-shadow:none!important}.post-media img,.post-media video{border-radius:12px!important;border:1px solid rgba(255,255,255,.06)!important;background:#ffffff05;max-height:360px;box-shadow:none!important;outline:none!important}.post-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem .875rem;flex-wrap:wrap;gap:.5rem;border-top:1px solid rgba(255,255,255,.04)}.post-reactions{display:flex;gap:.25rem}.reaction-btn{display:inline-flex!important;align-items:center!important;gap:.375rem!important;padding:.35rem .75rem!important;background:#ffffff0a!important;border:1px solid rgba(255,255,255,.06)!important;border-radius:999px!important;color:#ffffff73!important;font-size:.78rem!important;font-weight:600!important;cursor:pointer;transition:all .2s ease}.reaction-btn.like:hover,.reaction-btn.like.active{background:#ef44441f!important;border-color:#ef44444d!important;color:#ef4444!important}.reaction-btn.dislike:hover,.reaction-btn.dislike.active{background:#a78bfa1f!important;border-color:#a78bfa4d!important;color:#a78bfa!important}.post-actions{display:flex!important;align-items:center!important;gap:.25rem!important;flex-wrap:wrap;padding:0!important;border:none!important}.action-btn{display:inline-flex!important;align-items:center!important;gap:.375rem!important;padding:.35rem .625rem!important;background:transparent!important;border:none!important;border-radius:8px!important;color:#ffffff52!important;font-size:.75rem!important;font-weight:500!important;cursor:pointer;transition:all .15s ease}.action-btn:hover{background:#ffffff0d!important;color:#ffffffa6!important}.action-btn.comment-toggle:hover{color:#5f7d16!important}.action-btn.share:hover{color:#38bdf8!important}.action-btn.views{cursor:default}.post-menu-btn{display:flex!important;align-items:center!important;justify-content:center!important;width:30px!important;height:30px!important;background:transparent!important;border:none!important;border-radius:8px!important;color:#ffffff47!important;cursor:pointer;transition:all .15s}.post-menu-btn:hover{background:#ffffff0f!important;color:#ffffffa6!important}.post-menu-dropdown{position:absolute;right:0;top:calc(100% + 4px);background:#141618!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:12px!important;padding:.375rem!important;min-width:130px;z-index:50;display:none;box-shadow:0 8px 32px #00000080}.post-menu.open .post-menu-dropdown{display:block}.post-menu-item{display:block;width:100%;padding:.5rem .75rem!important;background:transparent!important;border:none!important;border-radius:8px!important;color:#ffffffa6!important;font-size:.8125rem!important;font-weight:500!important;text-align:left;cursor:pointer;transition:background .15s}.post-menu-item:hover{background:#ffffff12!important;color:#ffffffa6!important}.post-menu-item.danger{color:#ef4444!important}.post-menu-item.danger:hover{background:#ef44441f!important}.delete-post-form{margin:0}.comments-section{border-top:1px solid rgba(255,255,255,.05)!important;padding:1rem!important;background:#00000040!important}.comment-form textarea{background:#ffffff0a!important;border:1px solid rgba(255,255,255,.07)!important;border-radius:10px!important;color:#f4f7fb!important}.comment-form textarea:focus{border-color:#5f7d1666!important}.comment-form textarea::-moz-placeholder{color:#ffffff38!important}.comment-form textarea::placeholder{color:#ffffff38!important}.comment-submit,.btn-save,.reply-submit,.btn-reply,.submit-post-btn{background:linear-gradient(135deg,#7b9c29,#5f7d16,#49610d)!important;border:none!important;border-radius:999px!important;color:#07080a!important;font-weight:800!important;letter-spacing:.05em!important;text-transform:uppercase!important;box-shadow:0 4px 12px #5f7d162e!important;transform:none}.comment-submit:hover,.btn-save:hover,.reply-submit:hover,.btn-reply:hover,.submit-post-btn:hover{transform:translateY(-1px)!important;box-shadow:0 6px 18px #5f7d164d!important;color:#07080a!important}.replies-toggle-text{color:#5f7d16a6!important;font-weight:600!important}.replies-toggle-line{background:#5f7d1640!important}.comment-item{border-bottom:1px solid rgba(255,255,255,.04)!important}.comment-item .comment-author{color:#f4f7fb!important}.comment-item .comment-author:hover{color:#5f7d16!important}.comment-item .comment-username,.comment-item .comment-time{color:#ffffff4d!important}.comment-item .comment-text p{color:#ffffffa6!important}[id^=edit-post-form-]{background:#00000040!important;border-top:1px solid rgba(255,255,255,.05)!important}[id^=edit-post-form-] textarea{background:#ffffff0a!important;border:1px solid rgba(255,255,255,.07)!important;border-radius:10px!important;color:#f4f7fb!important}.composer-island{position:fixed!important;bottom:1.25rem!important;left:50%!important;transform:translate(-50%)!important;width:min(680px,calc(100vw - 2rem))!important;z-index:100!important;padding:0 1rem!important;background:none!important;border:none!important;box-shadow:none!important}.composer-island form{display:flex!important;align-items:flex-end!important;gap:.75rem!important;background:#141618!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:18px!important;padding:.75rem 1rem!important;box-shadow:0 20px 60px #0009,0 0 0 1px #5f7d160d!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;transition:border-radius .25s cubic-bezier(.4,0,.2,1)!important}.composer-avatar{width:34px!important;height:34px!important;border-radius:50%!important;flex-shrink:0;border:2px solid rgba(95,125,22,.2)!important;margin-top:2px}@media(max-width:992px){.composer-island{left:20px!important;right:20px!important;transform:none!important;width:auto!important;padding:0!important}.composer-island form{width:100%!important;gap:.5rem!important;padding:.625rem .75rem!important;border-radius:20px!important}.composer-avatar{width:32px!important;height:32px!important}.composer-body textarea{min-height:36px!important;padding:.4375rem 0!important}.composer-tools label,.composer-tools>button{width:32px!important;height:32px!important}.composer-submit{width:38px!important;height:38px!important}}.composer-body textarea{background:transparent!important;border:none!important;color:#f4f7fb!important;font-size:.9375rem;line-height:1.25!important;resize:none;outline:none;width:100%;overflow-y:hidden!important;display:block}.composer-body textarea::-moz-placeholder{color:#ffffff38!important}.composer-body textarea::placeholder{color:#ffffff38!important}.composer-submit{display:flex!important;align-items:center!important;justify-content:center!important;width:36px!important;height:36px!important;flex-shrink:0;background:linear-gradient(135deg,#7b9c29,#5f7d16,#49610d)!important;border:none!important;border-radius:50%!important;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #5f7d1640!important;align-self:center}.composer-submit svg{fill:#07080a!important}.composer-submit:hover{transform:scale(1.08);box-shadow:0 6px 20px #5f7d1659!important}.feed-empty{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;background:#0d0f13;border:1px solid rgba(255,255,255,.06);border-radius:16px;text-align:center;gap:.5rem}.feed-empty h3{font-family:Inter,sans-serif;font-size:1.25rem;font-weight:800;text-transform:uppercase;color:#fff;margin:0}.feed-empty p{font-size:.875rem;color:#ffffff59;margin:0}.sidebar-empty{font-size:.78rem;color:#ffffff47;text-align:center;padding:.5rem 0;margin:0}.calendar-page{--cal-bg: var(--bg-base);--cal-surface: var(--bg-glass-dark);--cal-elevated: var(--bg-glass-light);--cal-border: var(--border-default);--cal-border-hover: var(--bg-hover);--cal-primary: var(--primary);--cal-primary-glow: transparent;--cal-secondary: var(--accent);--cal-gradient: var(--primary);--cal-text: var(--text-primary);--cal-text-secondary: var(--text-secondary);--cal-text-muted: var(--text-muted);--cal-workout: var(--secondary);--cal-running: var(--info);--cal-yoga: var(--purple);--cal-cycling: var(--accent);--cal-swimming: var(--accent);--cal-weightlifting: var(--danger);--cal-rest: #6366f1;--cal-goal: var(--primary);--cal-hiking: #84cc16;--cal-boxing: #f43f5e;--cal-dance: #ec4899;--cal-crossfit: var(--warning);--cal-meditation: #8b5cf6;--cal-walking: #14b8a6;--cal-custom: var(--cal-primary);--cal-danger: var(--danger);--cal-success: var(--primary);--cal-radius-sm: var(--radius-sm);--cal-radius-md: var(--radius-md);--cal-radius-lg: var(--radius-lg);--cal-radius-xl: var(--radius-xl);--cal-shadow: 0 4px 24px rgba(0, 0, 0, .4);--cal-shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--cal-glow: none;background:transparent;min-height:100vh;padding:0}.calendar-header{padding:1.5rem 2rem;border-bottom:1px solid var(--cal-border);background:transparent}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1800px;margin:0 auto}.header-left{display:flex;flex-direction:column;gap:.25rem}.page-title{display:flex;align-items:center;gap:.75rem;font-size:1.75rem;font-weight:700;color:var(--cal-text);margin:0}.page-title svg.title-icon{flex-shrink:0;stroke:var(--cal-primary)}.page-title svg{flex-shrink:0}.page-subtitle{color:var(--cal-text-muted);font-size:.9375rem;margin:0}.header-right{display:flex;align-items:center;gap:.75rem}.today-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);color:var(--cal-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.today-btn:hover{border-color:var(--cal-primary);background:#5f7d161a}.today-btn svg{width:18px;height:18px}.add-event-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--cal-gradient);border:none;border-radius:var(--cal-radius-md);color:#000;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.add-event-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.add-event-btn svg{width:18px;height:18px}.calendar-layout{display:grid;grid-template-columns:360px 1fr 320px;gap:0;max-width:1800px;margin:0 auto;min-height:calc(100vh - 100px)}.calendar-sidebar{padding:1.5rem;border-right:1px solid var(--cal-border);background:transparent;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto;max-height:calc(100vh - 100px)}.mini-calendar-card{background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-lg);padding:1rem}.mini-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.mini-month-year{font-size:.875rem;font-weight:600;color:var(--cal-text)}.mini-nav-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--cal-border);border-radius:var(--cal-radius-sm);color:var(--cal-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.mini-nav-btn:hover{border-color:var(--cal-primary);color:var(--cal-primary);background:#5f7d161a}.mini-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mini-calendar-grid .mini-weekday{padding:.25rem;text-align:center;font-size:.625rem;font-weight:600;color:var(--cal-text-muted);text-transform:uppercase}.mini-calendar-grid .mini-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--cal-text-secondary);border-radius:6px;cursor:pointer;transition:all var(--transition-fast);position:relative}.mini-calendar-grid .mini-day:hover{background:#ffffff0d;color:var(--cal-text)}.mini-calendar-grid .mini-day.today{background:var(--cal-gradient);color:#000;font-weight:600}.mini-calendar-grid .mini-day.selected{background:var(--cal-primary);color:#000;font-weight:600}.mini-calendar-grid .mini-day.other-month{color:var(--cal-text-muted);opacity:.4}.mini-calendar-grid .mini-day.has-event:after{content:"";position:absolute;bottom:3px;width:4px;height:4px;background:var(--cal-primary);border-radius:var(--radius-full)}.mini-calendar-grid .mini-day.today.has-event:after{background:#000}.stats-card{background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-lg);padding:1.25rem}.card-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--cal-text);margin:0 0 1rem}.card-title svg{width:20px;height:20px;color:var(--cal-primary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-item{background:var(--cal-surface);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);padding:.75rem .5rem;text-align:center;transition:all var(--transition-fast);min-width:0}.stat-item:hover{border-color:var(--cal-border-hover)}.stat-value{display:block;font-size:1.25rem;font-weight:700;background:var(--cal-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.stat-label{font-size:.5625rem;color:var(--cal-text-muted);text-transform:uppercase;letter-spacing:.3px;line-height:1.3;word-break:break-word}.legend-card{background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-lg);padding:1.25rem}.legend-items{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.625rem;padding:.375rem .5rem;border-radius:var(--cal-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.legend-item:hover{background:#ffffff08}.legend-item span:last-child{font-size:.8125rem;color:var(--cal-text-secondary)}.legend-color{width:12px;height:12px;border-radius:4px;flex-shrink:0}.legend-color.workout{background:var(--cal-workout)}.legend-color.running{background:var(--cal-running)}.legend-color.yoga{background:var(--cal-yoga)}.legend-color.cycling{background:var(--cal-cycling)}.legend-color.swimming{background:var(--cal-swimming)}.legend-color.weightlifting{background:var(--cal-weightlifting)}.legend-color.rest{background:var(--cal-rest)}.legend-color.goal{background:var(--cal-goal)}.legend-color.hiking{background:var(--cal-hiking)}.legend-color.boxing{background:var(--cal-boxing)}.legend-color.dance{background:var(--cal-dance)}.legend-color.crossfit{background:var(--cal-crossfit)}.legend-color.meditation{background:var(--cal-meditation)}.legend-color.walking{background:var(--cal-walking)}.quick-add-card{background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-lg);padding:1.25rem}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.quick-btn{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem .5rem;background:var(--cal-surface);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);color:var(--cal-text-secondary);font-size:.6875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.quick-btn svg{width:20px;height:20px}.quick-btn.workout:hover{border-color:var(--cal-workout);background:#f973161a;color:var(--cal-workout)}.quick-btn.running:hover{border-color:var(--cal-running);background:#3b82f61a;color:var(--cal-running)}.quick-btn.yoga:hover{border-color:var(--cal-yoga);background:#a855f71a;color:var(--cal-yoga)}.quick-btn.rest:hover{border-color:var(--cal-rest);background:#6366f11a;color:var(--cal-rest)}.calendar-main{padding:1.5rem;background:transparent}.calendar-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1.5rem}.nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--cal-surface);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);color:var(--cal-text);cursor:pointer;transition:all var(--transition-fast)}.nav-btn:hover{border-color:var(--cal-primary);color:var(--cal-primary);background:#5f7d161a}.current-month{font-size:1.5rem;font-weight:600;color:var(--cal-text);min-width:200px;text-align:center;margin:0}.main-calendar{background:transparent;border:none;border-radius:var(--cal-radius-xl);overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:transparent;border-bottom:1px solid var(--cal-border)}.weekday{padding:1rem;text-align:center;font-size:.75rem;font-weight:600;color:var(--cal-text-muted);text-transform:uppercase;letter-spacing:.5px}.weekday.weekend{color:var(--cal-primary)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:100px;padding:.5rem;border-right:1px solid var(--cal-border);border-bottom:1px solid var(--cal-border);cursor:pointer;transition:all var(--transition-fast);position:relative}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:#ffffff05}.calendar-day.other-month{background:#0003}.calendar-day.other-month .day-number{color:var(--cal-text-muted);opacity:.4}.calendar-day.today{background:#5f7d160d}.calendar-day.today .day-number{background:var(--cal-gradient);color:#000;border-radius:var(--radius-sm);padding:.25rem .5rem;font-weight:700}.calendar-day.selected{background:#5f7d161a;box-shadow:inset 0 0 0 2px var(--cal-primary)}.day-number{font-size:.875rem;font-weight:500;color:var(--cal-text);margin-bottom:.375rem}.day-events{display:flex;flex-direction:column;gap:3px}.day-event{display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:4px;font-size:.6875rem;font-weight:500;color:#fff;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-event:hover{transform:scale(1.02);box-shadow:0 2px 8px #0000004d}.day-event.completed{opacity:.6;text-decoration:line-through}.day-event.workout{background:var(--cal-workout)}.day-event.running{background:var(--cal-running)}.day-event.yoga{background:var(--cal-yoga)}.day-event.cycling{background:var(--cal-cycling)}.day-event.swimming{background:var(--cal-swimming)}.day-event.weightlifting{background:var(--cal-weightlifting)}.day-event.rest{background:var(--cal-rest)}.day-event.goal{background:var(--cal-goal)}.day-event.hiking{background:var(--cal-hiking)}.day-event.boxing{background:var(--cal-boxing)}.day-event.dance{background:var(--cal-dance)}.day-event.crossfit{background:var(--cal-crossfit)}.day-event.meditation{background:var(--cal-meditation)}.day-event.walking{background:var(--cal-walking)}.day-event.custom{background:var(--cal-custom)}.more-events{font-size:.6875rem;color:var(--cal-text-muted);padding:2px 6px;cursor:pointer}.more-events:hover{color:var(--cal-primary)}.events-panel{padding:1.5rem;border-left:1px solid var(--cal-border);background:transparent;display:flex;flex-direction:column;overflow-y:auto;max-height:calc(100vh - 100px)}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.panel-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--cal-text);margin:0}.panel-title svg{width:20px;height:20px;color:var(--cal-primary)}.filter-select{padding:.5rem 2rem .5rem .75rem;background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-sm);color:var(--cal-text);font-size:.8125rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer;transition:all var(--transition-fast)}.filter-select:focus{outline:none;border-color:var(--cal-primary)}.events-timeline{flex:1;display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-state svg{color:var(--cal-text-muted);margin-bottom:1rem;opacity:.5}.empty-state p{color:var(--cal-text-muted);font-size:.9375rem;margin:0 0 1.25rem}.add-first-event-btn{padding:.5rem 1rem;background:transparent;border:1px dashed var(--cal-border);border-radius:var(--cal-radius-md);color:var(--cal-text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast)}.add-first-event-btn:hover{border-color:var(--cal-primary);color:var(--cal-primary)}.event-card{background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);padding:1rem;transition:all var(--transition-fast);position:relative;overflow:hidden}.event-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}.event-card.workout:before{background:var(--cal-workout)}.event-card.running:before{background:var(--cal-running)}.event-card.yoga:before{background:var(--cal-yoga)}.event-card.cycling:before{background:var(--cal-cycling)}.event-card.swimming:before{background:var(--cal-swimming)}.event-card.weightlifting:before{background:var(--cal-weightlifting)}.event-card.rest:before{background:var(--cal-rest)}.event-card.goal:before{background:var(--cal-goal)}.event-card.hiking:before{background:var(--cal-hiking)}.event-card.boxing:before{background:var(--cal-boxing)}.event-card.dance:before{background:var(--cal-dance)}.event-card.crossfit:before{background:var(--cal-crossfit)}.event-card.meditation:before{background:var(--cal-meditation)}.event-card.walking:before{background:var(--cal-walking)}.event-card.custom:before{background:var(--cal-custom)}.event-card:hover{border-color:var(--cal-border-hover);transform:translate(4px)}.event-card.completed{opacity:.6}.event-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.event-type-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--cal-radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.event-type-badge.workout{background:#f9731626;color:var(--cal-workout)}.event-type-badge.running{background:#3b82f626;color:var(--cal-running)}.event-type-badge.yoga{background:#a855f726;color:var(--cal-yoga)}.event-type-badge.cycling{background:#06b6d426;color:var(--cal-cycling)}.event-type-badge.swimming{background:#0ea5e926;color:var(--cal-swimming)}.event-type-badge.weightlifting{background:#ef444426;color:var(--cal-weightlifting)}.event-type-badge.rest{background:#6366f126;color:var(--cal-rest)}.event-type-badge.goal{background:#5f7d1626;color:var(--cal-goal)}.event-type-badge.hiking{background:#84cc1626;color:var(--cal-hiking)}.event-type-badge.boxing{background:#f43f5e26;color:var(--cal-boxing)}.event-type-badge.dance{background:#ec489926;color:var(--cal-dance)}.event-type-badge.crossfit{background:#f59e0b26;color:var(--cal-crossfit)}.event-type-badge.meditation{background:#8b5cf626;color:var(--cal-meditation)}.event-type-badge.walking{background:#14b8a626;color:var(--cal-walking)}.event-type-badge.custom{background:#5f7d1626;color:var(--cal-custom)}.event-actions{display:flex;gap:.25rem}.event-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--cal-radius-sm);color:var(--cal-text-muted);cursor:pointer;transition:all var(--transition-fast)}.event-action-btn:hover{background:#ffffff0d;color:var(--cal-text)}.event-action-btn.complete:hover{color:var(--cal-success)}.event-action-btn.delete:hover{color:var(--cal-danger)}.event-description{font-size:.875rem;color:var(--cal-text-secondary);line-height:1.5}.upcoming-section{border-top:1px solid var(--cal-border);padding-top:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--cal-text-muted);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.section-title svg{color:var(--cal-secondary)}.upcoming-list{display:flex;flex-direction:column;gap:.5rem}.upcoming-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);cursor:pointer;transition:all var(--transition-fast)}.upcoming-item:hover{border-color:var(--cal-border-hover)}.upcoming-date{display:flex;flex-direction:column;align-items:center;min-width:40px}.upcoming-date .date-day{font-size:1.125rem;font-weight:700;color:var(--cal-text);line-height:1}.upcoming-date .date-month{font-size:.625rem;color:var(--cal-text-muted);text-transform:uppercase}.upcoming-info{flex:1;min-width:0}.upcoming-type{font-size:.8125rem;font-weight:500;color:var(--cal-text);margin-bottom:.125rem}.upcoming-desc{font-size:.75rem;color:var(--cal-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upcoming-indicator{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.upcoming-indicator.workout{background:var(--cal-workout)}.upcoming-indicator.running{background:var(--cal-running)}.upcoming-indicator.yoga{background:var(--cal-yoga)}.upcoming-indicator.cycling{background:var(--cal-cycling)}.upcoming-indicator.swimming{background:var(--cal-swimming)}.upcoming-indicator.weightlifting{background:var(--cal-weightlifting)}.upcoming-indicator.rest{background:var(--cal-rest)}.upcoming-indicator.goal{background:var(--cal-goal)}.upcoming-indicator.hiking{background:var(--cal-hiking)}.upcoming-indicator.boxing{background:var(--cal-boxing)}.upcoming-indicator.dance{background:var(--cal-dance)}.upcoming-indicator.crossfit{background:var(--cal-crossfit)}.upcoming-indicator.meditation{background:var(--cal-meditation)}.upcoming-indicator.walking{background:var(--cal-walking)}.upcoming-indicator.custom{background:var(--cal-custom)}.modal-overlay{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all var(--transition-base);padding:1rem}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{background:#0d1117;border:1px solid rgba(255,255,255,.08);border-radius:20px;width:100%;max-width:620px;max-height:92vh;overflow-y:auto;transform:scale(.96) translateY(24px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 24px 80px #0009,0 0 0 1px #ffffff0a inset}.modal-overlay.active .modal-content{transform:scale(1) translateY(0)}.modal-content.modal-small{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.375rem 1.75rem;border-bottom:1px solid rgba(255,255,255,.07);background:#ffffff05;border-radius:20px 20px 0 0}.modal-title{font-size:1.125rem;font-weight:700;color:var(--cal-text);margin:0;letter-spacing:-.01em}.modal-title.danger{color:var(--cal-danger)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:50%;color:var(--cal-text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:#ffffff1f;color:var(--cal-text);border-color:#ffffff26}.event-form{padding:1.5rem 1.75rem}.form-row{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.25rem}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;color:var(--cal-text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.form-group label svg{width:16px;height:16px;color:var(--cal-text-muted)}.form-group input[type=date],.form-group textarea{width:100%;padding:.75rem 1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.09);border-radius:12px;color:var(--cal-text);font-size:.9375rem;font-family:inherit;transition:all var(--transition-fast)}.form-group input[type=date]:focus,.form-group textarea:focus{outline:none;border-color:var(--cal-primary);box-shadow:0 0 0 3px #5f7d161f;background:#ffffff0f}.form-group textarea{resize:vertical;min-height:80px}.form-group input::-moz-placeholder,.form-group textarea::-moz-placeholder{color:var(--cal-text-muted)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--cal-text-muted)}.type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:.55rem;align-items:start}.type-option input[type=radio]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:1;top:0;left:0}.type-option{position:relative;display:flex;flex-direction:column;align-items:center;gap:.45rem;cursor:pointer;min-width:0}.type-option .type-icon{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;padding:.6rem;background:#ffffff0a;border:1.5px solid rgba(255,255,255,.08);border-radius:12px;transition:all .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.type-option .type-icon svg{width:22px;height:22px;min-width:22px;min-height:22px;stroke-width:1.75;transition:all .22s ease;opacity:.65}.type-option .type-name{font-size:.5625rem;font-weight:500;text-align:center;color:var(--cal-text-muted);transition:all .22s ease;line-height:1.25;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-word;overflow-wrap:anywhere;text-wrap:balance;min-height:1.40625rem;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.type-option:hover .type-icon{border-color:#ffffff2e;background:#ffffff12;transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.type-option:hover .type-icon svg{opacity:1}.type-option:hover .type-name{color:var(--cal-text-secondary)}.type-option.workout .type-icon svg{fill:var(--cal-workout);stroke:var(--cal-workout)}.type-option.running .type-icon svg{fill:var(--cal-running);stroke:var(--cal-running)}.type-option.yoga .type-icon svg{fill:var(--cal-yoga);stroke:var(--cal-yoga)}.type-option.cycling .type-icon svg{fill:var(--cal-cycling);stroke:var(--cal-cycling)}.type-option.swimming .type-icon svg{fill:var(--cal-swimming);stroke:var(--cal-swimming)}.type-option.weightlifting .type-icon svg{fill:var(--cal-weightlifting);stroke:var(--cal-weightlifting)}.type-option.rest .type-icon svg{fill:var(--cal-rest);stroke:var(--cal-rest)}.type-option.goal .type-icon svg{fill:var(--cal-goal);stroke:var(--cal-goal)}.type-option.hiking .type-icon svg{fill:var(--cal-hiking);stroke:var(--cal-hiking)}.type-option.boxing .type-icon svg{fill:var(--cal-boxing);stroke:var(--cal-boxing)}.type-option.dance .type-icon svg{fill:var(--cal-dance);stroke:var(--cal-dance)}.type-option.crossfit .type-icon svg{fill:var(--cal-crossfit);stroke:var(--cal-crossfit)}.type-option.meditation .type-icon svg{fill:var(--cal-meditation);stroke:var(--cal-meditation)}.type-option.walking .type-icon svg{fill:var(--cal-walking);stroke:var(--cal-walking)}.type-option.custom .type-icon svg{fill:var(--cal-text-muted);stroke:var(--cal-text-muted)}.type-option input:checked+.type-icon{border-width:1.5px;transform:translateY(-2px);box-shadow:0 4px 16px #00000059}.type-option input:checked+.type-icon svg{opacity:1;transform:scale(1.1)}.type-option input:checked~.type-name{color:var(--cal-text);font-weight:600}.type-option.workout input:checked+.type-icon{border-color:var(--cal-workout);background:#f9731626;box-shadow:0 4px 16px #f9731633}.type-option.running input:checked+.type-icon{border-color:var(--cal-running);background:#3b82f626;box-shadow:0 4px 16px #3b82f633}.type-option.yoga input:checked+.type-icon{border-color:var(--cal-yoga);background:#a855f726;box-shadow:0 4px 16px #a855f733}.type-option.cycling input:checked+.type-icon{border-color:var(--cal-cycling);background:#06b6d426;box-shadow:0 4px 16px #06b6d433}.type-option.swimming input:checked+.type-icon{border-color:var(--cal-swimming);background:#0ea5e926;box-shadow:0 4px 16px #0ea5e933}.type-option.weightlifting input:checked+.type-icon{border-color:var(--cal-weightlifting);background:#ef444426;box-shadow:0 4px 16px #ef444433}.type-option.rest input:checked+.type-icon{border-color:var(--cal-rest);background:#6366f126;box-shadow:0 4px 16px #6366f133}.type-option.goal input:checked+.type-icon{border-color:var(--cal-goal);background:#5f7d1626;box-shadow:0 4px 16px #5f7d1633}.type-option.hiking input:checked+.type-icon{border-color:var(--cal-hiking);background:#84cc1626;box-shadow:0 4px 16px #84cc1633}.type-option.boxing input:checked+.type-icon{border-color:var(--cal-boxing);background:#f43f5e26;box-shadow:0 4px 16px #f43f5e33}.type-option.dance input:checked+.type-icon{border-color:var(--cal-dance);background:#ec489926;box-shadow:0 4px 16px #ec489933}.type-option.crossfit input:checked+.type-icon{border-color:var(--cal-crossfit);background:#f59e0b26;box-shadow:0 4px 16px #f59e0b33}.type-option.meditation input:checked+.type-icon{border-color:var(--cal-meditation);background:#8b5cf626;box-shadow:0 4px 16px #8b5cf633}.type-option.walking input:checked+.type-icon{border-color:var(--cal-walking);background:#14b8a626;box-shadow:0 4px 16px #14b8a633}.type-option.custom input:checked+.type-icon{border-color:var(--cal-primary);background:#4ade8026;box-shadow:0 4px 16px #4ade8033}.type-option.custom input:checked+.type-icon svg{fill:var(--cal-primary);stroke:var(--cal-primary)}.custom-type-input{margin-top:.75rem;padding:.75rem;background:var(--cal-elevated);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);animation:slideDown var(--transition-fast)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-type-input label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;color:var(--cal-text-secondary);margin-bottom:.5rem}.custom-type-input label svg{color:var(--cal-primary)}.custom-type-input input{width:100%;padding:.625rem .875rem;background:var(--cal-card);border:1px solid var(--cal-border);border-radius:var(--cal-radius-sm);color:var(--cal-text);font-size:.875rem;transition:all var(--transition-fast)}.custom-type-input input:focus{outline:none;border-color:var(--cal-primary);box-shadow:0 0 0 3px var(--primary-100)}.custom-type-input input::-moz-placeholder{color:var(--cal-text-muted)}.custom-type-input input::placeholder{color:var(--cal-text-muted)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.07);margin-top:1.25rem}.btn-cancel{padding:.625rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--cal-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{background:#ffffff17;border-color:#ffffff26;color:var(--cal-text)}.btn-save{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--cal-primary);border:none;border-radius:10px;color:#000;font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);letter-spacing:-.01em}.btn-save:hover{transform:translateY(-2px);box-shadow:0 8px 24px #5f7d1659;background:#4ade80}.btn-delete{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--cal-danger);border:none;border-radius:var(--cal-radius-md);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-delete:hover{background:var(--danger);transform:translateY(-2px)}.delete-content{display:flex;flex-direction:column;align-items:center;padding:2rem;text-align:center}.delete-content svg{margin-bottom:1rem}.delete-content p{color:var(--cal-text-secondary);font-size:.9375rem;margin:0}.toast-container{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.75rem;z-index:1100}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--cal-surface);border:1px solid var(--cal-border);border-radius:var(--cal-radius-md);box-shadow:var(--cal-shadow);animation:slideIn var(--transition-base);max-width:350px}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.success{border-left:4px solid var(--cal-success)}.toast.error{border-left:4px solid var(--cal-danger)}.toast-icon{width:24px;height:24px;flex-shrink:0}.toast.success .toast-icon{color:var(--cal-success)}.toast.error .toast-icon{color:var(--cal-danger)}.toast-message{font-size:.875rem;color:var(--cal-text)}.toast-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--cal-text-muted);cursor:pointer;margin-left:auto;flex-shrink:0}.toast-close:hover{color:var(--cal-text)}@media(max-width:1400px){.calendar-layout{grid-template-columns:260px 1fr 280px}}@media(max-width:1200px){.calendar-layout{grid-template-columns:1fr 280px}.calendar-sidebar{display:none}.calendar-main{padding:1rem}.calendar-day{min-height:80px}}@media(max-width:900px){.calendar-layout{grid-template-columns:1fr}.events-panel{display:none}}@media(max-width:768px){.calendar-page{padding-bottom:0}.calendar-header{padding:1rem}.header-content{flex-direction:column;align-items:stretch;gap:.75rem}.header-left{gap:.125rem}.page-title{font-size:1.25rem;gap:.5rem}.page-title svg.title-icon{width:24px;height:24px}.page-subtitle{font-size:.8125rem}.header-right{width:100%;gap:.5rem}.today-btn,.add-event-btn{flex:1;justify-content:center;padding:.5rem .75rem;font-size:.8125rem}.calendar-main{padding:.75rem}.calendar-nav{gap:.75rem;margin-bottom:1rem}.current-month{font-size:1.125rem;min-width:auto}.nav-btn{width:36px;height:36px}.main-calendar{border-radius:var(--cal-radius-lg)}.weekday{padding:.625rem .25rem;font-size:.625rem;letter-spacing:0}.calendar-day{min-height:56px;padding:.375rem}.day-number{font-size:.75rem}.day-event{padding:2px 4px;font-size:.5625rem}.modal-content{max-height:95vh;border-radius:var(--cal-radius-lg);margin:.5rem}.modal-header{padding:1rem}.modal-title{font-size:1.125rem}.event-form{padding:1rem}.type-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.type-option{padding:.625rem .375rem}.type-icon{width:28px;height:28px}.type-icon svg{width:16px;height:16px}.type-name{font-size:.625rem}.toast-container{left:.75rem;right:.75rem;bottom:.75rem}.toast{max-width:none}}@media(max-width:480px){.calendar-header{padding:.75rem}.page-title{font-size:1.0625rem}.page-title svg.title-icon{width:22px;height:22px}.page-subtitle{font-size:.75rem}.today-btn,.add-event-btn{padding:.5rem;font-size:.75rem;gap:.375rem}.today-btn svg,.add-event-btn svg{width:16px;height:16px}.calendar-main{padding:.5rem}.calendar-nav{gap:.5rem;margin-bottom:.75rem}.current-month{font-size:1rem}.nav-btn{width:34px;height:34px}.main-calendar{border-radius:var(--cal-radius-md)}.weekday{padding:.5rem .125rem;font-size:.5625rem}.calendar-day{min-height:44px;padding:.25rem}.calendar-day.today .day-number{padding:.125rem .375rem;font-size:.6875rem}.day-number{font-size:.6875rem}.day-events{display:none}.calendar-day.has-events:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;background:var(--cal-primary);border-radius:var(--radius-full)}.type-grid{grid-template-columns:repeat(3,1fr);gap:.375rem}.type-option{padding:.5rem .25rem}.modal-actions{flex-direction:column;padding:1rem}.btn-cancel,.btn-save,.btn-delete{width:100%;justify-content:center}}@media(max-width:360px){.calendar-day{min-height:38px}.day-number{font-size:.625rem}.type-grid{grid-template-columns:repeat(2,1fr)}.today-btn span,.add-event-btn span{display:none}.today-btn,.add-event-btn{padding:.625rem}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.loading{animation:pulse 1.5s ease-in-out infinite}.fade-in{animation:fadeIn var(--transition-base)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp var(--transition-base)}#mobile-toggle{display:none}#fitlife-container main>header{margin-bottom:var(--space-6)}#fitlife-container main>header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}#fitlife-container main>header h1 span{color:var(--primary)}#fitlife-container main>header p.muted{color:var(--text-muted);font-size:var(--text-base)}.success-msg{display:flex;align-items:center;gap:var(--space-3);background:#5f7d161a;border:1px solid var(--border-default);color:var(--primary);padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium)}.success-msg svg{width:20px;height:20px;flex-shrink:0}.biography-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);max-width:640px}.biography-form{display:flex;flex-direction:column;gap:var(--space-6)}.bio-section{display:flex;flex-direction:column;gap:var(--space-4)}.bio-section+.bio-section{padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.bio-section-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-2)}.bio-section-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.bio-section-icon svg{width:22px;height:22px}.bio-section-icon--personal{background:#0ea5e926}.bio-section-icon--personal svg{stroke:var(--accent)}.bio-section-icon--physical{background:#f9731626}.bio-section-icon--physical svg{stroke:var(--secondary)}.bio-section-header h3{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.bio-section-desc{font-size:var(--text-sm);color:var(--text-muted)}.bio-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.biography-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.biography-form .form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.biography-form .form-group input[type=text],.biography-form .form-group input[type=number],.biography-form .form-group select{padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);height:48px}.biography-form .form-group input:focus,.biography-form .form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.biography-form .form-group input::-moz-placeholder{color:var(--text-muted)}.biography-form .form-group input::placeholder{color:var(--text-muted)}.input-with-suffix{position:relative;display:flex;align-items:center}.input-with-suffix input{width:100%;padding-right:var(--space-10)!important}.input-suffix{position:absolute;right:var(--space-4);font-size:var(--text-sm);color:var(--text-muted);font-weight:var(--font-medium);pointer-events:none}.biography-form .form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a3a3a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer}.biography-form .form-group select option{background:var(--bg-elevated);color:var(--text-primary)}.save-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:var(--primary);color:var(--bg-base);font-weight:var(--font-bold);font-size:var(--text-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:52px;margin-top:var(--space-2)}.save-btn:hover{background:var(--primary-light);transform:translateY(-1px)}.save-btn:active{transform:translateY(0)}.save-btn svg{width:20px;height:20px;min-width:20px;min-height:20px;max-width:20px;max-height:20px;flex-shrink:0;stroke:var(--bg-base)}@media(max-width:768px){.bio-row{grid-template-columns:1fr}.biography-card{padding:var(--space-5)}}@media(max-width:480px){#fitlife-container main>header h1{font-size:var(--text-xl)}.biography-card{padding:var(--space-4)}.biography-card h3{font-size:var(--text-lg)}}.admin-layout{--admin-surface: var(--bg-surface);--admin-surface-strong: var(--bg-elevated);--admin-border: var(--border-subtle);--admin-text: var(--text-primary);--admin-muted: var(--text-secondary);--admin-primary: var(--primary);--admin-primary-strong: var(--primary-dark);--admin-success: var(--success);--admin-warning: var(--warning);--admin-danger: var(--danger);--admin-info: var(--accent);--admin-shadow: var(--shadow-md);width:min(1180px,calc(100% - 2rem));margin:0 auto;padding:1.5rem 0 3rem;color:var(--admin-text)}.admin-layout>*+*{margin-top:1.25rem}.admin-layout--dashboard{width:min(1240px,calc(100% - 2rem))}.admin-layout--comments,.admin-layout--administrators{width:min(1200px,calc(100% - 2rem))}.admin-hero{position:relative;overflow:hidden;padding:1.5rem;border:1px solid var(--admin-border);border-radius:1.5rem;background:radial-gradient(circle at top right,rgba(95,125,22,.08),transparent 42%),linear-gradient(135deg,#090b0ff5,#0e1014eb);box-shadow:var(--admin-shadow)}.admin-hero:after{content:"";position:absolute;inset:auto -8rem -8rem auto;width:18rem;height:18rem;border-radius:999px;background:radial-gradient(circle,rgba(37,99,235,.18),transparent 65%);pointer-events:none}.admin-hero--premium{background:radial-gradient(circle at top right,rgba(167,139,250,.12),transparent 42%),linear-gradient(135deg,#090b0ffa,#0e1014f0)}.admin-hero--warning{background:radial-gradient(circle at top right,rgba(245,158,11,.12),transparent 42%),linear-gradient(135deg,#090b0ffa,#0e1014f0)}.admin-hero__content,.admin-card__header,.admin-card__body,.admin-card__footer{position:relative;z-index:1}.admin-hero__content{display:grid;gap:1rem}.admin-hero__eyebrow{display:inline-flex;align-items:center;gap:.5rem;width:-moz-fit-content;width:fit-content;padding:.35rem .7rem;border-radius:999px;background:#2563eb1a;color:var(--admin-primary-strong);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.admin-hero__title{margin:0;font-size:clamp(1.75rem,2vw + 1rem,3rem);line-height:1.05;letter-spacing:-.03em;color:var(--admin-text)}.admin-hero__description{max-width:70ch;margin:0;color:var(--admin-muted);font-size:1rem;line-height:1.65}.admin-hero__meta,.admin-card__meta,.admin-table__meta,.admin-toolbar__meta,.admin-hero__actions,.admin-card__actions,.admin-table__actions,.admin-toolbar__actions{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center}.admin-grid{display:grid;gap:1rem}.admin-grid--stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.admin-grid--cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.admin-grid--content{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.admin-dashboard__layout{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:1rem;align-items:start}.admin-dashboard__primary,.admin-dashboard__sidebar{display:grid;gap:1rem;min-width:0}.admin-dashboard__sidebar .admin-card{height:-moz-fit-content;height:fit-content}.admin-stat{display:grid;gap:.35rem;min-height:100%;padding:1rem;border:1px solid var(--admin-border);border-radius:1rem;background:var(--admin-surface-strong)}.admin-stat__label{color:var(--admin-muted);font-size:.84rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.admin-stat__value{color:var(--admin-text);font-size:clamp(1.35rem,1vw + 1rem,2.1rem);font-weight:800;line-height:1.1}.admin-stat__hint{color:var(--admin-muted);font-size:.88rem;line-height:1.55}.admin-activity{display:grid;gap:.75rem}.admin-activity__item{display:grid;gap:.55rem;padding:1.1rem 1.15rem;border:1px solid var(--admin-border);border-radius:1rem;background:#ffffff05}.admin-activity__title{margin:0;color:var(--admin-text);font-size:.98rem;font-weight:700}.admin-activity__meta{display:flex;flex-wrap:wrap;gap:.45rem .8rem;color:var(--admin-muted);font-size:.86rem;line-height:1.55}.admin-card{position:relative;overflow:hidden;border:1px solid var(--admin-border);border-radius:1.25rem;background:var(--admin-surface);box-shadow:var(--shadow-sm)}.admin-card--strong{background:var(--admin-surface-strong)}.admin-card__header{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:flex-start;padding:1rem 1.15rem;border-bottom:1px solid rgba(15,23,42,.06)}.admin-card__title-group{display:grid;gap:.3rem}.admin-card__title{margin:0;color:var(--admin-text);font-size:1.05rem;font-weight:700;line-height:1.3}.admin-card__description{margin:0;color:var(--admin-muted);font-size:.92rem;line-height:1.55}.admin-card__body{padding:1rem 1.15rem 1.15rem}.admin-card__footer{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:center;padding:1rem 1.15rem 1.15rem;border-top:1px solid rgba(15,23,42,.06)}.admin-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:center;padding:1rem 1.15rem;border:1px solid var(--admin-border);border-radius:1rem;background:var(--admin-surface);box-shadow:var(--shadow-xs)}.admin-toolbar__group{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.admin-toolbar__label{display:inline-flex;align-items:center;gap:.35rem;color:var(--admin-muted);font-size:.92rem;font-weight:600}.admin-toolbar__search,.admin-toolbar__select,.admin-form__control{width:100%;min-width:14rem;padding:.8rem .95rem;border:1px solid var(--admin-border);border-radius:.9rem;background:var(--admin-surface-strong);color:var(--admin-text);font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background-color .2s ease}.admin-toolbar__search:focus,.admin-toolbar__select:focus,.admin-form__control:focus,.admin-form textarea:focus,.admin-form input:focus{outline:none;border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb1f}.admin-toolbar__search::-moz-placeholder,.admin-form__control::-moz-placeholder,.admin-form textarea::-moz-placeholder,.admin-form input::-moz-placeholder{color:color-mix(in srgb,var(--admin-muted) 76%,transparent)}.admin-toolbar__search::placeholder,.admin-form__control::placeholder,.admin-form textarea::placeholder,.admin-form input::placeholder{color:color-mix(in srgb,var(--admin-muted) 76%,transparent)}.admin-toolbar__search{min-width:min(100%,22rem)}.admin-toolbar__select{min-width:12rem}.admin-toolbar__search::-webkit-autofill,.admin-toolbar__select::-webkit-autofill,.admin-form__control::-webkit-autofill,.admin-form input::-webkit-autofill,.admin-form textarea::-webkit-autofill{-webkit-text-fill-color:var(--admin-text);box-shadow:0 0 0 1000px var(--admin-surface-strong) inset;-webkit-transition:background-color 9999s ease-out 0s;transition:background-color 9999s ease-out 0s}.admin-table-wrap{overflow:hidden;border:1px solid var(--admin-border);border-radius:1.25rem;background:var(--admin-surface);box-shadow:var(--shadow-sm)}.admin-table{width:100%;border-collapse:collapse;background:transparent}.admin-table thead th{padding:.9rem 1rem;border-bottom:1px solid var(--admin-border);color:var(--admin-muted);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-align:left;text-transform:uppercase;white-space:nowrap;background:var(--admin-surface-strong)}.admin-table tbody td{padding:1rem;border-bottom:1px solid rgba(15,23,42,.05);color:var(--admin-text);vertical-align:top}.admin-table tbody tr{transition:background-color .2s ease,transform .2s ease}.admin-table tbody tr:hover{background:#2563eb08}.admin-table tbody tr:last-child td{border-bottom:0}.admin-table__row--super{background:#a855f70d}.admin-table__cell-title,.admin-comment__context,.admin-comment__meta,.admin-admin-card__role,.admin-table__stack{display:grid;gap:.2rem}.admin-table__title,.admin-comment__excerpt{margin:0;font-weight:700;line-height:1.35}.admin-table__subtitle,.admin-table__meta,.admin-table__footnote,.admin-comment__author,.admin-comment__meta span,.admin-comment__meta strong{color:var(--admin-muted);font-size:.9rem;line-height:1.5}.admin-comment__excerpt{color:var(--admin-text);font-size:.95rem}.admin-comment__actions,.admin-admin-card__actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:flex-end}.admin-table__actions{justify-content:flex-end}.admin-table__actions form{margin:0}.admin-badge{display:inline-flex;align-items:center;gap:.35rem;width:-moz-fit-content;width:fit-content;padding:.35rem .7rem;border-radius:999px;border:1px solid transparent;font-size:.74rem;font-weight:700;letter-spacing:.04em;line-height:1;text-transform:uppercase}.admin-badge--primary{background:#2563eb1f;border-color:#2563eb2e;color:var(--admin-primary-strong)}.admin-badge--success{background:#5f7d161f;border-color:#5f7d162e;color:var(--admin-success)}.admin-badge--warning{background:#d977061f;border-color:#d977062e;color:var(--admin-warning)}.admin-badge--danger{background:#dc26261f;border-color:#dc26262e;color:var(--admin-danger)}.admin-badge--info{background:#0f766e1f;border-color:#0f766e2e;color:var(--admin-info)}.admin-badge--muted{background:#64748b1f;border-color:#64748b2e;color:var(--admin-muted)}.admin-badge--super{background:linear-gradient(135deg,#a855f729,#2563eb24);border-color:#a855f738;color:#7c3aed}.admin-button,button.admin-button,a.admin-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:2.65rem;padding:.7rem 1rem;border:1px solid transparent;border-radius:.9rem;color:#fff;font-size:.92rem;font-weight:700;line-height:1;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease;cursor:pointer}.admin-button:hover,button.admin-button:hover,a.admin-button:hover{transform:translateY(-1px);text-decoration:none}.admin-button:focus-visible,.admin-toolbar__search:focus-visible,.admin-toolbar__select:focus-visible,.admin-form__control:focus-visible{outline:2px solid transparent}.admin-button--primary{background:linear-gradient(135deg,var(--admin-primary),var(--admin-primary-strong));box-shadow:0 14px 24px #2563eb2e}.admin-button--secondary{background:#0f172ae0;box-shadow:0 12px 20px #0f172a1f}.admin-button--danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 14px 24px #dc26262e}.admin-button--ghost{color:var(--admin-text);background:var(--admin-surface-strong);border-color:var(--admin-border);box-shadow:none}.admin-button--ghost:hover{background:var(--admin-surface)}.admin-button--sm{min-height:2.2rem;padding:.45rem .75rem;border-radius:.75rem;font-size:.82rem}.admin-button--block{width:100%}.admin-note{padding:.9rem 1rem;border-radius:.95rem;border:1px solid var(--admin-border);background:#5f7d160f;color:var(--text-primary);font-size:.92rem;line-height:1.6}.admin-note--warning{border-color:#d9770624;background:#d9770614;color:#92400e}.admin-note--danger{border-color:#dc262624;background:#dc262614;color:#991b1b}.admin-empty-state{display:grid;place-items:center;gap:.55rem;padding:2rem 1.25rem;border:1px dashed var(--admin-border);border-radius:1rem;background:#ffffff05;text-align:center}.admin-empty-state__title{margin:0;color:var(--admin-text);font-size:1rem;font-weight:700}.admin-empty-state__description{max-width:42rem;margin:0;color:var(--admin-muted);font-size:.94rem;line-height:1.6}.admin-pagination{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(15,23,42,.08)}.admin-pagination nav{display:flex;flex-wrap:wrap;gap:.35rem}.admin-pagination nav>div,.admin-pagination nav>span,.admin-pagination nav a{border-color:var(--admin-border)!important;background:var(--admin-surface-strong)!important;color:var(--admin-text)!important}.admin-pagination nav a:hover{background:var(--admin-surface)!important}.admin-chart-shell{position:relative;min-height:20rem;padding:.75rem;border-radius:1rem;background:linear-gradient(180deg,#090b0fe0,#0e1014f5)}.admin-chart-shell canvas{width:100%!important;height:100%!important;min-height:18rem}.admin-form{display:grid;gap:1rem}.admin-form__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.admin-form__group{display:grid;gap:.45rem}.admin-form__label{color:var(--admin-text);font-size:.92rem;font-weight:700}.admin-form__hint{color:var(--admin-muted);font-size:.88rem;line-height:1.5}.admin-form textarea{min-height:10rem;resize:vertical}.admin-form__footer{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:center;margin-top:.5rem}.admin-division{height:1px;margin:.5rem 0;background:#0f172a14}.admin-quick-links{display:flex;flex-wrap:wrap;gap:.65rem}.admin-page-note{margin:0;color:var(--admin-muted);font-size:.92rem;line-height:1.6}@media(max-width:900px){.admin-layout{width:min(100% - 1rem,1180px);padding-top:1rem}.admin-hero{padding:1.25rem}.admin-card__header,.admin-card__body,.admin-card__footer,.admin-toolbar{padding-left:1rem;padding-right:1rem}.admin-table thead{display:none}.admin-table,.admin-table tbody,.admin-table tr,.admin-table td{display:block;width:100%}.admin-table tbody tr{padding:.2rem 0;border-bottom:1px solid rgba(15,23,42,.08)}.admin-table tbody td{display:flex;justify-content:space-between;gap:.75rem;padding:.8rem 1rem;text-align:right}.admin-table tbody td:before{content:attr(data-label);color:var(--admin-muted);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:left}.admin-table__actions,.admin-comment__actions,.admin-admin-card__actions,.admin-pagination{justify-content:flex-start}.admin-toolbar__search,.admin-toolbar__select,.admin-form__control{min-width:100%}}@media(max-width:640px){.admin-hero__actions,.admin-card__actions,.admin-table__actions,.admin-toolbar__actions,.admin-form__footer,.admin-quick-links,.admin-button,button.admin-button,a.admin-button{width:100%}.admin-grid--stats,.admin-grid--cards,.admin-grid--content,.admin-dashboard__layout{grid-template-columns:1fr}.admin-pagination{justify-content:flex-start}}.admin-layout--dashboard .admin-hero{margin-bottom:.25rem}.admin-layout--dashboard .admin-stat{display:grid;gap:.35rem;min-height:100%;padding:1rem;border:1px solid var(--admin-border);border-radius:1rem;background:var(--admin-surface-strong)}.admin-layout--dashboard .admin-stat__label{color:var(--admin-muted);font-size:.84rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.admin-layout--dashboard .admin-stat__value{color:var(--admin-text);font-size:clamp(1.35rem,1vw + 1rem,2.1rem);font-weight:800;line-height:1.1}.admin-layout--dashboard .admin-stat__hint{color:var(--admin-muted);font-size:.88rem;line-height:1.55}.admin-layout--dashboard .admin-card--summary{min-height:100%}.admin-layout--dashboard .admin-card--summary .admin-card__body{display:grid;gap:.75rem}.admin-layout--dashboard .admin-card__body{display:grid;gap:.9rem}.admin-layout--dashboard .admin-quick-links{display:flex;flex-wrap:wrap;gap:.65rem}.admin-layout--dashboard .admin-quick-links .admin-button{flex:1 1 11rem}.admin-layout--dashboard .admin-activity{display:grid;gap:.75rem}.admin-layout--dashboard .admin-activity__item{display:grid;gap:.15rem;padding:.9rem 1rem;border:1px solid var(--admin-border);border-radius:1rem;background:#ffffff05}.admin-layout--dashboard .admin-activity__item+.admin-activity__item{margin-top:.9rem}.admin-layout--dashboard .admin-activity__title{margin:0;color:var(--admin-text);font-size:.98rem;font-weight:700}.admin-layout--dashboard .admin-activity__meta{color:var(--admin-muted);font-size:.86rem;line-height:1.45}@media(max-width:640px){.admin-layout--dashboard .admin-quick-links .admin-button{flex-basis:100%}}.admin-layout--dashboard .pagination{display:flex;justify-content:center;gap:.5rem;margin-top:1.25rem;flex-wrap:wrap}.admin-layout--dashboard .pagination a,.admin-layout--dashboard .pagination span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:.5rem .75rem;background:var(--admin-surface-strong);color:var(--admin-text);font-size:.9rem;text-decoration:none;border-radius:.75rem;border:1px solid var(--admin-border);transition:all .18s ease}.admin-layout--dashboard .pagination a:hover:not(.disabled){background:var(--admin-primary);color:#fff;border-color:var(--admin-primary)}.admin-layout--dashboard .pagination .current,.admin-layout--dashboard .pagination span[aria-current=page]{background:var(--admin-primary);color:#fff;border-color:var(--admin-primary);font-weight:700}.admin-layout--dashboard .pagination .disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.admin-layout--posts .admin-card__body,.admin-layout--events .admin-card__body,.admin-layout--comments .admin-card__body,.admin-layout--administrators .admin-card__body{display:grid;gap:1rem}.admin-layout--posts .admin-post-card,.admin-layout--events .admin-event-card,.admin-layout--comments .admin-comment-card,.admin-layout--administrators .admin-admin-card{display:grid;gap:.75rem}.admin-layout--posts .admin-post-card__title,.admin-layout--events .admin-event-card__title,.admin-layout--comments .admin-comment-card__title,.admin-layout--administrators .admin-admin-card__title{margin:0;color:var(--admin-text);font-size:1rem;font-weight:800;line-height:1.4}.admin-layout--posts .admin-post-card__excerpt,.admin-layout--events .admin-event-card__excerpt,.admin-layout--comments .admin-comment-card__excerpt,.admin-layout--administrators .admin-admin-card__excerpt{color:var(--admin-muted);font-size:.92rem;line-height:1.6}.admin-layout--posts .admin-post-card__meta,.admin-layout--events .admin-event-card__meta,.admin-layout--comments .admin-comment-card__meta,.admin-layout--administrators .admin-admin-card__meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.admin-layout--posts .admin-post-card__actions,.admin-layout--events .admin-event-card__actions,.admin-layout--comments .admin-comment-card__actions,.admin-layout--administrators .admin-admin-card__actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.admin-layout--posts .admin-post-card__actions .admin-button,.admin-layout--events .admin-event-card__actions .admin-button,.admin-layout--comments .admin-comment-card__actions .admin-button,.admin-layout--administrators .admin-admin-card__actions .admin-button{min-width:6rem}@media(max-width:640px){.admin-layout--posts .admin-post-card__actions .admin-button,.admin-layout--events .admin-event-card__actions .admin-button,.admin-layout--comments .admin-comment-card__actions .admin-button,.admin-layout--administrators .admin-admin-card__actions .admin-button{width:100%}}.admin-layout--users .admin-hero{margin-bottom:.35rem}.admin-layout--users .admin-table__role,.admin-layout--users .admin-role{display:inline-flex;align-items:center;gap:.35rem}.admin-layout--users .admin-table__row--super .admin-table__title{color:#6d28d9}.admin-layout--users .admin-table__row--super .admin-table__subtitle{color:#7c3aed}.admin-layout--users .admin-user-card{display:grid;gap:.7rem}.admin-layout--users .admin-user-card__top{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;align-items:flex-start}.admin-layout--users .admin-user-card__meta{display:grid;gap:.25rem}.admin-layout--users .admin-user-card__name{margin:0;color:var(--admin-text);font-size:1.05rem;font-weight:800}.admin-layout--users .admin-user-card__email{color:var(--admin-muted);font-size:.92rem;line-height:1.5;word-break:break-word}.admin-layout--users .admin-user-card__actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.admin-layout--users .admin-user-card__actions .admin-button{min-width:6.5rem}.admin-layout--users .admin-user-profile{display:grid;gap:1rem}.admin-layout--users .admin-user-profile__header{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:space-between;align-items:flex-start}.admin-layout--users .admin-user-profile__summary{display:grid;gap:.35rem}.admin-layout--users .admin-user-profile__name{margin:0;font-size:clamp(1.35rem,1vw + 1rem,2rem);font-weight:800}.admin-layout--users .admin-user-profile__email{color:var(--admin-muted);font-size:.95rem;line-height:1.6}.admin-layout--users .admin-user-profile__role{display:flex;flex-wrap:wrap;gap:.5rem}.admin-layout--users .admin-user-profile__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.85rem}.admin-layout--users .admin-user-profile__detail{padding:.9rem 1rem;border-radius:1rem;border:1px solid rgba(15,23,42,.06);background:#f8fafcd9}.admin-layout--users .admin-user-profile__detail-label{color:var(--admin-muted);font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.admin-layout--users .admin-user-profile__detail-value{margin-top:.25rem;color:var(--admin-text);font-size:.98rem;font-weight:700;line-height:1.45;word-break:break-word}.admin-layout--users .admin-user-profile__section{display:grid;gap:.75rem}.admin-layout--users .admin-user-profile__section-title{margin:0;color:var(--admin-text);font-size:1rem;font-weight:800}.admin-layout--users .admin-user-profile__section-description{margin:0;color:var(--admin-muted);font-size:.92rem;line-height:1.55}.admin-layout--users .admin-form__role-lock{display:grid;gap:.65rem}.admin-layout--users .admin-form__role-lock .admin-badge{width:-moz-fit-content;width:fit-content}@media(max-width:640px){.admin-layout--users .admin-user-card__actions{width:100%;justify-content:flex-start}.admin-layout--users .admin-user-card__actions .admin-button{width:100%}}.admin-layout--events .admin-toolbar__select{min-width:13rem}.admin-layout--events .admin-event__type{display:inline-flex;align-items:center;gap:.35rem}.admin-layout--events .admin-event__time{display:grid;gap:.25rem}.admin-layout--events .admin-event__time strong{color:var(--admin-text);font-weight:800}.admin-layout--events .admin-event__time span{color:var(--admin-muted);font-size:.88rem;line-height:1.45}.admin-layout--events .admin-event__location{color:var(--admin-text);font-size:.95rem;line-height:1.5}.admin-layout--events .admin-table__row[data-type=online]{background:#0f766e0a}.admin-layout--events .admin-table__row[data-type=offline],.admin-layout--events .admin-table__row[data-type=in_person]{background:#2563eb08}@media(max-width:640px){.admin-layout--events .admin-toolbar__select{min-width:100%}}.user-profile-page{padding:0}.up-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem;font-weight:500;text-decoration:none;margin-bottom:1.5rem;transition:color var(--transition-base)}.up-back-link:hover{color:var(--primary)}.up-back-link svg{flex-shrink:0}.up-profile-card{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem;transition:all var(--transition-base);position:relative}.up-profile-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);z-index:2}.up-banner{position:relative;height:180px;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-surface) 100%);overflow:hidden}.up-banner__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.up-banner__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,10,10,.85) 100%)}.up-profile-info{display:flex;align-items:flex-end;gap:1.25rem;padding:0 1.5rem 1.5rem;margin-top:-3.5rem;position:relative;z-index:1}.up-avatar{flex-shrink:0;width:100px;height:100px;border-radius:var(--radius-full);border:4px solid var(--bg-glass-dark);overflow:hidden;background:var(--bg-elevated);box-shadow:0 4px 20px #0006}.up-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.up-details{flex:1;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;min-width:0;padding-bottom:.25rem}.up-name-section{min-width:0}.up-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.up-username{font-size:.875rem;color:var(--text-muted)}.up-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.up-subscription-badge{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:600;color:var(--primary);padding:.375rem .875rem;background:#5f7d161f;border:1px solid var(--border-default);border-radius:var(--radius-sm)}.up-subscription-badge--pending{color:var(--warning);background:#f59e0b1f;border-color:#f59e0b40}.up-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1.25rem;font-size:.8125rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.up-btn--primary{background:var(--primary);color:#000;box-shadow:0 4px 15px #5f7d164d}.up-btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5f7d1666}.up-btn--danger{background:transparent;color:var(--danger);border:1px solid rgba(239,68,68,.4)}.up-btn--danger:hover{background:#ef44441a;border-color:var(--danger)}.up-grid{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;align-items:start}.up-sidebar{display:flex;flex-direction:column;gap:1rem}.up-card{background:var(--bg-glass-dark);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);position:relative}.up-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);transform:scaleX(0);transition:transform var(--transition-base)}.up-card:hover:before{transform:scaleX(1)}.up-card:hover{border-color:var(--border-strong)}.up-card--flat:before{transform:scaleX(1)}.up-card__header{display:flex;align-items:center;gap:.625rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-default)}.up-card__header svg{color:var(--primary);flex-shrink:0}.up-card__header h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0}.up-bio-list{padding:.25rem 0}.up-bio-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-default);transition:background var(--transition-base)}.up-bio-item:last-child{border-bottom:none}.up-bio-item:hover{background:#5f7d1608}.up-bio-label{font-size:.8125rem;color:var(--text-muted)}.up-bio-value{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.up-stats{display:grid;grid-template-columns:1fr 1fr}.up-stat-item{display:flex;flex-direction:column;align-items:center;padding:1rem;gap:.25rem}.up-stat-item:first-child{border-right:1px solid var(--border-default)}.up-stat-value{font-size:1.5rem;font-weight:700;background:var(--primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.up-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.up-main{min-width:0}.up-posts-feed{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.up-posts-feed .post-card{display:block}.up-posts-feed .post-content{padding:.75rem 1rem}.up-posts-feed .post-actions{display:flex;align-items:center;gap:.5rem;padding-top:.5rem;margin-top:.5rem;border-top:1px solid var(--border-default)}.up-posts-feed .post-action svg{width:18px;height:18px;fill:currentColor}.up-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;background:var(--bg-glass-dark);border:1px dashed var(--border-default);border-radius:var(--radius-lg);text-align:center}.up-empty-state svg{color:var(--text-muted);opacity:.5}.up-empty-state p{font-size:.9375rem;color:var(--text-muted);margin:0}@media(max-width:1024px){.up-grid{grid-template-columns:260px 1fr}}@media(max-width:768px){.up-grid{grid-template-columns:1fr}.up-sidebar{order:-1}.up-banner{height:140px}.up-profile-info{flex-direction:column;align-items:flex-start;margin-top:-2.5rem;padding:0 1rem 1.25rem}.up-avatar{width:80px;height:80px}.up-details{flex-direction:column;align-items:flex-start}.up-name{font-size:1.25rem}}@media(max-width:480px){.up-banner{height:110px}.up-avatar{width:68px;height:68px}.up-profile-info{margin-top:-2rem}}.chats-tabs{display:flex;border-bottom:1px solid var(--border-subtle);margin-bottom:0}.chats-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:14px;font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:inherit;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s}.chats-tab:hover{color:var(--text-secondary)}.chats-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.chats-tab svg{opacity:.7}.chats-tab.active svg{opacity:1;stroke:var(--primary)}.chats-tab__badge{background:var(--danger);color:#fff;font-size:10px;font-weight:var(--font-bold);min-width:18px;height:18px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.chats-tab__count{background:var(--bg-elevated);color:var(--text-muted);font-size:10px;font-weight:var(--font-bold);min-width:18px;height:18px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.chats-panel{display:none;opacity:0}.chats-panel.active{display:block;animation:panelFadeIn .25s var(--ease-out) forwards}@keyframes panelFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msg-page{max-width:700px;margin:0 auto;padding:var(--space-4)}body:has(.messenger){overflow:hidden}.main-content:has(.messenger){padding:64px 0 0;max-width:none}.content-wrapper:has(.messenger){max-width:none;padding:0}.messenger{display:flex;height:calc(100vh - 64px);background:var(--bg-surface);overflow:hidden;animation:messengerFadeIn .3s var(--ease-out)}@keyframes messengerFadeIn{0%{opacity:0}to{opacity:1}}.chat-sidebar-list{width:360px;min-width:360px;display:flex;flex-direction:column;background:var(--bg-surface);border-right:1px solid var(--border-default);overflow:hidden;animation:sidebarSlideIn .35s var(--ease-out)}@keyframes sidebarSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.chat-sidebar-list__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-2)}.chat-sidebar-list__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.chat-sidebar-list__new{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}.chat-sidebar-list__new:hover{background:var(--primary);color:#fff}.chat-sidebar-list .chats-tabs{flex-shrink:0}.chat-sidebar-list .chats-panel{flex:1;overflow-y:auto}.chat-sidebar-list .msg-list{border-radius:0;background:transparent;gap:0}.chat-sidebar-list .msg-item{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);border-radius:0;transition:all .2s var(--ease-default);border-left:3px solid transparent;padding-left:calc(var(--space-4) - 3px)}.chat-sidebar-list .msg-item:hover{background:var(--bg-hover)}.chat-sidebar-list .msg-item--active{background:var(--bg-hover);border-left-color:var(--primary)}.chat-sidebar-list .msg-empty{padding:var(--space-8) var(--space-4)}.messenger__main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg-base);animation:mainSlideIn .35s var(--ease-out)}@keyframes mainSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.messenger__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--text-muted);animation:emptyPulse 3s ease-in-out infinite}@keyframes emptyPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}@media(max-width:900px){.msg-form__input,input[type=text],textarea{font-size:16px!important;-webkit-text-size-adjust:100%!important}}.messenger__empty svg{opacity:.25}.messenger__empty p{font-size:var(--text-sm)}.messenger ::-webkit-scrollbar{width:6px}.messenger ::-webkit-scrollbar-track{background:transparent}.messenger ::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}.messenger ::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.msg-item__badge{animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.chat-header__actions button,.chat-header__actions a{transition:all .2s var(--ease-default)}.chat-header__actions button:hover,.chat-header__actions a:hover{transform:scale(1.1)}.chat-header__actions button:active,.chat-header__actions a:active{transform:scale(.9)}.msg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-3)}.msg-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.msg-btn-create{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--primary);color:#fff;border-radius:var(--radius-sm);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);transition:background var(--transition-fast)}.msg-btn-create:hover{background:var(--primary-dark)}.msg-list{display:flex;flex-direction:column;gap:1px;background:var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.msg-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-surface);text-decoration:none;color:var(--text-primary);transition:background var(--transition-fast)}.msg-item:hover{background:var(--bg-hover)}.msg-item--static{cursor:default}.msg-item--static:hover{background:var(--bg-surface)}.msg-item__avatar{width:48px;height:48px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.msg-item__group-icon{width:48px;height:48px;border-radius:var(--radius-full);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.msg-item__content{flex:1;min-width:0}.msg-item__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}.msg-item__name{font-weight:var(--font-semibold);font-size:var(--text-base)}.msg-item__time{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0}.msg-item__meta{font-size:var(--text-xs);color:var(--text-muted)}.msg-item__preview{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-item__badge{background:var(--primary);color:#fff;font-size:11px;font-weight:var(--font-bold);min-width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0 6px}.msg-empty{padding:var(--space-12) var(--space-4);text-align:center;color:var(--text-muted);background:var(--bg-surface)}.msg-empty svg{margin:0 auto var(--space-3);opacity:.4}.msg-empty p{font-size:var(--text-sm)}.msg-alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);margin-bottom:var(--space-4);font-size:var(--text-sm)}.msg-alert--success{background:var(--success-bg);color:var(--success);border:1px solid rgba(95,125,22,.2)}.msg-alert--error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,38,38,.2)}.msg-form{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--space-6);border:1px solid var(--border-default)}.msg-form__group{margin-bottom:var(--space-5)}.msg-form__label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.msg-form__input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast);resize:vertical}.msg-form__input:focus{outline:none;border-color:var(--primary)}.msg-form__error{display:block;font-size:var(--text-xs);color:var(--danger);margin-top:var(--space-1)}.msg-form__submit{width:100%;padding:var(--space-3) var(--space-6);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:background var(--transition-fast)}.msg-form__submit:hover{background:var(--primary-dark)}.msg-btn-invite{padding:var(--space-2) var(--space-4);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background var(--transition-fast);flex-shrink:0}.msg-btn-invite:hover{background:var(--primary-dark)}.chat-page{display:flex;flex-direction:column;flex:1;height:100%;min-height:0}.chat-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-bottom:1px solid var(--border-default);flex-shrink:0}.chat-back{color:var(--text-secondary);display:flex;transition:all .2s var(--ease-default)}.chat-back:hover{color:var(--text-primary);transform:translate(-3px)}.chat-user{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:var(--text-primary);flex:1;min-width:0}.chat-user__avatar{width:36px;height:36px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover}.chat-user__group-icon{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.chat-user__name{font-weight:var(--font-semibold);font-size:var(--text-base)}.chat-user__meta{font-size:var(--text-xs);color:var(--text-muted);display:block}.chat-header__actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.chat-header__btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--bg-elevated);border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.chat-header__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-header__btn--danger:hover{background:var(--danger-bg);color:var(--danger)}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-4);background:var(--bg-base);display:flex;flex-direction:column;gap:var(--space-3);min-height:0}.chat-msg{display:flex;align-items:flex-end;gap:var(--space-2);max-width:80%;animation:msgSlideIn .3s var(--ease-out) both}.chat-msg--mine{align-self:flex-end;flex-direction:row-reverse}.chat-msg--theirs{align-self:flex-start}@keyframes msgSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.chat-msg__avatar{width:28px;height:28px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.chat-msg__bubble{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);position:relative}.chat-msg--mine .chat-msg__bubble{background:var(--primary);color:#fff;border-bottom-right-radius:var(--radius-xs)}.chat-msg--theirs .chat-msg__bubble{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-default);border-bottom-left-radius:var(--radius-xs)}.chat-msg__author{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--primary);display:block;margin-bottom:2px}.chat-msg--theirs .chat-msg__author{color:var(--primary)}.chat-msg__text{font-size:var(--text-sm);line-height:1.4;word-break:break-word}.chat-msg__time{font-size:10px;opacity:.6;display:block;text-align:right;margin-top:2px}.chat-input{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-top:1px solid var(--border-default);flex-shrink:0;position:relative}.chat-input__field{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.chat-input__field:focus{border-color:var(--primary)}.chat-input__send{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .2s var(--ease-default);flex-shrink:0}.chat-input__send:hover{background:var(--primary-dark);transform:scale(1.1)}.chat-input__send:active{transform:scale(.92)}.notif-item{flex-wrap:wrap}.notif-item__text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.4}.notif-item__actions{display:flex;gap:var(--space-2);margin-left:auto;flex-shrink:0}.notif-btn{padding:var(--space-1) var(--space-3);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.notif-btn--accept{background:var(--primary);color:#fff}.notif-btn--accept:hover{background:var(--primary-dark)}.notif-btn--decline{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default)}.notif-btn--decline:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-badge{position:absolute;top:2px;right:2px;background:var(--danger);color:#fff;font-size:9px;font-weight:var(--font-bold);min-width:16px;height:16px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}@media(max-width:768px){.msg-page{padding:var(--space-3)}.messenger{height:calc(100vh - 64px);border-radius:0}.chat-sidebar-list{width:100%;min-width:0}.chat-sidebar-list__header{padding:var(--space-3) var(--space-3) var(--space-2)}.chat-sidebar-list__title{font-size:var(--text-lg)}.chat-sidebar-list__new{width:32px;height:32px}.chats-tab{padding:10px;font-size:var(--text-xs);gap:var(--space-1)}.chats-tab svg{width:14px;height:14px}.chat-sidebar-list .msg-item{padding:var(--space-2) var(--space-3);padding-left:calc(var(--space-3) - 3px)}.msg-item__avatar,.msg-item__group-icon{width:40px;height:40px}.msg-item__name{font-size:var(--text-sm)}.msg-item__time,.msg-item__meta{font-size:.625rem}.msg-item__preview{font-size:var(--text-xs)}.messenger:has(.chat-page) .chat-sidebar-list{display:none}.messenger__empty{display:none}.chat-back{display:flex}.msg-header{margin-bottom:var(--space-4)}.msg-title{font-size:var(--text-xl)}.notif-item__actions{width:100%;margin-left:0;margin-top:var(--space-2);padding-left:60px}.msg-empty{padding:var(--space-6) var(--space-3)}.msg-empty svg{width:32px;height:32px}.msg-empty p{font-size:var(--text-sm)}}.chat-msg__media{max-width:360px;max-height:360px;border-radius:var(--radius-sm);display:block;margin-bottom:var(--space-1);cursor:pointer;transition:opacity .15s var(--ease-default)}.chat-msg__media:hover{opacity:.85}.chat-msg__media:is(video){width:320px}.chat-msg--mine .chat-msg__media,.chat-msg--theirs .chat-msg__media{border:none}.media-lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#000000e0;opacity:0;visibility:hidden;transition:opacity .25s var(--ease-out),visibility .25s;cursor:zoom-out}.media-lightbox.active{opacity:1;visibility:visible}.media-lightbox__content{position:relative;max-width:92vw;max-height:90vh;display:flex;align-items:center;justify-content:center;transform:scale(.92);transition:transform .3s var(--ease-out)}.media-lightbox.active .media-lightbox__content{transform:scale(1)}.media-lightbox__content img{max-width:92vw;max-height:90vh;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.media-lightbox__content video{max-width:92vw;max-height:90vh;border-radius:var(--radius-sm);cursor:default;outline:none}.media-lightbox__close{position:absolute;top:16px;right:16px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00000080;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);color:#fff;font-size:22px;cursor:pointer;z-index:201;transition:all .2s var(--ease-default);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.media-lightbox__close:hover{background:#ffffff26;transform:scale(1.1)}.chat-input__media{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.chat-input__media:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary)}.chat-media-preview{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-surface);font-size:var(--text-xs);color:var(--text-secondary)}.chat-media-preview span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-media-clear{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.chat-media-clear:hover{color:var(--danger)}.msg-form__avatar-upload{display:flex;align-items:center;gap:var(--space-4)}.msg-form__avatar-preview{width:72px;height:72px;border-radius:var(--radius-full);background:var(--bg-elevated);border:2px dashed var(--border-default);display:flex;align-items:center;justify-content:center;color:var(--text-muted);overflow:hidden;flex-shrink:0}.user-menu-avatar-wrap{position:relative;display:inline-block}.user-menu-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;font-size:10px;font-weight:var(--font-bold);min-width:18px;height:18px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;border:2px solid var(--bg-base)}.user-dropdown-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:var(--font-bold);min-width:18px;height:18px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;padding:0 5px;margin-left:auto}.msg-empty__hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-2);opacity:.7}.chat-msg__wrap{display:flex;flex-direction:column;position:relative;max-width:100%}.chat-msg__hover-actions{display:flex;align-items:center;gap:4px;position:absolute;top:-28px;z-index:5;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .2s var(--ease-out),transform .2s var(--ease-out)}.chat-msg--mine .chat-msg__hover-actions{right:0;flex-direction:row-reverse}.chat-msg--theirs .chat-msg__hover-actions{left:0}.chat-msg:hover .chat-msg__hover-actions{opacity:1;transform:translateY(0);pointer-events:auto}.chat-msg__react-bar{display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:2px 4px;box-shadow:0 2px 8px #0000004d}.chat-msg__react-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;font-size:14px;border-radius:var(--radius-full);transition:all .15s var(--ease-default);padding:0;line-height:1}.chat-msg__react-btn:hover{background:var(--bg-hover);transform:scale(1.3)}.chat-msg__react-btn:active{transform:scale(.85)}.chat-msg__dropdown-wrap{position:relative}.chat-msg__arrow-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all .15s;padding:0;box-shadow:0 2px 8px #0000004d}.chat-msg__arrow-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-msg__dropdown{position:absolute;top:100%;margin-top:4px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0006;min-width:120px;z-index:10;overflow:hidden;opacity:0;transform:scale(.95) translateY(-4px);transform-origin:top;pointer-events:none;transition:opacity .15s var(--ease-out),transform .15s var(--ease-out)}.chat-msg__dropdown.show{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}.chat-msg--mine .chat-msg__dropdown{right:0}.chat-msg--theirs .chat-msg__dropdown{left:0}.chat-msg__dropdown.show{display:block}.chat-msg__dropdown-item{display:block;width:100%;padding:8px 14px;background:none;border:none;font-size:var(--text-sm);font-family:inherit;color:var(--text-primary);text-align:left;cursor:pointer;transition:background .15s}.chat-msg__dropdown-item:hover{background:var(--bg-hover)}.chat-msg__dropdown-item--danger{color:var(--danger)}.chat-msg__dropdown-item--danger:hover{background:var(--danger-bg)}.chat-msg__reactions-display{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.chat-msg__reactions-display:empty{display:none}.chat-msg__reaction-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-full);font-size:12px;cursor:pointer;transition:all .2s var(--ease-default);line-height:1.4;font-family:inherit;color:var(--text-secondary)}.chat-msg__reaction-badge:hover{background:var(--bg-hover);border-color:var(--primary);transform:scale(1.1)}.chat-msg__reaction-badge:active{transform:scale(.9)}.chat-msg__reaction-badge.reacted{background:#007aff26;border-color:var(--primary);color:var(--primary)}.chat-msg__edited{font-style:italic;opacity:.6;font-size:9px}.chat-msg__edit-input{width:100%;padding:4px 8px;background:var(--bg-elevated);border:1px solid var(--primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;outline:none}.chat-user__avatar-wrap{position:relative;flex-shrink:0}.chat-user__status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:var(--radius-full);background:var(--text-muted);border:2px solid var(--bg-surface);display:block}.chat-user__status--online{background:#5f7d16}.msg-item__avatar-wrap{position:relative;flex-shrink:0}.msg-item__online-dot{position:absolute;bottom:2px;right:2px;width:10px;height:10px;border-radius:var(--radius-full);background:#5f7d16;border:2px solid var(--bg-surface)}.chat-header__badge{position:absolute;top:-4px;right:-4px;background:var(--primary);color:#fff;font-size:9px;font-weight:var(--font-bold);min-width:16px;height:16px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1}.chat-header__btn{position:relative}.chat-search-bar{padding:var(--space-2) var(--space-4);background:var(--bg-surface);position:relative;animation:slideDown .2s var(--ease-out)}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0;overflow:hidden}to{opacity:1;max-height:100px;overflow:visible}}.chat-search-bar__input{width:100%;padding:var(--space-2) var(--space-3);padding-right:32px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.chat-search-bar__input:focus{border-color:var(--primary)}.chat-search-bar__close{position:absolute;right:24px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.chat-search-bar__close:hover{color:var(--text-primary)}.chat-search-results{max-height:240px;overflow-y:auto;margin-top:var(--space-2)}.chat-search-results:empty{display:none}.chat-search-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.chat-search-item:hover{background:var(--bg-hover)}.chat-search-item strong{font-size:var(--text-sm);color:var(--text-primary)}.chat-search-item__time{font-size:var(--text-xs);color:var(--text-muted);margin-left:var(--space-2)}.chat-search-item p{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-search-empty{padding:var(--space-4);text-align:center;font-size:var(--text-sm);color:var(--text-muted)}.chat-pinned-panel{background:var(--bg-surface);max-height:220px;overflow-y:auto;animation:slideDown .25s var(--ease-out)}.chat-pinned-panel__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.chat-pinned-panel__close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.chat-pinned-panel__close:hover{color:var(--text-primary)}.chat-pinned-item{padding:var(--space-2) var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.chat-pinned-item:hover{background:var(--bg-hover)}.chat-pinned-item:last-child{border-bottom:none}.chat-pinned-item strong{font-size:var(--text-xs);color:var(--text-primary)}.chat-pinned-item p{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.chat-pinned-item span{font-size:10px;color:var(--text-muted)}.chat-pinned-empty{padding:var(--space-4);text-align:center;font-size:var(--text-sm);color:var(--text-muted)}.chat-load-more{text-align:center;padding:var(--space-2)}.chat-load-more__btn{padding:var(--space-1) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--text-xs);font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.chat-load-more__btn:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.chat-load-more__btn:disabled{opacity:.5;cursor:default}.chat-typing{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-4);background:var(--bg-surface);font-size:var(--text-xs);color:var(--text-muted)}.chat-typing__dots{display:flex;gap:3px;align-items:center}.chat-typing__dots span{width:5px;height:5px;border-radius:var(--radius-full);background:var(--text-muted);animation:typingBounce 1.4s infinite both}.chat-typing__dots span:nth-child(2){animation-delay:.2s}.chat-typing__dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-reply-preview{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-surface);border-top:1px solid var(--border-subtle)}.chat-reply-preview__content{flex:1;min-width:0;padding-left:var(--space-2);border-left:3px solid var(--primary)}.chat-reply-preview__author{display:block;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--primary)}.chat-reply-preview__text{display:block;font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-reply-preview__close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}.chat-reply-preview__close:hover{color:var(--danger)}.chat-msg__reply-ref{padding:var(--space-1) var(--space-2);margin-bottom:4px;border-left:3px solid var(--primary);border-radius:0 var(--radius-xs) var(--radius-xs) 0;background:#007aff14;cursor:pointer;transition:background var(--transition-fast)}.chat-msg__reply-ref:hover{background:#007aff26}.chat-msg__reply-author{display:block;font-size:10px;font-weight:var(--font-semibold);color:var(--primary)}.chat-msg__reply-text{display:block;font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.chat-msg--mine .chat-msg__reply-ref{border-left-color:#ffffff80;background:#ffffff1a}.chat-msg--mine .chat-msg__reply-author{color:#fffc}.chat-msg--mine .chat-msg__reply-text{color:#ffffffb3}.chat-msg__forwarded{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-muted);font-style:italic;margin-bottom:4px}.chat-msg--mine .chat-msg__forwarded{color:#fff9}.chat-msg--pinned .chat-msg__bubble{border-left:3px solid #f59e0b}.chat-msg--mine.chat-msg--pinned .chat-msg__bubble{border-left:3px solid rgba(245,158,11,.7)}.chat-msg__pin-icon{vertical-align:middle;opacity:.6}.chat-msg__read-icon{vertical-align:middle;margin-left:2px}.chat-msg__read-icon--unread{opacity:.4}.chat-msg__file{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#0000000f;border-radius:var(--radius-sm);text-decoration:none;color:inherit;margin-bottom:var(--space-1);transition:background var(--transition-fast)}.chat-msg__file:hover{background:#0000001a}.chat-msg--mine .chat-msg__file{background:#ffffff26}.chat-msg--mine .chat-msg__file:hover{background:#ffffff40}.chat-msg__file svg{flex-shrink:0;opacity:.7}.chat-msg__file-info{min-width:0;flex:1}.chat-msg__file-name{display:block;font-size:var(--text-xs);font-weight:var(--font-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-msg__file-size{display:block;font-size:10px;opacity:.6}.chat-msg--highlight .chat-msg__bubble{outline:2px solid var(--primary);outline-offset:2px;animation:msgFlash 2s ease-out}@keyframes msgFlash{0%,30%{background:#007aff1f}to{background:inherit}}.chat-forward-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;animation:modalOverlayIn .25s var(--ease-out)}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.chat-forward-modal__overlay{position:absolute;inset:0;background:#00000080}.chat-forward-modal__content{position:relative;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);width:360px;max-height:420px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006;animation:modalContentIn .3s var(--ease-out)}@keyframes modalContentIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.chat-forward-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default)}.chat-forward-modal__header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.chat-forward-modal__close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.chat-forward-modal__close:hover{color:var(--text-primary)}.chat-forward-modal__list{flex:1;overflow-y:auto;padding:var(--space-2)}.chat-forward-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.chat-forward-item:hover{background:var(--bg-hover)}.chat-forward-item__icon{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.chat-forward-item__avatar{width:36px;height:36px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.chat-page--group{flex-direction:row}.chat-main{flex:1;min-width:0;display:flex;flex-direction:column;height:100%}.chat-sidebar{width:280px;background:var(--bg-surface);border-left:1px solid var(--border-default);display:flex;flex-direction:column;height:100%;overflow-y:auto;animation:sidebarRightSlideIn .3s var(--ease-out)}@keyframes sidebarRightSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.chat-sidebar__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default)}.chat-sidebar__header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.chat-sidebar__close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.chat-sidebar__close:hover{color:var(--text-primary)}.chat-sidebar__body{padding:var(--space-3) var(--space-4)}.chat-sidebar__section{margin-bottom:var(--space-4)}.chat-sidebar__label{display:block;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.chat-sidebar__edit-row{display:flex;gap:var(--space-2);align-items:flex-start}.chat-sidebar__input{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.chat-sidebar__input:focus{border-color:var(--primary)}.chat-sidebar__textarea{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:inherit;outline:none;resize:vertical;transition:border-color var(--transition-fast)}.chat-sidebar__textarea:focus{border-color:var(--primary)}.chat-sidebar__save-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:16px;flex-shrink:0;transition:background var(--transition-fast)}.chat-sidebar__save-btn:hover{background:var(--primary-dark)}.chat-sidebar__text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.chat-sidebar__members{display:flex;flex-direction:column;gap:2px}.chat-member{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.chat-member:hover{background:var(--bg-hover)}.chat-member__avatar{width:32px;height:32px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.chat-member__info{flex:1;min-width:0}.chat-member__name{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-member__role{display:inline-block;font-size:10px;padding:1px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;font-weight:var(--font-semibold)}.chat-member__role--owner{background:#f59e0b26;color:#f59e0b}.chat-member__role--admin{background:#007aff1f;color:var(--primary)}.chat-member__role--member{background:var(--bg-elevated);color:var(--text-muted)}.chat-member__actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.chat-member:hover .chat-member__actions{opacity:1}.chat-member__action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xs);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);padding:0}.chat-member__action-btn:hover{background:var(--bg-hover);color:var(--primary);border-color:var(--primary)}.chat-member__action-btn--danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-bg)}@media(max-width:768px){.chat-page--group{flex-direction:column}.chat-sidebar{width:100%;height:auto;max-height:50vh;border-radius:0;border:1px solid var(--border-default);border-top:none;position:fixed;bottom:0;left:0;right:0;z-index:50}.chat-sidebar__header{padding:var(--space-2) var(--space-3)}.chat-sidebar__header h3{font-size:var(--text-sm)}.chat-member{padding:var(--space-1) var(--space-2)}.chat-member__avatar{width:28px;height:28px}.chat-member__name{font-size:var(--text-xs)}.chat-member__actions{opacity:1}.chat-forward-modal__content{width:calc(100% - 32px);max-width:360px}.chat-msg__reply-text{max-width:140px}.chat-header{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.chat-user__avatar,.chat-user__group-icon{width:32px;height:32px}.chat-user__name{font-size:var(--text-sm)}.chat-user__meta{font-size:.625rem}.chat-user{gap:var(--space-2)}.chat-header__actions{gap:4px}.chat-header__btn{width:32px;height:32px}.chat-header__btn svg{width:16px;height:16px}.chat-back svg{width:18px;height:18px}.chat-messages{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.chat-msg{max-width:88%}.chat-msg__avatar{width:24px;height:24px}.chat-msg__bubble{padding:var(--space-2)}.chat-msg__text{font-size:var(--text-sm)}.chat-msg__author{font-size:.625rem}.chat-msg__time{font-size:9px}.chat-msg__forwarded{font-size:.625rem}.chat-msg__reply-ref{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.chat-msg__media{max-width:240px;max-height:240px}.chat-msg__media:is(video){width:240px}.chat-input{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.chat-input__field{font-size:var(--text-sm);padding:var(--space-2)}.chat-input__send,.chat-input__media{width:36px;height:36px}.chat-search-bar{padding:var(--space-2) var(--space-3)}.chat-search-bar__input{font-size:var(--text-sm)}.chat-pinned-panel{max-height:200px}.chat-pinned-panel__header{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.chat-pinned-item{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.chat-msg__voice{gap:var(--space-1)}.chat-msg__voice-play svg{width:14px;height:14px}.chat-msg__voice-dur{font-size:var(--text-xs)}.chat-msg__reactions{gap:2px}.chat-load-more__btn{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.media-lightbox__close{width:36px;height:36px;top:var(--space-3);right:var(--space-3)}.chat-typing{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}}@media(max-width:480px){.chat-header{padding:var(--space-2);gap:var(--space-1)}.chat-user__avatar,.chat-user__group-icon{width:28px;height:28px}.chat-user__name{font-size:var(--text-xs)}.chat-user__meta{font-size:.5625rem}.chat-header__btn{width:28px;height:28px}.chat-header__btn svg{width:14px;height:14px}.chat-messages{padding:var(--space-2);gap:var(--space-1)}.chat-msg{max-width:92%}.chat-msg__avatar{width:20px;height:20px}.chat-msg__bubble{padding:6px 8px}.chat-msg__text{font-size:var(--text-xs)}.chat-msg__media{max-width:200px;max-height:200px}.chat-input{padding:var(--space-1) var(--space-2);gap:var(--space-1)}.chat-input__field{padding:6px var(--space-2);font-size:var(--text-xs)}.chat-input__send,.chat-input__media{width:32px;height:32px}.chat-sidebar{max-height:40vh}.chat-forward-modal__content{width:calc(100% - 16px)}}.chat-msg__voice{display:flex;align-items:center;gap:10px;padding:8px 12px;min-width:200px;background:#0000000a;border-radius:12px;margin-bottom:4px}.chat-msg--mine .chat-msg__voice{background:#ffffff26}.chat-msg__voice-play{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent-primary, #3b82f6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s}.chat-msg__voice-play:hover{transform:scale(1.1)}.chat-msg__voice-play.playing svg{display:none}.chat-msg__voice-play.playing:after{content:"";width:10px;height:12px;border-left:3px solid #fff;border-right:3px solid #fff}.chat-msg__voice-wave{flex:1;height:24px;background:repeating-linear-gradient(90deg,var(--accent-primary, #3b82f6) 0px,var(--accent-primary, #3b82f6) 2px,transparent 2px,transparent 5px);opacity:.4;border-radius:4px}.chat-msg__voice-dur{font-size:12px;color:inherit;opacity:.7;white-space:nowrap;min-width:30px;text-align:right}.chat-input__voice{border:none;background:none;color:var(--text-secondary, #6b7280);cursor:pointer;padding:6px;display:flex;align-items:center;transition:color .2s}.chat-input__voice:hover{color:var(--accent-primary, #3b82f6)}.chat-input__voice-recording{display:flex;align-items:center;gap:8px;padding:0 8px}.chat-input__voice-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:voice-pulse 1s infinite}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.3}}.chat-input__voice-timer{font-size:13px;font-variant-numeric:tabular-nums;color:#ef4444;min-width:35px}.chat-input__voice-cancel{border:none;background:none;font-size:20px;cursor:pointer;color:var(--text-secondary, #6b7280);padding:4px;line-height:1}.chat-input__voice-cancel:hover{color:#ef4444}.chat-input__voice-send{border:none;background:var(--accent-primary, #3b82f6);color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.chat-input__voice-send:hover{background:var(--accent-hover, #2563eb)}.chat-input__poll{border:none;background:none;color:var(--text-secondary, #6b7280);cursor:pointer;padding:6px;display:flex;align-items:center;transition:color .2s}.chat-input__poll:hover{color:var(--accent-primary, #3b82f6)}.chat-theme-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center}.chat-theme-modal__overlay{position:absolute;inset:0;background:#00000080}.chat-theme-modal__content{position:relative;background:var(--bg-primary, #fff);border-radius:16px;padding:24px;width:400px;max-width:calc(100vw - 32px);max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.chat-theme-modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.chat-theme-modal__header h3{margin:0;font-size:18px}.chat-theme-modal__close{border:none;background:none;font-size:24px;cursor:pointer;color:var(--text-secondary, #6b7280);padding:0;line-height:1}.chat-theme-modal__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.chat-theme-swatch{border:2px solid transparent;border-radius:12px;padding:14px 8px;cursor:pointer;text-align:center;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px;min-height:70px}.chat-theme-swatch:hover{transform:scale(1.05)}.chat-theme-swatch.active{border-color:var(--accent-primary, #3b82f6);box-shadow:0 0 0 2px var(--accent-primary, #3b82f6)}.chat-theme-swatch__name{font-size:11px;font-weight:500;pointer-events:none}.chat-theme-swatch--default{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151}.chat-theme-swatch--ocean{background:linear-gradient(135deg,#0369a1,#0ea5e9);color:#fff}.chat-theme-swatch--sunset{background:linear-gradient(135deg,#ea580c,#f59e0b);color:#fff}.chat-theme-swatch--forest{background:linear-gradient(135deg,#49610d,#5f7d16);color:#fff}.chat-theme-swatch--neon{background:linear-gradient(135deg,#7c3aed,#06b6d4);color:#fff}.chat-theme-swatch--aurora{background:linear-gradient(135deg,#1e3a5f,#10b981,#8b5cf6);color:#fff}.chat-theme-swatch--cherry{background:linear-gradient(135deg,#be123c,#fb7185);color:#fff}.chat-theme-swatch--midnight{background:linear-gradient(135deg,#0f172a,#1e293b);color:#94a3b8}.chat-theme-swatch--lavender{background:linear-gradient(135deg,#c084fc,#e9d5ff);color:#581c87}.chat-theme-swatch--ember{background:linear-gradient(135deg,#92400e,#f97316);color:#fff}.chat-theme-swatch--arctic{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0c4a6e}.chat-theme-swatch--tropical{background:linear-gradient(135deg,#065f46,#fbbf24);color:#fff}.chat-theme-swatch--vintage{background:linear-gradient(135deg,#78716c,#d6d3d1);color:#292524}.chat-theme-swatch--cyberpunk{background:linear-gradient(135deg,#1a1a2e,#e94560);color:#0ff}.chat-theme-swatch--rose_gold{background:linear-gradient(135deg,#be185d,#fda4af);color:#fff}.chat-theme--ocean{--theme-bg: #0c4a6e;--theme-msg-mine: #0284c7;--theme-msg-theirs: #075985;--theme-text: #e0f2fe;--theme-input-bg: #0369a1}.chat-theme--sunset{--theme-bg: #7c2d12;--theme-msg-mine: #ea580c;--theme-msg-theirs: #9a3412;--theme-text: #fff7ed;--theme-input-bg: #c2410c}.chat-theme--forest{--theme-bg: #14532d;--theme-msg-mine: #49610d;--theme-msg-theirs: #49610d;--theme-text: #f0fdf4;--theme-input-bg: #15803d}.chat-theme--neon{--theme-bg: #1e1b4b;--theme-msg-mine: #7c3aed;--theme-msg-theirs: #312e81;--theme-text: #ede9fe;--theme-input-bg: #4c1d95}.chat-theme--aurora{--theme-bg: #0f172a;--theme-msg-mine: #10b981;--theme-msg-theirs: #1e3a5f;--theme-text: #ecfdf5;--theme-input-bg: #064e3b}.chat-theme--cherry{--theme-bg: #4c0519;--theme-msg-mine: #e11d48;--theme-msg-theirs: #881337;--theme-text: #fff1f2;--theme-input-bg: #be123c}.chat-theme--midnight{--theme-bg: #020617;--theme-msg-mine: #334155;--theme-msg-theirs: #1e293b;--theme-text: #cbd5e1;--theme-input-bg: #0f172a}.chat-theme--lavender{--theme-bg: #faf5ff;--theme-msg-mine: #a855f7;--theme-msg-theirs: #e9d5ff;--theme-text: #3b0764;--theme-input-bg: #f3e8ff}.chat-theme--ember{--theme-bg: #431407;--theme-msg-mine: #f97316;--theme-msg-theirs: #7c2d12;--theme-text: #fff7ed;--theme-input-bg: #9a3412}.chat-theme--arctic{--theme-bg: #f0f9ff;--theme-msg-mine: #38bdf8;--theme-msg-theirs: #e0f2fe;--theme-text: #0c4a6e;--theme-input-bg: #bae6fd}.chat-theme--tropical{--theme-bg: #022c22;--theme-msg-mine: #059669;--theme-msg-theirs: #064e3b;--theme-text: #d1fae5;--theme-input-bg: #065f46}.chat-theme--vintage{--theme-bg: #f5f5f4;--theme-msg-mine: #78716c;--theme-msg-theirs: #e7e5e4;--theme-text: #292524;--theme-input-bg: #d6d3d1}.chat-theme--cyberpunk{--theme-bg: #0a0a1a;--theme-msg-mine: #e94560;--theme-msg-theirs: #1a1a2e;--theme-text: #0ff;--theme-input-bg: #16213e}.chat-theme--rose_gold{--theme-bg: #fdf2f8;--theme-msg-mine: #ec4899;--theme-msg-theirs: #fce7f3;--theme-text: #831843;--theme-input-bg: #fbcfe8}.chat-page[data-theme]:not([data-theme=default]) .chat-messages{background:var(--theme-bg)}.chat-page[data-theme]:not([data-theme=default]) .chat-msg--mine .chat-msg__bubble{background:var(--theme-msg-mine);color:var(--theme-text)}.chat-page[data-theme]:not([data-theme=default]) .chat-msg--theirs .chat-msg__bubble{background:var(--theme-msg-theirs);color:var(--theme-text)}.chat-page[data-theme]:not([data-theme=default]) .chat-input{background:var(--theme-input-bg)}.chat-page[data-theme]:not([data-theme=default]) .chat-input__field{background:#ffffff1a;color:var(--theme-text)}.chat-page[data-theme]:not([data-theme=default]) .chat-input__field::-moz-placeholder{color:var(--theme-text);opacity:.5}.chat-page[data-theme]:not([data-theme=default]) .chat-input__field::placeholder{color:var(--theme-text);opacity:.5}.chat-page[data-theme]:not([data-theme=default]) .chat-msg__time{color:var(--theme-text);opacity:.6}.chat-page[data-theme]:not([data-theme=default]) .chat-msg__author{color:var(--theme-text);opacity:.8}.chat-page[data-theme]:not([data-theme=default]) .chat-msg__edited{color:var(--theme-text);opacity:.5}.chat-msg--favorited .chat-msg__bubble{box-shadow:inset 0 0 0 1px #eab30866}.chat-poll{min-width:240px;max-width:320px;margin-bottom:6px}.chat-poll__question{font-weight:600;font-size:14px;margin-bottom:8px;line-height:1.3}.chat-poll__option{display:flex;align-items:center;width:100%;position:relative;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:8px 12px;margin-bottom:4px;cursor:pointer;background:transparent;text-align:left;overflow:hidden;transition:border-color .2s}.chat-poll__option:hover{border-color:var(--accent-primary, #3b82f6)}.chat-poll__option--voted{border-color:var(--accent-primary, #3b82f6);font-weight:500}.chat-poll__bar{position:absolute;left:0;top:0;bottom:0;background:var(--accent-primary, #3b82f6);opacity:.12;border-radius:8px;transition:width .4s ease}.chat-poll__option-text{position:relative;z-index:1;flex:1;font-size:13px}.chat-poll__pct{position:relative;z-index:1;font-size:12px;opacity:.7;margin-left:8px;min-width:30px;text-align:right}.chat-poll__meta{font-size:11px;opacity:.6;margin-top:4px}.chat-poll-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center}.chat-poll-modal__overlay{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chat-poll-modal__content{position:relative;background:var(--bg-primary, #fff);border-radius:20px;padding:28px;width:420px;max-width:calc(100vw - 32px);max-height:80vh;overflow-y:auto;box-shadow:0 24px 64px #00000040,0 0 0 1px #0000000d;animation:pollModalIn .2s ease-out}@keyframes pollModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.chat-poll-modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-default, #e5e7eb)}.chat-poll-modal__header h3{margin:0;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.chat-poll-modal__header h3:before{content:"📊";font-size:20px}.chat-poll-modal__close{border:none;background:var(--bg-hover, #f3f4f6);font-size:18px;cursor:pointer;color:var(--text-secondary, #6b7280);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;line-height:1}.chat-poll-modal__close:hover{background:#fee2e2;color:#ef4444}.chat-poll-modal__body{display:flex;flex-direction:column;gap:10px}.chat-poll-modal__input{width:100%;padding:12px 14px;border:1.5px solid var(--border-default, #d1d5db);border-radius:10px;font-size:14px;outline:none;box-sizing:border-box;transition:border-color .2s,box-shadow .2s;background:var(--bg-primary, #fff)}.chat-poll-modal__input:focus{border-color:var(--accent-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.chat-poll-modal__input:first-child{font-size:15px;font-weight:500}#pollOptions{display:flex;flex-direction:column;gap:8px}.chat-poll-modal__add-btn{border:1.5px dashed var(--accent-primary, #3b82f6);background:#3b82f60a;color:var(--accent-primary, #3b82f6);cursor:pointer;font-size:13px;font-weight:500;padding:10px;text-align:center;border-radius:10px;transition:background .15s}.chat-poll-modal__add-btn:hover{background:#3b82f61a}.chat-poll-modal__checkbox{display:flex;align-items:center;gap:10px;font-size:13px;cursor:pointer;padding:6px 0;color:var(--text-secondary, #6b7280)}.chat-poll-modal__checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary, #3b82f6);cursor:pointer}.chat-poll-modal__footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-default, #e5e7eb)}.chat-poll-modal__submit{width:100%;padding:12px;background:var(--accent-primary, #3b82f6);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.chat-poll-modal__submit:hover{background:var(--accent-hover, #2563eb)}.chat-poll-modal__submit:active{transform:scale(.98)}.chat-mention-dropdown{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-primary, #fff);border:1px solid var(--border-default, #d1d5db);border-radius:8px;box-shadow:0 -4px 16px #0000001f;max-height:200px;overflow-y:auto;z-index:50}.chat-mention-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:14px;transition:background .15s}.chat-mention-item:hover{background:var(--bg-hover, #f3f4f6)}.chat-mention-item__avatar{width:28px;height:28px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.grid{display:grid;gap:var(--space-6)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-5{grid-template-columns:repeat(5,1fr)}.grid-cols-6{grid-template-columns:repeat(6,1fr)}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-auto-fill{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.hidden{display:none!important}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.flex-1{flex:1}.flex-none{flex:none}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.m-0{margin:0}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.mt-0{margin-top:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.w-full{width:100%}.w-auto{width:auto}.h-full{height:100%}.min-h-screen{min-height:100vh}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-accent{color:var(--primary-light)}.bg-surface{background:var(--bg-surface)}.bg-elevated{background:var(--bg-elevated)}.bg-glass{background:var(--bg-glass)}.border{border:1px solid var(--border-default)}.border-subtle{border:1px solid var(--border-subtle)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-100{opacity:1}.transition{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-glow{box-shadow:var(--shadow-glow)}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.active{transform:translate(0)}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.active{pointer-events:auto}.main-wrapper{margin-left:0}.mobile-menu-toggle{display:flex}.mobile-user-avatar,.mobile-nav{display:block}.main-content{padding:var(--space-6);padding-top:calc(var(--space-6) + 72px);padding-bottom:calc(var(--mobile-nav-height) + var(--space-6) + env(safe-area-inset-bottom))}.lg\:grid-cols-1{grid-template-columns:1fr}.lg\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}}@media(max-width:768px){.main-content{padding:var(--space-4);padding-top:calc(var(--space-4) + 72px);padding-bottom:calc(var(--mobile-nav-height) + var(--space-4) + env(safe-area-inset-bottom))}.page-title{font-size:var(--text-2xl)}.card{border-radius:var(--radius-lg)}.card-header,.card-body,.card-footer{padding:var(--space-4)}.md\:grid-cols-1{grid-template-columns:1fr}.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}}@media(max-width:640px){:root{--space-lg: 20px;--space-xl: 24px}.main-content{padding:var(--space-3);padding-top:calc(var(--space-3) + 72px);padding-bottom:calc(var(--mobile-nav-height) + var(--space-3) + env(safe-area-inset-bottom))}.page-title{font-size:var(--text-xl)}.btn{padding:var(--space-2) var(--space-4)}.btn-lg{padding:var(--space-3) var(--space-6)}.sm\:grid-cols-1{grid-template-columns:1fr}.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.sm\:hidden{display:none}.sm\:block{display:block}.sm\:flex{display:flex}}@media print{.sidebar,.mobile-nav,.mobile-menu-toggle,.mobile-user-avatar{display:none!important}.main-wrapper{margin-left:0!important}.main-content{padding:0!important}body{background:#fff;color:#000}.card{border:1px solid #ddd;box-shadow:none;background:#fff}}[data-theme=light]{color-scheme:light}[data-theme=light] body{background:radial-gradient(circle at top left,rgba(95,125,22,.16),transparent 28%),radial-gradient(circle at top right,rgba(56,189,248,.14),transparent 24%),linear-gradient(180deg,#fbfcfe,#f5f7fb 42%,#eef2f7)}[data-theme=light] ::-moz-selection{color:#16202c}[data-theme=light] ::selection{color:#16202c}[data-theme=light] .site-footer{background:linear-gradient(180deg,#ffffffa6,#ffffffeb),linear-gradient(135deg,rgba(95,125,22,.08),transparent 35%);border-top-color:var(--border-default)}[data-theme=light] .site-footer__copy,[data-theme=light] .site-footer__bottom{color:var(--text-secondary)}[data-theme=light] .site-footer__title{color:#334155}[data-theme=light] .site-footer__links a,[data-theme=light] .site-footer__bottom-links a{color:var(--text-primary);transition:none}[data-theme=light] .site-footer__links a:hover,[data-theme=light] .site-footer__bottom-links a:hover{color:var(--text-primary)}[data-theme=light] .site-footer__bottom{border-top-color:var(--border-subtle)}[data-theme=light] .toast{background:#ffffffeb;border-color:var(--border-default);box-shadow:0 18px 40px #0f172a1f;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}[data-theme=light] .toast-message{color:var(--text-primary)}[data-theme=light] .toast-close svg{fill:var(--text-muted)}[data-theme=light] .fitconfirm-backdrop{background:#f8fafcb3}[data-theme=light] .fitconfirm-modal{background:#fffffff5;border-color:var(--border-default);box-shadow:0 24px 56px #0f172a29}[data-theme=light] .fitconfirm-message{color:var(--text-secondary)}[data-theme=light] .fitconfirm-no{background:var(--bg-elevated);border-color:var(--border-default);color:var(--text-secondary)}[data-theme=light] .fitconfirm-no:hover{background:var(--bg-hover);color:var(--text-primary)}[data-theme=light] .settings-page .settings-header h1{background:linear-gradient(135deg,#16202c,#4b5d73 55%,#8290a3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .settings-page .settings-header p,[data-theme=light] .settings-page .header-text p,[data-theme=light] .settings-page .form-label,[data-theme=light] .settings-page .theme-card-label,[data-theme=light] .settings-page .back-link{color:var(--text-secondary)}[data-theme=light] .settings-page .sidebar-card,[data-theme=light] .settings-page .content-card{background:linear-gradient(180deg,#fffffffa,#f7fafdfa);border-color:var(--border-default);box-shadow:var(--shadow-md)}[data-theme=light] .settings-page .sidebar-link{color:var(--text-secondary)}[data-theme=light] .settings-page .sidebar-link:hover{background:#0f172a0a;color:var(--text-primary)}[data-theme=light] .settings-page .sidebar-link.active{background:#5f7d1624;color:#24310f}[data-theme=light] .settings-page .link-icon{background:var(--bg-elevated)}[data-theme=light] .settings-page .sidebar-link:hover .link-icon,[data-theme=light] .settings-page .sidebar-link.active .link-icon{background:#5f7d162e}[data-theme=light] .settings-page .card-header{border-bottom-color:var(--border-subtle)}[data-theme=light] .settings-page .form-select,[data-theme=light] .settings-page .theme-card{background:var(--bg-elevated);border-color:var(--border-default)}[data-theme=light] .settings-page .theme-card{box-shadow:var(--shadow-sm)}[data-theme=light] .settings-page .theme-card:hover{background:var(--bg-hover)}[data-theme=light] .settings-page .theme-card.selected{background:linear-gradient(180deg,#5f7d1624,#fffffff5);box-shadow:0 0 0 1px #5f7d1633,var(--shadow-md)}[data-theme=light] .settings-page .back-link:hover{background:#0f172a0a;color:var(--text-primary)}[data-theme=light] .settings-page .settings-alert.success{background:#5f7d161a;border-color:#5f7d162e}[data-theme=light] .dashboard-page .stat-card,[data-theme=light] .dashboard-page .dash-card,[data-theme=light] .dashboard-page .profile-card{background:linear-gradient(180deg,#fffffffa,#f6f9fcfa);box-shadow:var(--shadow-md)}[data-theme=light] .dashboard-page .dashboard-greeting span{color:#5f7d16;-webkit-text-fill-color:#5f7d16}[data-theme=light] .sidebar-card{background:var(--bg-surface)!important;border-color:var(--border-default)!important}[data-theme=light] .sidebar-title{color:var(--text-secondary)!important}[data-theme=light] .sidebar-title svg{stroke:var(--primary)!important}[data-theme=light] .stat-label{color:var(--text-muted)!important}[data-theme=light] .stat-value{color:var(--text-primary)!important;-webkit-text-fill-color:currentColor!important}[data-theme=light] .feed-page .feed-header{border-bottom-color:var(--border-subtle)}[data-theme=light] .feed-page .feed-header h1,[data-theme=light] .feed-page .trending-author,[data-theme=light] .feed-page .post-author-name,[data-theme=light] .feed-page .feed-empty h3,[data-theme=light] .feed-page .comment-item .comment-author{color:var(--text-primary)!important}[data-theme=light] .feed-page .feed-tabs{background:#0f172a0a;border-color:#0f172a14}[data-theme=light] .feed-page .feed-tab{color:var(--text-secondary)}[data-theme=light] .feed-page .feed-tab.active,[data-theme=light] .feed-page .feed-tab:hover{background:linear-gradient(135deg,#7b9c29,#5f7d16);color:#16202c}[data-theme=light] .feed-page .sidebar-card,[data-theme=light] .feed-page .post,[data-theme=light] .feed-page .feed-empty{background:linear-gradient(180deg,#fffffffa,#f6f9fcfa)!important;border-color:#0f172a1a!important;box-shadow:var(--shadow-md)}[data-theme=light] .feed-page .sidebar-card:hover,[data-theme=light] .feed-page .post:hover{border-color:#0f172a29!important}[data-theme=light] .feed-page .trending-text,[data-theme=light] .feed-page .post-meta,[data-theme=light] .feed-page .feed-empty p,[data-theme=light] .feed-page .sidebar-empty,[data-theme=light] .feed-page .comment-item .comment-username,[data-theme=light] .feed-page .comment-item .comment-time,[data-theme=light] .feed-page .action-btn,[data-theme=light] .feed-page .post-menu-btn{color:var(--text-muted)!important}[data-theme=light] .feed-page .post-text p,[data-theme=light] .feed-page .comment-item .comment-text p{color:var(--text-secondary)!important}[data-theme=light] .feed-page .search-box input,[data-theme=light] .feed-page .comment-form textarea,[data-theme=light] .feed-page [id^=edit-post-form-] textarea,[data-theme=light] .feed-page .reaction-btn,[data-theme=light] .feed-page .stat-item{background:var(--bg-elevated)!important;border-color:#0f172a1a!important;color:var(--text-primary)!important}[data-theme=light] .feed-page .search-box input::-moz-placeholder,[data-theme=light] .feed-page .comment-form textarea::-moz-placeholder,[data-theme=light] .feed-page .composer-body textarea::-moz-placeholder{color:var(--text-muted)!important}[data-theme=light] .feed-page .search-box input::placeholder,[data-theme=light] .feed-page .comment-form textarea::placeholder,[data-theme=light] .feed-page .composer-body textarea::placeholder{color:var(--text-muted)!important}[data-theme=light] .feed-page .search-box input:focus,[data-theme=light] .feed-page .comment-form textarea:focus,[data-theme=light] .feed-page [id^=edit-post-form-] textarea:focus{border-color:#5f7d1673!important}[data-theme=light] .feed-page .trending-item:hover,[data-theme=light] .feed-page .action-btn:hover{background:#0f172a0d!important;color:var(--text-primary)!important}[data-theme=light] .feed-page .stat-value{color:#5f7d16!important;-webkit-text-fill-color:#5f7d16!important}[data-theme=light] .feed-page .post-avatar,[data-theme=light] .feed-page .post-media img,[data-theme=light] .feed-page .post-media video{border-color:#0f172a1a!important;background:#fffc}[data-theme=light] .feed-page .post-footer,[data-theme=light] .feed-page .comments-section,[data-theme=light] .feed-page [id^=edit-post-form-]{border-top-color:#0f172a14!important}[data-theme=light] .feed-page .comments-section,[data-theme=light] .feed-page [id^=edit-post-form-]{background:#f8fafcf5!important}[data-theme=light] .feed-page .post-menu-dropdown{background:#fff!important;border-color:#0f172a1f!important;box-shadow:0 20px 40px #0f172a24}[data-theme=light] .feed-page .post-menu-item{color:var(--text-secondary)!important}[data-theme=light] .feed-page .post-menu-item:hover{background:#0f172a0d!important;color:var(--text-primary)!important}[data-theme=light] .feed-page .composer-island form{background:#fffffff0!important;border-color:#0f172a1f!important;box-shadow:0 20px 60px #0f172a1f,0 0 0 1px #5f7d1614!important}[data-theme=light] .feed-page .composer-body textarea{color:var(--text-primary)!important}[data-theme=light] .feed-page .composer-avatar{border-color:#5f7d1638!important}[data-theme=light] .mt-summary-item__value{color:#b45309}[data-theme=light] .mt-summary-item--protein .mt-summary-item__value,[data-theme=light] .mt-macros__tag--p{color:#1d4ed8}[data-theme=light] .mt-summary-item--fat .mt-summary-item__value,[data-theme=light] .mt-macros__tag--f{color:#b91c1c}[data-theme=light] .mt-summary-item--carbs .mt-summary-item__value,[data-theme=light] .mt-macros__tag--c{color:#49610d}[data-theme=light] .mt-macros__tag--p,[data-theme=light] .mt-macros__tag--f,[data-theme=light] .mt-macros__tag--c{font-weight:var(--font-bold)}[data-theme=light] .water-amount-badge{background:#0ea5e924;color:#0f4c81}[data-theme=light] .water-progress-val.goal-done{color:#0f4c81}[data-theme=light] .sleep-duration-badge--good{background:#84b11f29;color:#4d6b0f}[data-theme=light] .sleep-duration-badge--ok{background:#f9731629;color:#9a3412}[data-theme=light] .sleep-duration-badge--low{background:#ef444424;color:#b91c1c}[data-theme=light] .sleep-progress-val.sleep-goal-done{color:#9a3412}[data-theme=light] .profile-edit-page .pe-banner-preview__avatar-btn{background:#fffffff5;border:1px solid rgba(15,23,42,.12);box-shadow:0 8px 22px #0f172a29}[data-theme=light] .profile-edit-page .pe-banner-preview__avatar-btn svg{color:var(--text-primary)}[data-theme=light] .profile-edit-page .pe-banner-preview__avatar-btn:hover{background:var(--bg-elevated)}[data-theme=light] .profile-edit-page .pe-banner-preview__change-btn{background:#fffffff0;color:var(--text-primary);border:1px solid rgba(15,23,42,.12);box-shadow:0 10px 28px #0f172a29;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=light] .profile-edit-page .pe-banner-preview__change-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}[data-theme=light] .feed-page .reaction-btn.like:hover,[data-theme=light] .feed-page .reaction-btn.like.active{background:#ef44441a!important;border-color:#ef44443d!important;color:#dc2626!important}[data-theme=light] .feed-page .reaction-btn.dislike:hover,[data-theme=light] .feed-page .reaction-btn.dislike.active{background:#7c3aed1a!important;border-color:#7c3aed38!important;color:#7c3aed!important}[data-theme=light] .feed-page .comment-btn.like:hover,[data-theme=light] .feed-page .comment-btn.like.active,[data-theme=light] .feed-page .comment-action.like:hover,[data-theme=light] .feed-page .comment-action.like.active{color:#dc2626!important}[data-theme=light] .feed-page .comment-btn.like.active svg{fill:#dc2626!important}[data-theme=light] .feed-page .comment-btn.dislike:hover,[data-theme=light] .feed-page .comment-btn.dislike.active,[data-theme=light] .feed-page .comment-action.dislike:hover,[data-theme=light] .feed-page .comment-action.dislike.active{color:#7c3aed!important}[data-theme=light] .feed-page .comment-btn.dislike.active svg{fill:#7c3aed!important}[data-theme=light] .feed-page .comment-btn:hover,[data-theme=light] .feed-page .comment-action:hover,[data-theme=light] .feed-page .comment .comment-actions .action-btn:hover{background:#0f172a0d!important;border-color:#0f172a1a!important;color:var(--text-primary)!important}[data-theme=light] .feed-page .comment-btn.reply:hover,[data-theme=light] .feed-page .comment-action.reply:hover,[data-theme=light] .feed-page .comment .comment-actions .reply-btn:hover{background:#0f172a0f!important;color:#1f2937!important}[data-theme=light] .feed-page .comment-btn.edit:hover,[data-theme=light] .feed-page .comment .comment-actions .edit-comment-btn:hover{background:#d977061f!important;color:#92400e!important}[data-theme=light] .feed-page .comment-btn.delete:hover,[data-theme=light] .feed-page .comment .comment-actions .delete-btn:hover{background:#dc26261a!important;color:#b91c1c!important}[data-theme=light] .feed-page .comment-btn.show-replies,[data-theme=light] .feed-page .comment .comment-actions .show-replies-btn,[data-theme=light] .feed-page .replies-toggle-text{color:#334155!important}[data-theme=light] .feed-page .replies-toggle,[data-theme=light] .feed-page .replies-collapse-btn{background:transparent!important;border:none!important;color:#334155!important}[data-theme=light] .feed-page .replies-toggle-line{background:#33415533!important}[data-theme=light] .feed-page .comment-btn.show-replies:hover,[data-theme=light] .feed-page .comment .comment-actions .show-replies-btn:hover,[data-theme=light] .feed-page .replies-toggle:hover,[data-theme=light] .feed-page .replies-collapse-btn:hover,[data-theme=light] .feed-page .replies-toggle:hover .replies-toggle-text{background:#0f172a0f!important;color:#0f172a!important}[data-theme=light] .feed-page .replies-toggle:hover .replies-toggle-line{background:#0f172a57!important}[data-theme=light] .feed-page .comment-quote{background:#f3f6fb!important;border-left-color:#3b82f673!important}[data-theme=light] .feed-page .comment-quote:hover{background:#e9eef6!important}[data-theme=light] .feed-page .comment-quote-author{color:#1e3a8a!important}[data-theme=light] .feed-page .comment-quote-username,[data-theme=light] .feed-page .comment-quote-text{color:#475569!important}[data-theme=light] .feed-page .comment-item .comment-author,[data-theme=light] .feed-page .comment-author{color:#0f172a!important}[data-theme=light] .feed-page .comment-item .comment-author:hover,[data-theme=light] .feed-page .comment-author:hover{color:#1e293b!important}[data-theme=light] .feed-page .comment-item .comment-username,[data-theme=light] .feed-page .comment-item .comment-time,[data-theme=light] .feed-page .comment-item .comment-edited,[data-theme=light] .feed-page .comment-username,[data-theme=light] .feed-page .comment-time{color:#64748b!important}[data-theme=light] .feed-page .comment-item .comment-text p,[data-theme=light] .feed-page .comment-body p{color:#334155!important}[data-theme=light] .feed-page .comment-item .comment-mention,[data-theme=light] .feed-page .comment-mention{color:#1d4ed8!important}[data-theme=light] .feed-page .btn-cancel,[data-theme=light] .feed-page .edit-cancel-btn,[data-theme=light] .feed-page .cancel-edit,[data-theme=light] .feed-page .cancel-edit-comment,[data-theme=light] .feed-page .reply-cancel,[data-theme=light] .feed-page .cancel-reply{background:#fff!important;border-color:#0f172a1f!important;color:#475569!important}[data-theme=light] .feed-page .btn-cancel:hover,[data-theme=light] .feed-page .edit-cancel-btn:hover,[data-theme=light] .feed-page .cancel-edit:hover,[data-theme=light] .feed-page .cancel-edit-comment:hover,[data-theme=light] .feed-page .reply-cancel:hover,[data-theme=light] .feed-page .cancel-reply:hover{background:#0f172a0f!important;border-color:#0f172a29!important;color:#0f172a!important;box-shadow:none!important}[data-theme=light] .dashboard-page .profile-stat-value{color:var(--text-primary)}[data-theme=light] .dashboard-page .event-item{color:var(--text-secondary)}[data-theme=light] .dashboard-page .event-date{background:#5f7d1624;border-color:#5f7d1638}[data-theme=light] .dashboard-page .event-date-day,[data-theme=light] .dashboard-page .event-type{color:var(--text-primary)}[data-theme=light] .dashboard-page .event-date-month,[data-theme=light] .dashboard-page .event-desc,[data-theme=light] .dashboard-page .empty-state-text{color:var(--text-secondary)}[data-theme=light] .dashboard-page .empty-state-btn{color:#16202c}[data-theme=light] .sp-name,[data-theme=light] .sp-card__header h3,[data-theme=light] .sp-stat__value,[data-theme=light] .sp-detail__value,[data-theme=light] .sp-mini-stat__value{color:var(--text-primary)}[data-theme=light] .sp-username,[data-theme=light] .sp-bio,[data-theme=light] .sp-stat__label,[data-theme=light] .sp-detail__label,[data-theme=light] .sp-mini-stat__label,[data-theme=light] .sp-empty p{color:var(--text-secondary)}[data-theme=light] .sp-stat,[data-theme=light] .sp-mini-stat,[data-theme=light] .sp-tab{background:var(--bg-elevated);border-color:var(--border-default)}[data-theme=light] .sp-tab{color:var(--text-secondary)}[data-theme=light] .sp-tab:hover,[data-theme=light] .sp-tab.active{background:#5f7d161f;color:#24310f}[data-theme=light] .progress-page .calculate-btn,[data-theme=light] .goals-page .create-btn,[data-theme=light] .calendar-page .add-event-btn,[data-theme=light] .calendar-page .add-first-event-btn,[data-theme=light] .calendar-page .btn-save,[data-theme=light] .calorie-page .calorie-submit-btn,[data-theme=light] .goals-page .gm-submit-btn:not(.gm-submit-btn--log){color:#16202c;box-shadow:0 14px 30px #84b11f2e}[data-theme=light] .progress-page .calculate-btn svg,[data-theme=light] .goals-page .create-btn svg,[data-theme=light] .calendar-page .add-event-btn svg,[data-theme=light] .calendar-page .btn-save svg,[data-theme=light] .goals-page .gm-submit-btn:not(.gm-submit-btn--log) svg{stroke:currentColor}[data-theme=light] .goals-page .log-btn{background:#5f7d161a;border-color:#5f7d1638;color:#5f7d16}[data-theme=light] .goals-page .log-btn:hover{background:var(--primary);border-color:var(--primary);color:#16202c}[data-theme=light] .goals-page .gm-backdrop{background:#f1f5f9c2}[data-theme=light] .goals-page .gm-modal{background:#fffffffa;border-color:#0f172a1a;box-shadow:0 28px 80px #0f172a2e}[data-theme=light] .goals-page .gm-log-stat{background:var(--bg-elevated);box-shadow:none}[data-theme=light] .goals-page .gm-log-stat--accent{background:#0ea5e914;border-color:#0ea5e929}[data-theme=light] .goals-page .gm-log-input-shell{background:#5f7d1614;border-color:#5f7d162e;box-shadow:none}[data-theme=light] .goals-page .gm-log-input-shell:focus-within{border-color:#5f7d1657;box-shadow:0 0 0 3px #5f7d161a}[data-theme=light] .goals-page .gm-log-input::-moz-placeholder{color:#0f172a59}[data-theme=light] .goals-page .gm-log-input::placeholder{color:#0f172a59}[data-theme=light] .goals-page .gm-type-tile-inner{background:var(--bg-elevated);border-color:#0f172a1a}[data-theme=light] .calendar-page .modal-overlay{background:#f1f5f9c7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}[data-theme=light] .calendar-page .modal-content{background:#fffffffa;border-color:#0f172a1a;box-shadow:0 24px 80px #0f172a2e}[data-theme=light] .calendar-page .modal-header{background:#f8fafcf0;border-bottom-color:#0f172a14}[data-theme=light] .calendar-page .modal-close{background:var(--bg-elevated);border-color:#0f172a1a;color:var(--text-muted)}[data-theme=light] .calendar-page .modal-close:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#0f172a24}[data-theme=light] .calendar-page .form-group label,[data-theme=light] .calendar-page .custom-type-input label,[data-theme=light] .calendar-page .type-option .type-name,[data-theme=light] .calendar-page .delete-content p{color:var(--text-secondary)}[data-theme=light] .calendar-page .form-group label svg{color:var(--text-muted)}[data-theme=light] .calendar-page .form-group input[type=date],[data-theme=light] .calendar-page .form-group textarea,[data-theme=light] .calendar-page .custom-type-input,[data-theme=light] .calendar-page .custom-type-input input{background:var(--bg-elevated);border-color:#0f172a1a;color:var(--text-primary)}[data-theme=light] .calendar-page .type-option .type-icon{background:var(--bg-elevated);border-color:#0f172a1a}[data-theme=light] .calendar-page .type-option:hover .type-icon{background:#fffffff5;border-color:#0f172a29;box-shadow:0 10px 26px #0f172a1f}[data-theme=light] .calendar-page .modal-actions{border-top-color:#0f172a14}[data-theme=light] .calendar-page .btn-cancel{background:var(--bg-elevated);border-color:#0f172a1a;color:var(--text-secondary)}[data-theme=light] .calendar-page .btn-cancel:hover{background:var(--bg-hover);border-color:#0f172a24;color:var(--text-primary)}[data-theme=light] .progress-page #lightbox{background:#f1f5f9c7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}[data-theme=light] .progress-page .lightbox-content img{box-shadow:0 28px 80px #0f172a38}[data-theme=light] .progress-page .lightbox-close,[data-theme=light] .progress-page .lightbox-nav{background:#fffffff0;border-color:#0f172a1a;box-shadow:0 10px 30px #0f172a1f}[data-theme=light] .progress-page .lightbox-info p:first-child{color:var(--text-primary)}[data-theme=light] .progress-page .lightbox-info p:last-child{color:var(--text-secondary)}[data-theme=light] .progress-page .photo-action-btn{border-color:#0f172a1a;background:#fffffffa}[data-theme=light] .admin-layout{--admin-surface: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(247, 250, 253, .98));--admin-surface-strong: #f8fafc;--admin-border: rgba(15, 23, 42, .1);--admin-text: #16202c;--admin-muted: #5b6777;--admin-shadow: 0 20px 44px rgba(15, 23, 42, .08)}[data-theme=light] .admin-layout .admin-hero,[data-theme=light] .admin-layout .admin-hero--premium,[data-theme=light] .admin-layout .admin-hero--warning{background:radial-gradient(circle at top right,rgba(95,125,22,.12),transparent 42%),linear-gradient(180deg,#fffffffa,#f7fafdfa);border-color:#0f172a1a;box-shadow:var(--admin-shadow)}[data-theme=light] .admin-layout .admin-card,[data-theme=light] .admin-layout .admin-toolbar,[data-theme=light] .admin-layout .admin-table-wrap,[data-theme=light] .admin-layout .admin-stat,[data-theme=light] .admin-layout .admin-activity__item,[data-theme=light] .admin-layout .admin-empty-state,[data-theme=light] .admin-layout .admin-chart-shell{box-shadow:var(--admin-shadow)}[data-theme=light] .admin-layout .admin-activity__item,[data-theme=light] .admin-layout .admin-empty-state{background:var(--admin-surface-strong)}[data-theme=light] .admin-layout .admin-table thead th{background:#f8fafc}[data-theme=light] .admin-layout .admin-table tbody tr:hover{background:#0f172a08}[data-theme=light] .admin-layout .admin-chart-shell{background:linear-gradient(180deg,#fffffffa,#f6f9fcfa);border:1px solid var(--admin-border)}[data-theme=light] .admin-layout .admin-button--ghost{background:#fff;border-color:#0f172a1f;color:#16202c}[data-theme=light] .admin-layout .admin-button--ghost:hover{background:#0f172a0d}#app{display:flex;min-height:100vh}.main-wrapper{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition-base)}.main-content{flex:1;max-width:var(--content-max-width);width:100%;margin:0 auto}.mobile-menu-toggle{display:none;position:fixed;top:var(--space-4);left:var(--space-4);width:44px;height:44px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-items:center;justify-content:center;z-index:calc(var(--z-fixed) + 1);cursor:pointer;transition:all var(--transition-fast)}.mobile-menu-toggle:hover{background:var(--bg-elevated);border-color:var(--primary)}.mobile-menu-toggle svg{width:24px;height:24px;fill:var(--text-primary)}.mobile-user-avatar{display:none;position:fixed;top:var(--space-4);right:var(--space-4);z-index:calc(var(--z-fixed) + 1)}.mobile-user-avatar img{width:40px;height:40px;border-radius:var(--radius-full);border:2px solid var(--primary);-o-object-fit:cover;object-fit:cover;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.mobile-user-avatar:hover img{transform:scale(1.05);box-shadow:var(--shadow-glow)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border-subtle);padding:var(--space-2) var(--space-4);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom));z-index:var(--z-fixed)}.mobile-nav-inner{display:flex;justify-content:space-around;align-items:center;max-width:500px;margin:0 auto}.mobile-nav-link{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2);color:var(--text-muted);font-size:.65rem;font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:60px}.mobile-nav-link svg{width:22px;height:22px;fill:currentColor}.mobile-nav-link.active{color:var(--primary-light)}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2);color:var(--text-primary)}.page-subtitle{color:var(--text-secondary);font-size:var(--text-base)}.alert{padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);margin-bottom:var(--space-6);display:flex;align-items:center;gap:var(--space-3);animation:slideDown .3s var(--ease-out)}.alert-success{background:var(--success-bg);border:1px solid rgba(16,185,129,.3);color:var(--success)}.alert-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:var(--danger)}.alert-warning{background:var(--warning-bg);border:1px solid rgba(245,158,11,.3);color:var(--warning)}.alert-info{background:var(--info-bg);border:1px solid rgba(59,130,246,.3);color:var(--info)}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-base)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-6);border-top:1px solid var(--border-subtle);background:var(--bg-glass-light)}.stat-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--primary)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}.stat-icon svg{width:24px;height:24px;fill:#fff}.stat-icon.primary{background:var(--primary)}.stat-icon.secondary{background:var(--secondary)}.stat-icon.success{background:var(--success)}.stat-icon.warning{background:var(--warning)}.stat-icon.danger{background:var(--danger)}.stat-icon.accent{background:var(--accent)}.stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-1)}.stat-label{font-size:var(--text-sm);color:var(--text-muted)}.stat-change{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium);margin-top:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.stat-change.positive{color:var(--success);background:var(--success-bg)}.stat-change.negative{color:var(--danger);background:var(--danger-bg)}.progress-bar{width:100%;height:8px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-fill.success{background:var(--success)}.progress-fill.warning{background:var(--warning)}.progress-fill.danger{background:var(--danger)}.circular-progress{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.circular-progress svg{transform:rotate(-90deg);width:100%;height:100%}.circular-progress .progress-bg{fill:none;stroke:var(--bg-elevated);stroke-width:8}.circular-progress .progress-value-circle{fill:none;stroke:url(#progressGradient);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.circular-progress .progress-text{position:absolute;text-align:center}.circular-progress .progress-number{font-size:var(--text-xl);font-weight:var(--font-bold)}.circular-progress .progress-label{font-size:var(--text-xs);color:var(--text-muted)}.avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-default)}.avatar-xs{width:24px;height:24px}.avatar-sm{width:32px;height:32px}.avatar-md{width:40px;height:40px}.avatar-lg{width:56px;height:56px}.avatar-xl{width:80px;height:80px}.avatar-glow{border-color:var(--primary)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full)}.badge-primary{background:var(--primary-100);color:var(--primary-light)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-4);text-align:left;border-bottom:1px solid var(--border-subtle)}.table th{background:var(--bg-glass-light);font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.table td{font-size:var(--text-sm)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-glass-light)}.table tbody tr:last-child td{border-bottom:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn .3s var(--ease-out)}.animate-slide-up{animation:slideUp .4s var(--ease-out)}.animate-slide-down{animation:slideDown .4s var(--ease-out)}.animate-slide-in{animation:slideIn .4s var(--ease-out)}.animate-scale-in{animation:scaleIn .3s var(--ease-out)}.animate-pulse{animation:pulse 2s infinite}.animate-spin{animation:spin 1s linear infinite}.stagger-animation>*{animation:slideUp .4s var(--ease-out) backwards}.stagger-animation>*:nth-child(1){animation-delay:.05s}.stagger-animation>*:nth-child(2){animation-delay:.1s}.stagger-animation>*:nth-child(3){animation-delay:.15s}.stagger-animation>*:nth-child(4){animation-delay:.2s}.stagger-animation>*:nth-child(5){animation-delay:.25s}.stagger-animation>*:nth-child(6){animation-delay:.3s}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-glass-light) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}
