:root{--color-primary: #1a7a4c;--color-primary-rgb: 26, 122, 76;--color-primary-light: #2da365;--color-primary-dark: #145e3b;--color-primary-glow: rgba(26, 122, 76, .2);--color-primary-50: rgba(26, 122, 76, .05);--color-primary-100: rgba(26, 122, 76, .1);--color-secondary: #a85613;--color-secondary-light: #c97a3a;--color-secondary-dark: #8a440e;--color-secondary-glow: rgba(168, 86, 19, .2);--color-accent: #5e6b64;--color-accent-glow: rgba(94, 107, 100, .2);--color-error: #dc3545;--color-error-dark: #b02a37;--color-error-light: rgba(220, 53, 69, .08);--color-success: #198754;--color-success-dark: #146c43;--color-success-light: rgba(25, 135, 84, .08);--color-warning: #e8a317;--color-warning-dark: #c48a0f;--color-warning-light: rgba(232, 163, 23, .08);--color-info: #0d6efd;--color-info-dark: #0a58ca;--color-info-light: rgba(13, 110, 253, .08);--color-teal-100: rgba(26, 122, 76, .08);--color-teal-700: #145e3b;--bg-primary: #ffffff;--bg-secondary: #f3f6f5;--bg-tertiary: #e8edeb;--bg-card: #ffffff;--bg-card-hover: #f8faf9;--bg-hover: rgba(19, 38, 27, .03);--bg-app-gradient: #f3f6f5;--text-primary: #13261b;--text-secondary: #3d4f47;--text-tertiary: #5e6b64;--text-muted: #969696;--text-placeholder: #b0b0b0;--border-color: rgba(19, 38, 27, .12);--border-color-hover: rgba(26, 122, 76, .35);--border-color-focus: #1a7a4c;--gradient-primary: linear-gradient(135deg, #1a7a4c 0%, #2da365 100%);--gradient-secondary: linear-gradient(135deg, #a85613 0%, #c97a3a 100%);--gradient-teal: linear-gradient(135deg, #1a7a4c 0%, #145e3b 100%);--gradient-accent: linear-gradient(135deg, #1a7a4c 0%, #a85613 100%);--gradient-glow: linear-gradient(90deg, #1a7a4c, #a85613, #1a7a4c);--glass-background: rgba(255, 255, 255, .7);--glass-dark-background: rgba(19, 38, 27, .95);--glass-border: rgba(19, 38, 27, .08);--glass-dark-border: rgba(255, 255, 255, .1);--glass-backdrop: blur(20px);--glass-shadow: 0 4px 24px rgba(19, 38, 27, .08);--glass-dark-shadow: 0 8px 32px rgba(19, 38, 27, .15);--shadow-sm: 0 1px 3px rgba(19, 38, 27, .06), 0 1px 2px rgba(19, 38, 27, .04);--shadow-md: 0 4px 12px rgba(19, 38, 27, .08);--shadow-lg: 0 10px 30px -10px rgba(19, 38, 27, .12);--shadow-xl: 0 20px 40px -12px rgba(19, 38, 27, .15);--shadow-glow-primary: 0 4px 20px rgba(26, 122, 76, .15);--shadow-glow-secondary: 0 4px 20px rgba(168, 86, 19, .15);--shadow-glow-teal: 0 4px 20px rgba(26, 122, 76, .15);--shadow-glow-purple: 0 4px 20px rgba(168, 86, 19, .15);--shadow-primary: 0 4px 14px rgba(26, 122, 76, .15);--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Outfit", var(--font-sans);--font-mono: "JetBrains Mono", "SF Mono", "Cascadia Code", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500;--focus-ring: 0 0 0 3px rgba(26, 122, 76, .3);--focus-ring-error: 0 0 0 3px rgba(220, 53, 69, .25);--focus-ring-success: 0 0 0 3px rgba(25, 135, 84, .25)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-app-gradient);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;letter-spacing:-.02em;color:var(--text-primary)}h1{font-size:2.25rem;font-weight:800;letter-spacing:-.03em}h2{font-size:1.75rem;font-weight:700;letter-spacing:-.025em}h3{font-size:1.375rem;font-weight:600}h4{font-size:1.125rem;font-weight:600}h5{font-size:1rem;font-weight:600}h6{font-size:.875rem;font-weight:600;letter-spacing:0}p{color:var(--text-secondary);line-height:1.7}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark);text-decoration:underline}a.btn:hover{color:inherit;text-decoration:none}a:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:var(--space-2) var(--space-4);z-index:var(--z-tooltip);transition:top var(--transition-fast)}.skip-link:focus{top:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-6)}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-color-hover)}.card-static{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:.9375rem;font-weight:500;line-height:1.5;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px #1a7a4c40}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-color-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-error-dark);transform:translateY(-2px);box-shadow:0 6px 20px #dc354533}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-success-dark);transform:translateY(-2px);box-shadow:0 6px 20px #19875433}.btn-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-outline:hover:not(:disabled){background:var(--color-primary-50);border-color:var(--color-primary-light);transform:translateY(-2px)}.btn-teal{background:var(--gradient-teal);color:#fff;box-shadow:0 4px 14px #1a7a4c33}.btn-teal:hover:not(:disabled){background:linear-gradient(135deg,#145e3b,#0f4d2e);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px #1a7a4c40}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8125rem}.btn-lg{padding:var(--space-4) var(--space-8);font-size:1rem}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:.9375rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(var(--color-primary-rgb),.15)}.form-input::placeholder{color:var(--text-placeholder)}.form-input:disabled{background:var(--bg-tertiary);opacity:.7;cursor:not-allowed}.form-input.error,.form-input.form-input-error{border-color:var(--color-error)}.form-input.error:focus,.form-input.form-input-error:focus{box-shadow:var(--focus-ring-error)}.form-input.success{border-color:var(--color-success)}.form-input.success:focus{box-shadow:var(--focus-ring-success)}textarea.form-input{min-height:120px;resize:vertical}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:var(--space-10)}.form-error{display:block;margin-top:var(--space-2);font-size:.8125rem;color:var(--color-error);font-weight:500}.form-hint{display:block;margin-top:var(--space-2);font-size:.8125rem;color:var(--text-muted)}.search-input{width:100%;padding:var(--space-4) var(--space-5);padding-left:var(--space-12);font-family:var(--font-sans);font-size:1rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-2xl);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(var(--color-primary-rgb),.15)}.search-input::placeholder{color:var(--text-placeholder)}.search-wrapper{position:relative}.search-wrapper .search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.form-label.required:after{content:" *";color:var(--color-error)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.375rem var(--space-3);font-size:.75rem;font-weight:600;letter-spacing:.01em;border-radius:var(--radius-full)}.badge-primary{background:var(--color-primary-100);color:var(--color-primary-dark)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background:var(--color-info-light);color:var(--color-info-dark)}.badge-teal{background:var(--color-teal-100);color:var(--color-teal-700)}.tag{display:inline-flex;align-items:center;padding:.375rem var(--space-3);font-size:.8125rem;font-weight:500;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary)}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px}.spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-card-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease forwards}.animate-slide-up{animation:slideUp var(--transition-slow) ease forwards}.animate-slide-down{animation:slideDown var(--transition-slow) ease forwards}.animate-scale-in{animation:scaleIn var(--transition-slow) ease forwards}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.modal-overlay{position:fixed;inset:0;background:#13261b40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:var(--space-6);z-index:var(--z-modal);animation:fadeIn var(--transition-fast) ease;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal{width:100%;max-width:500px;max-height:90vh;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn var(--transition-base) ease;margin:var(--space-6) auto;flex-shrink:0}.modal-content{width:100%;max-width:500px;max-height:calc(100vh - var(--space-12));background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn var(--transition-base) ease;margin:var(--space-6) auto;flex-shrink:0;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.125rem;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-5) var(--space-6);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center}.empty-state-icon{width:80px;height:80px;margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:var(--bg-tertiary);border-radius:var(--radius-full)}.empty-state-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2)}.empty-state-description{max-width:400px;margin-bottom:var(--space-6);color:var(--text-tertiary)}.stars{display:flex;gap:var(--space-1)}.star{width:24px;height:24px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.star.filled{color:var(--color-warning)}.star:hover{transform:scale(1.1)}.avatar{display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;font-weight:600;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-md{width:40px;height:40px;font-size:.875rem}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.avatar-xl{width:80px;height:80px;font-size:1.75rem}.avatar-2xl{width:120px;height:120px;font-size:2.5rem}.avatar-teal{background:var(--gradient-teal)}.avatar-indigo{background:linear-gradient(135deg,#6366f1,#4f46e5)}.avatar-rose{background:linear-gradient(135deg,#f43f5e,#e11d48)}.avatar-orange{background:linear-gradient(135deg,#f97316,#ea580c)}.avatar-editable{position:relative;cursor:pointer}.avatar-editable:hover .avatar-overlay{opacity:1}.avatar-overlay{position:absolute;inset:0;background:#13261b66;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity var(--transition-fast);border-radius:var(--radius-full)}.pronouns{font-size:.875rem;color:var(--text-muted);font-weight:400}.pronouns-inline{margin-left:var(--space-2)}.page-header{margin-bottom:var(--space-8)}.page-header h1{font-size:1.75rem;margin-bottom:var(--space-2)}.page-header p{color:var(--text-secondary);font-size:1rem}@media(max-width:768px){h1{font-size:1.75rem}h2{font-size:1.25rem}h3{font-size:1.125rem}.container{padding:0 var(--space-4)}.card{padding:var(--space-4)}.hide-mobile{display:none!important}.modal-overlay{padding:var(--space-4);align-items:flex-start;padding-top:env(safe-area-inset-top,var(--space-4));padding-bottom:env(safe-area-inset-bottom,var(--space-4))}.modal,.modal-content{max-height:calc(100vh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - var(--space-8));margin:var(--space-4) auto;border-radius:var(--radius-xl)}.modal-body{max-height:calc(100vh - 200px);overflow-y:auto;-webkit-overflow-scrolling:touch}}@media(min-width:769px){.hide-desktop{display:none!important}}@supports (-webkit-touch-callout: none){.modal-overlay,body{min-height:-webkit-fill-available}}.glass-card{background:var(--glass-background);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);transition:all var(--transition-base)}.glass-card:hover{background:#ffffffe6;border-color:#1a7a4c26;transform:translateY(-4px);box-shadow:var(--shadow-lg)}.glass-card-dark{background:var(--glass-dark-background);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-dark-border);border-radius:var(--radius-2xl);box-shadow:var(--glass-dark-shadow);color:#fff}.glow-primary{box-shadow:var(--shadow-glow-primary);animation:pulse-glow-primary 3s ease-in-out infinite}.glow-teal{box-shadow:var(--shadow-glow-teal);animation:pulse-glow-teal 3s ease-in-out infinite}.glow-purple{box-shadow:var(--shadow-glow-purple);animation:pulse-glow-purple 3s ease-in-out infinite}@keyframes pulse-glow-primary{0%,to{box-shadow:0 4px 20px #1a7a4c1f}50%{box-shadow:0 4px 30px #1a7a4c33}}@keyframes pulse-glow-teal{0%,to{box-shadow:0 4px 20px #1a7a4c1f}50%{box-shadow:0 4px 30px #1a7a4c33}}@keyframes pulse-glow-purple{0%,to{box-shadow:0 4px 20px #a856131f}50%{box-shadow:0 4px 30px #a8561333}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.float-animation{animation:float 6s ease-in-out infinite}.magnetic{transition:transform .3s cubic-bezier(.23,1,.32,1)}.magnetic:hover{transform:scale(1.05)}.particle-background{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:-1;pointer-events:none}.layout{min-height:100vh;display:flex;flex-direction:row}.sidebar{position:fixed;top:0;left:0;bottom:0;width:252px;background:#fff;border-right:1px solid rgba(19,38,27,.12);display:flex;flex-direction:column;z-index:var(--z-sticky, 100);transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden;font-family:"Outfit",var(--font-sans)}.sidebar:after{content:"";position:absolute;top:0;right:0;bottom:0;width:1px;background:linear-gradient(180deg,#1a7a4c40,#1a7a4c14 30%,#a856130f 70%,#a8561326);pointer-events:none}.sidebar.collapsed{width:68px}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#1a7a4c33;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#1a7a4c59}.sidebar-logo{display:flex;align-items:center;gap:.625rem;padding:1.125rem 1rem;font-family:"Outfit",var(--font-sans);font-size:1.375rem;font-weight:700;color:#13261b;text-decoration:none;flex-shrink:0;height:64px;border-bottom:1px solid rgba(19,38,27,.08);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;white-space:nowrap;position:relative}.sidebar-logo:after{content:"";position:absolute;bottom:0;left:1rem;right:1rem;height:1px;background:linear-gradient(90deg,transparent,rgba(26,122,76,.2),rgba(168,86,19,.12),transparent)}.sidebar-logo:hover{text-decoration:none;color:#13261b}.sidebar-logo .logo-icon{font-size:1.625rem;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(26,122,76,.35));animation:fish-bob 4s ease-in-out infinite}@keyframes fish-bob{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-2px) rotate(2deg)}75%{transform:translateY(1px) rotate(-1deg)}}.sidebar-logo .logo-text{background:linear-gradient(135deg,#1a7a4c,#2da365 60%,#a85613);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;opacity:1;transition:opacity .25s ease,width .3s ease}.sidebar.collapsed .sidebar-logo .logo-text{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-logo{padding:1.125rem 0;justify-content:center}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem 0}.sidebar-section-label{padding:1.25rem 1.125rem .375rem;font-family:"Outfit",var(--font-sans);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#969696;white-space:nowrap;overflow:hidden;transition:all .25s ease}.sidebar.collapsed .sidebar-section-label{opacity:0;height:0;padding:0;margin:0}.sidebar-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(19,38,27,.08),transparent);margin:.375rem .75rem}.sidebar.collapsed .sidebar-divider{margin:.375rem .5rem}.sidebar-nav-link{display:flex;align-items:center;gap:.75rem;padding:.5rem .875rem;margin:2px .5rem;font-family:"Outfit",var(--font-sans);font-size:.8125rem;font-weight:500;color:#3d4f47;text-decoration:none;border-radius:.5rem;transition:all .2s ease;position:relative;white-space:nowrap;overflow:hidden;letter-spacing:.01em}.sidebar-nav-link:hover{background:#1a7a4c0f;color:#13261b;text-decoration:none}.sidebar-nav-link:hover .nav-icon{filter:drop-shadow(0 0 3px rgba(26,122,76,.2))}.sidebar-nav-link.active{background:#1a7a4c14;color:#1a7a4c;font-weight:600}.sidebar-nav-link.active:before{content:"";position:absolute;left:0;top:.375rem;bottom:.375rem;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#1a7a4c,#2da365);box-shadow:0 0 8px #1a7a4c4d,0 0 3px #1a7a4c33}.sidebar-nav-link.active .nav-icon{filter:drop-shadow(0 0 4px rgba(26,122,76,.25))}.sidebar-nav-link .nav-icon{font-size:1.0625rem;flex-shrink:0;width:24px;text-align:center;transition:filter .2s ease}.sidebar-nav-link .nav-label{opacity:1;transition:opacity .2s ease;flex:1}.sidebar.collapsed .sidebar-nav-link .nav-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-nav-link{justify-content:center;padding:.5rem;margin:2px .375rem}.sidebar.collapsed .sidebar-nav-link.active:before{top:.25rem;bottom:.25rem}.sidebar-nav-badge{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%);color:#fff;border-radius:10px;padding:.0625rem .4rem;font-family:"Outfit",var(--font-sans);font-size:.6875rem;font-weight:600;min-width:18px;text-align:center;line-height:1.4;flex-shrink:0;box-shadow:0 1px 3px #ef444440}.sidebar.collapsed .sidebar-nav-badge{position:absolute;top:0;right:0;padding:0 .25rem;font-size:.5625rem;min-width:15px;border-radius:8px}.sidebar.collapsed .sidebar-nav-link[title]{position:relative}.sidebar-footer{flex-shrink:0;border-top:1px solid rgba(19,38,27,.08);padding:.5rem;position:relative;background:#f3f6f5}.sidebar-footer:before{content:"";position:absolute;top:0;left:.75rem;right:.75rem;height:1px;background:linear-gradient(90deg,transparent,rgba(26,122,76,.15),rgba(168,86,19,.1),transparent)}.sidebar-role-badge{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .625rem;background:#fff;border:1px solid rgba(19,38,27,.1);border-radius:.5rem;cursor:pointer;font-family:"Outfit",var(--font-sans);font-size:.8125rem;font-weight:500;color:#3d4f47;transition:all .2s ease;overflow:hidden;white-space:nowrap}.sidebar-role-badge:hover{background:#1a7a4c0a;border-color:#1a7a4c33}.sidebar-role-badge .role-icons{display:flex;gap:.125rem;flex-shrink:0}.sidebar-role-badge .role-text{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;transition:opacity .25s ease}.sidebar-role-badge .role-arrow{font-size:.5625rem;flex-shrink:0;transition:opacity .25s ease;color:#5e6b64}.sidebar.collapsed .sidebar-role-badge .role-text,.sidebar.collapsed .sidebar-role-badge .role-arrow{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-role-badge{justify-content:center;padding:.5rem}.sidebar-user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .375rem;margin-top:.25rem;overflow:hidden;white-space:nowrap}.sidebar-user-avatar{flex-shrink:0;text-decoration:none;display:flex;align-items:center;transition:all .2s ease}.sidebar-user-avatar:hover{transform:scale(1.08);text-decoration:none;filter:drop-shadow(0 0 4px rgba(26,122,76,.2))}.sidebar-user-name{flex:1;font-family:"Outfit",var(--font-sans);font-size:.8125rem;font-weight:500;color:#13261b;overflow:hidden;text-overflow:ellipsis;transition:opacity .25s ease}.sidebar.collapsed .sidebar-user-name{opacity:0;width:0;overflow:hidden}.sidebar-settings-link{flex-shrink:0;font-size:.9375rem;color:#5e6b64;text-decoration:none;padding:.25rem;border-radius:.375rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.sidebar-settings-link:hover{color:#1a7a4c;background:#1a7a4c14;text-decoration:none}.sidebar.collapsed .sidebar-settings-link{display:none}.sidebar-logout-btn{flex-shrink:0;background:none;border:none;font-size:.9375rem;color:#5e6b64;padding:.25rem;border-radius:.375rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.sidebar-logout-btn:hover{color:#dc2626;background:#dc26260f}.sidebar.collapsed .sidebar-logout-btn{display:none}.sidebar-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.4375rem;margin-top:.25rem;background:none;border:1px solid rgba(19,38,27,.08);border-radius:.5rem;cursor:pointer;font-family:"Outfit",var(--font-sans);font-size:.75rem;color:#5e6b64;transition:all .2s ease;overflow:hidden;white-space:nowrap;letter-spacing:.02em}.sidebar-toggle:hover{background:#13261b0a;color:#3d4f47;border-color:#13261b26}.sidebar-toggle .toggle-icon{flex-shrink:0;font-size:.75rem;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed .sidebar-toggle .toggle-icon{transform:rotate(180deg)}.sidebar-toggle .toggle-label{transition:opacity .2s ease}.sidebar.collapsed .sidebar-toggle .toggle-label{opacity:0;width:0;overflow:hidden}.sidebar-role-switcher{position:relative}.role-switcher-dropdown{position:absolute;bottom:calc(100% + .5rem);left:0;right:0;background:#fff;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(19,38,27,.12);border-radius:.625rem;box-shadow:0 -8px 32px #13261b14,0 0 0 1px #13261b0a,0 -4px 16px #1a7a4c0a;min-width:220px;z-index:1000;overflow:hidden}.sidebar.collapsed .role-switcher-dropdown{left:68px;right:auto;bottom:0;min-width:240px}.role-switcher-header{padding:.75rem 1rem;font-family:"Outfit",var(--font-sans);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#5e6b64;border-bottom:1px solid rgba(19,38,27,.08);background:#f3f6f5}.role-switcher-option{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:transparent;text-align:left;cursor:pointer;transition:all .15s ease;font-family:"Outfit",var(--font-sans);font-size:.875rem;color:#13261b}.role-switcher-option:hover:not(:disabled){background:#1a7a4c0f}.role-switcher-option.active{background:#1a7a4c1a;color:#1a7a4c}.role-switcher-option.locked{opacity:.4;cursor:not-allowed}.role-switcher-option .role-icon{font-size:1.25rem}.role-switcher-option .role-label{flex:1;font-weight:500}.role-switcher-option .role-lock{font-size:.875rem}.role-switcher-hint{padding:.75rem 1rem;background:#f3f6f5;border-top:1px solid rgba(19,38,27,.08);font-family:"Outfit",var(--font-sans);font-size:.75rem;color:#5e6b64;line-height:1.4}.main-area{flex:1;margin-left:252px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.sidebar-is-collapsed .main-area{margin-left:68px}.main-content{flex:1;padding:var(--space-8, 2rem) 0;background:#f3f6f5}.footer{background:#fff;border-top:1px solid rgba(19,38,27,.12);padding:var(--space-6, 1.5rem) 0}.footer-content{max-width:1200px;margin:0 auto;padding:0 var(--space-6, 1.5rem);text-align:center}.footer-content p{font-family:"Outfit",var(--font-sans);font-size:.8125rem;color:#969696;letter-spacing:.01em}.offline-indicator{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%);color:#fff;padding:.125rem .5rem;border-radius:9999px;font-family:"Outfit",var(--font-sans);font-size:.6875rem;font-weight:600;animation:pulse 2s infinite;margin-left:auto;box-shadow:0 1px 4px #ef444440}.sidebar.collapsed .offline-indicator{margin:0;padding:.125rem .25rem;font-size:.5rem}.mobile-header{display:none}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:1px solid rgba(19,38,27,.12);font-size:1.25rem;color:#13261b;cursor:pointer;border-radius:.5rem;transition:all .2s ease}.hamburger-btn:hover{background:#1a7a4c0f;border-color:#1a7a4c33}.sidebar-overlay{display:none}@media(max-width:1024px)and (min-width:769px){.sidebar{width:68px}.sidebar:not(.collapsed){width:252px}.main-area{margin-left:68px}.layout:not(.sidebar-is-collapsed) .main-area{margin-left:252px}.sidebar.collapsed .sidebar-logo .logo-text,.sidebar.collapsed .sidebar-nav-link .nav-label,.sidebar.collapsed .sidebar-role-badge .role-text,.sidebar.collapsed .sidebar-role-badge .role-arrow,.sidebar.collapsed .sidebar-user-name,.sidebar.collapsed .sidebar-toggle .toggle-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-section-label{opacity:0;height:0;padding:0;margin:0}.sidebar.collapsed .sidebar-nav-link{justify-content:center;padding:.5rem;margin:2px .375rem}.sidebar.collapsed .sidebar-logo{padding:1.125rem 0;justify-content:center}.sidebar.collapsed .sidebar-role-badge{justify-content:center;padding:.5rem}.sidebar.collapsed .sidebar-settings-link,.sidebar.collapsed .sidebar-logout-btn{display:none}.sidebar.collapsed .sidebar-nav-badge{position:absolute;top:0;right:0;padding:0 .25rem;font-size:.5625rem;min-width:15px}.sidebar.collapsed .sidebar-toggle .toggle-icon{transform:rotate(180deg)}}@media(max-width:768px){.sidebar{width:272px;transform:translate(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:1100}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open.collapsed{width:272px}.sidebar.mobile-open .sidebar-logo .logo-text,.sidebar.mobile-open .sidebar-nav-link .nav-label,.sidebar.mobile-open .sidebar-role-badge .role-text,.sidebar.mobile-open .sidebar-role-badge .role-arrow,.sidebar.mobile-open .sidebar-user-name,.sidebar.mobile-open .sidebar-toggle .toggle-label{opacity:1;width:auto}.sidebar.mobile-open .sidebar-section-label{opacity:1;height:auto;padding:1.25rem 1.125rem .375rem}.sidebar.mobile-open .sidebar-nav-link{justify-content:flex-start;padding:.5rem .875rem;margin:2px .5rem}.sidebar.mobile-open .sidebar-logo{padding:1.125rem 1rem;justify-content:flex-start}.sidebar.mobile-open .sidebar-role-badge{justify-content:flex-start;padding:.5rem .625rem}.sidebar.mobile-open .sidebar-settings-link,.sidebar.mobile-open .sidebar-logout-btn{display:flex}.sidebar.mobile-open .sidebar-nav-badge{position:static;padding:.0625rem .4rem;font-size:.6875rem;min-width:18px}.sidebar-overlay{display:block;position:fixed;inset:0;background:#13261b4d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1050;opacity:0;pointer-events:none;transition:opacity .35s ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.main-area{margin-left:0!important}.mobile-header{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:#fff;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(19,38,27,.1);position:sticky;top:0;z-index:var(--z-sticky, 100)}.mobile-header .logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;font-family:"Outfit",var(--font-sans);font-size:1.25rem;font-weight:700;color:#13261b}.mobile-header .logo-icon{font-size:1.375rem;filter:drop-shadow(0 0 4px rgba(26,122,76,.3))}.mobile-header .logo-text{background:linear-gradient(135deg,#1a7a4c,#2da365);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-toggle{display:none}.main-content{padding:var(--space-6, 1.5rem) 0}}.toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:400px}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideDown var(--transition-base) ease}.toast-icon{font-size:1.25rem;flex-shrink:0}.toast-content{flex:1}.toast-message{font-size:.9375rem;color:var(--text-primary);line-height:1.4}.toast-close{padding:var(--space-1);background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;transition:color var(--transition-fast)}.toast-close:hover{color:var(--text-primary)}.toast-success{border-left:4px solid var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-left:4px solid var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}@media(max-width:768px){.toast-container{left:var(--space-4);right:var(--space-4);max-width:none}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4);background:var(--bg-primary)}.loading-screen p{color:var(--text-secondary)}
