@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary-50: #F0FAF3;--primary-100: #EBF7EE;--primary-200: #D8F3DC;--primary-300: #B7E4C7;--primary-400: #95D5B2;--primary-500: #74C69D;--primary-600: #52B788;--primary-700: #40916C;--primary-800: #2D6A4F;--primary-900: #1B4332;--accent-500: #40916C;--accent-600: #2D6A4F;--success-50: #ecfdf5;--success-100: #d1fae5;--success-500: #10b981;--success-600: #059669;--success-700: #047857;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: var(--gray-50);--bg-tertiary: var(--gray-100);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-muted: var(--gray-400);--border-light: var(--gray-200);--border-default: var(--gray-300);--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--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;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal: 1000;--z-toast: 1100}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;border:none;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}@media(max-width:768px){input,select,textarea{font-size:16px!important}}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}:focus:not(:focus-visible){outline:none}::selection{background:var(--primary-100);color:var(--text-primary)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success-600)}.text-warning{color:var(--warning-600)}.text-error{color:var(--error-600)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.btn-base{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;line-height:1.5;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-base:disabled{opacity:.5;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.toast-container{position:fixed;top:80px;right:20px;z-index:1100;display:flex;flex-direction:column;gap:12px;min-width:320px;max-width:420px;width:calc(100% - 40px)}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border-radius:10px;box-shadow:0 4px 16px #1b43321f;animation:toastSlideIn .3s ease-out;position:relative;overflow:hidden;border:1px solid #E8F2EA}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast.removing{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toast-icon svg{width:24px;height:24px}.toast-content{flex:1;min-width:0}.toast-message{margin:0;font-size:14px;font-weight:500;line-height:1.5;word-wrap:break-word}.toast-close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#9ca89f;transition:all .2s ease;margin:-2px -2px -2px 0}.toast-close:hover{background:#f0faf3;color:#6b7f74}.toast-close svg{width:16px;height:16px}.toast-progress{position:absolute;bottom:0;left:0;height:3px;width:100%;animation:progress linear forwards}@keyframes progress{0%{width:100%}to{width:0%}}.toast-success{border-left:4px solid #059669}.toast-success .toast-icon{color:#059669}.toast-success .toast-message{color:#065f46}.toast-success .toast-progress{background:#059669}.toast-error{border-left:4px solid #DC2626}.toast-error .toast-icon{color:#dc2626}.toast-error .toast-message{color:#991b1b}.toast-error .toast-progress{background:#dc2626}.toast-warning{border-left:4px solid #D97706}.toast-warning .toast-icon{color:#d97706}.toast-warning .toast-message{color:#92400e}.toast-warning .toast-progress{background:#d97706}.toast-info{border-left:4px solid #0284C7}.toast-info .toast-icon{color:#0284c7}.toast-info .toast-message{color:#0c4a6e}.toast-info .toast-progress{background:#0284c7}@media(max-width:480px){.toast-container{inset:auto 16px 20px;width:auto;max-width:none;min-width:0}.toast{padding:12px 14px}.toast-message{font-size:13px}}.error-boundary-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0faf3;padding:1rem}.error-boundary-card{width:100%;max-width:480px;background:#fff;border-radius:16px;box-shadow:0 12px 40px #1b43321f;padding:2.5rem;text-align:center}.error-boundary-icon{width:80px;height:80px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;box-shadow:0 10px 25px -5px #ef44444d}.error-boundary-icon svg{width:40px;height:40px;color:#fff}.error-boundary-title{margin:0 0 1rem;font-size:20px;font-weight:700;color:#1b2a22}.error-boundary-message{margin:0 0 2rem;color:#6b7f74;font-size:14px;line-height:1.6}.error-boundary-details{background:#fef2f2;border:1px solid #FECACA;border-radius:12px;padding:1rem;margin-bottom:2rem;text-align:left}.error-boundary-error-name{margin:0 0 .75rem;color:#dc2626;font-weight:600;font-size:.875rem;word-break:break-word}.error-boundary-stack{margin:0;padding:.75rem;background:#fee2e2;border-radius:8px;font-size:.75rem;color:#991b1b;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.error-boundary-actions{display:flex;gap:1rem;justify-content:center}.error-boundary-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.error-boundary-button svg{width:18px;height:18px}.error-boundary-button.primary{background:linear-gradient(135deg,#2d6a4f,#40916c);color:#fff}.error-boundary-button.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1b43324d}.error-boundary-button.primary:active{transform:translateY(0)}.error-boundary-button.secondary{background:#fff;color:#2d6a4f;border:1px solid #D1E7D8}.error-boundary-button.secondary:hover{background:#f0faf3;border-color:#52b788}.error-boundary-button.secondary:active{background:#ebf7ee}@media(max-width:480px){.error-boundary-container{padding:0;align-items:flex-start}.error-boundary-card{max-width:100%;min-height:100vh;border-radius:0;display:flex;flex-direction:column;justify-content:center;padding:1.5rem}.error-boundary-icon{width:64px;height:64px}.error-boundary-icon svg{width:32px;height:32px}.error-boundary-title{font-size:1.5rem}.error-boundary-message{font-size:14px}.error-boundary-actions{flex-direction:column}.error-boundary-button{width:100%;padding:1rem}}.manual-send-overlay{position:fixed;inset:0;background:#0a1f1380;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.manual-send-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #1b433226;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideUp .25s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(135deg,#1b4332,#2d6a4f);color:#fff;border-radius:16px 16px 0 0;border-bottom:none}.modal-header h2{margin:0;font-size:18px;font-weight:600}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:8px;font-size:24px;color:#fff;cursor:pointer;transition:all .2s ease;padding:0;line-height:1}.modal-close:hover{background:#fff3}.modal-tabs{display:flex;border-bottom:1px solid #E8F2EA;background:#f8fcf9}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6b7f74;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-1px}.tab-btn:hover{color:#1b2a22;background:#ebf7ee}.tab-btn.active{color:#2d6a4f;border-bottom-color:#2d6a4f;background:#fff}.tab-btn svg{width:18px;height:18px}.modal-content{flex:1;overflow-y:auto;padding:24px}.error-box{background:#fef2f2;border:1px solid #fee2e2;color:#dc2626;padding:12px 16px;border-radius:12px;margin-bottom:20px;font-size:14px}.error-box p{margin:0 0 4px}.error-box p:last-child{margin-bottom:0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:13px;color:#1b2a22;text-transform:uppercase;letter-spacing:.03em}.required{color:#dc2626;margin-left:2px}.form-input{width:100%;padding:10px 14px;height:44px;border:1px solid #D1E7D8;border-radius:8px;font-size:14px;color:#1b2a22;background:#fff;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#52b788;box-shadow:0 0 0 3px #52b78826}.form-input:disabled{background:#f8fcf9;color:#9ca89f;cursor:not-allowed}.form-textarea{resize:vertical;min-height:100px;height:auto;font-family:inherit}.form-help{font-size:12px;color:#6b7f74;margin-top:6px;margin-bottom:0}.char-count{text-align:right}.channel-selector{display:flex;gap:8px}.channel-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:2px solid #D1E7D8;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;font-size:13px;font-weight:500;color:#1b2a22}.channel-btn:hover{border-color:#52b788;background:#f0faf3}.channel-btn.active{border-color:#2d6a4f;background:#d8f3dc;color:#1b4332}.channel-btn .channel-icon{width:24px;height:24px}.channel-btn .channel-icon.whatsapp{color:#25d366}.channel-btn .channel-icon.sms{color:#52b788}.channel-btn .channel-icon.email{color:#40916c}.file-drop-zone{border:2px dashed #D1E7D8;border-radius:12px;padding:24px 16px;text-align:center;cursor:pointer;transition:all .2s;background:#f8fcf9}.file-drop-zone:hover{border-color:#52b788;background:#ebf7ee}.file-drop-zone .upload-icon{width:36px;height:36px;color:#95d5b2;margin-bottom:8px}.file-drop-zone:hover .upload-icon{color:#2d6a4f}.file-drop-zone p{margin:0;font-size:14px;color:#1b2a22;font-weight:500}.file-drop-zone span{font-size:12px;color:#6b7f74}.hidden-input{display:none}.attached-file{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ebf7ee;border:1px solid #D1E7D8;border-radius:12px}.attached-file .file-icon{width:28px;height:28px;color:#2d6a4f;flex-shrink:0}.attached-file .file-info{flex:1;min-width:0}.attached-file .file-name{display:block;font-weight:600;color:#1b2a22;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attached-file .file-size{font-size:12px;color:#6b7f74}.attached-file .file-remove{width:28px;height:28px;padding:4px;background:transparent;border:none;color:#9ca89f;cursor:pointer;border-radius:6px;transition:all .2s;flex-shrink:0}.attached-file .file-remove:hover{background:#fee2e2;color:#dc2626}.attached-file .file-remove svg{width:100%;height:100%}.info-box{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#ebf7ee;border:1px solid #D1E7D8;border-radius:12px;font-size:13px;color:#2d6a4f}.info-box svg{width:18px;height:18px;flex-shrink:0;margin-top:1px}.warning-box{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#fef3c7;border:1px solid #fcd34d;border-radius:12px;font-size:13px;color:#92400e;margin-bottom:16px}.warning-box svg{width:20px;height:20px;flex-shrink:0;margin-top:1px;color:#d97706}.warning-box strong{color:#78350f}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #E8F2EA;background:#fff;border-radius:0 0 16px 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#2d6a4f,#40916c);color:#fff;border:none}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1b4332,#2d6a4f);box-shadow:0 4px 12px #1b43324d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:#2d6a4f;border:1px solid #D1E7D8}.btn-secondary:hover:not(:disabled){background:#f0faf3;border-color:#52b788}.btn-send{background:linear-gradient(135deg,#2d6a4f,#40916c);color:#fff;padding:10px 24px;border:none}.btn-send:hover:not(:disabled){background:linear-gradient(135deg,#1b4332,#2d6a4f);box-shadow:0 4px 12px #1b43324d;transform:translateY(-1px)}.btn-send .send-icon{width:18px;height:18px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.success-state{text-align:center;padding:20px 0}.success-state .success-icon{width:64px;height:64px;margin:0 auto 16px;color:#2d6a4f}.success-state .success-icon svg{width:100%;height:100%}.success-state h3{margin:0 0 8px;font-size:20px;font-weight:700;color:#1b2a22}.success-state p{margin:0;font-size:14px;color:#6b7f74}.success-state p strong{color:#1b2a22}.success-actions{display:flex;justify-content:center;gap:12px;margin-top:24px}.history-tab{min-height:200px}.history-list{max-height:400px;overflow-y:auto;margin-bottom:16px}.history-item{background:#f8fcf9;border:1px solid #E8F2EA;border-radius:12px;padding:12px 16px;margin-bottom:10px;transition:border-color .2s}.history-item:hover{border-color:#d1e7d8}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.history-channel{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#1b2a22;text-transform:capitalize}.channel-icon-small{width:16px;height:16px}.channel-icon-small.whatsapp{color:#25d366}.channel-icon-small.sms{color:#52b788}.channel-icon-small.email{color:#40916c}.history-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.02em}.history-status.status-delivered{background:#d1fae5;color:#059669}.history-status.status-sent{background:#fef3c7;color:#92400e}.history-status.status-failed{background:#fee2e2;color:#dc2626}.history-status.status-pending{background:#e8f2ea;color:#6b7f74}.history-recipient{font-size:13px;color:#1b2a22;margin-bottom:4px}.history-recipient strong{color:#0a1f13}.history-subject{font-size:12px;color:#6b7f74;margin-bottom:4px;font-style:italic}.history-content{font-size:13px;color:#6b7f74;background:#fff;padding:8px 10px;border-radius:6px;margin:8px 0;border-left:3px solid #D1E7D8}.history-footer{display:flex;gap:12px;font-size:11px;color:#9ca89f}.history-delivered{color:#059669}.history-error-box{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:12px;color:#dc2626;margin-top:8px}.history-error-box svg{width:14px;height:14px;flex-shrink:0;margin-top:1px}.history-actions{display:flex;gap:8px;margin-top:16px}.history-actions .btn{flex:1;justify-content:center}.history-actions .btn svg{width:16px;height:16px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#6b7f74}.loading-state .spinner.large{width:32px;height:32px;border-width:3px;border-color:#2d6a4f33;border-top-color:#2d6a4f}.loading-state p{margin-top:12px;font-size:14px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#9ca89f}.empty-state svg{width:48px;height:48px;margin-bottom:12px}.empty-state p{font-size:14px;margin:0}.delivery-note{font-size:12px;color:#9ca89f;margin-top:8px;font-style:italic}@media(max-width:480px){.manual-send-modal{max-height:100vh;border-radius:0}.manual-send-overlay{padding:0}.modal-header,.modal-footer{border-radius:0}.channel-selector{flex-direction:column}.channel-btn{flex-direction:row;justify-content:center;gap:10px}.success-actions{flex-direction:column}.history-list{max-height:300px}}.app-layout{min-height:100vh;background:#f5f3e8}.main-nav{background:linear-gradient(135deg,#1b4332,#2d6a4f);color:#fff;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;box-shadow:0 2px 8px #0000001a}.header-brand{display:flex;align-items:center;gap:12px}.brand-info{display:flex;flex-direction:column}.brand-name{font-size:16px;font-weight:700;color:#fff;line-height:1.2}.brand-subtitle{font-size:11px;color:#fff9;letter-spacing:.5px}.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s ease}.menu-toggle:hover{background:#ffffff1a}.menu-toggle span{display:block;width:20px;height:2px;background:#fff;border-radius:1px;transition:all .2s ease}.header-nav{display:flex;align-items:center;gap:4px}.nav-link{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;border-radius:8px;color:#fffc;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;white-space:nowrap}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#ffffff26;color:#fff;font-weight:600}.nav-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:9999px;min-width:18px;text-align:center;line-height:1.4}.header-right{display:flex;align-items:center;gap:12px}.status-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border-radius:9999px;font-size:13px}.status-text{color:#95d5b2;font-weight:500}.dot{width:8px;height:8px;border-radius:50%}.dot.online{background:#52b788;box-shadow:0 0 8px #52b788}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px;border-radius:50%;transition:all .2s ease}.user-button:hover{background:#ffffff1a}.user-avatar{width:36px;height:36px;background:#ffffff26;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff}.avatar-backdrop{position:fixed;inset:0;z-index:299}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 12px 40px #1b433226;border:1px solid #E8F2EA;min-width:200px;overflow:hidden;z-index:300;animation:dropdownSlide .15s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:16px;border-bottom:1px solid #E8F2EA}.dropdown-header strong{display:block;color:#1b2a22;font-size:14px}.dropdown-header span{font-size:12px;color:#6b7f74}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:none;cursor:pointer;color:#374151;font-size:14px;text-align:left;transition:background .2s ease}.dropdown-item:hover{background:#f0faf3}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout:hover{background:#fef2f2}.dropdown-item svg{width:18px;height:18px;flex-shrink:0}.mobile-nav-backdrop,.mobile-nav{display:none}@media(max-width:768px){.menu-toggle{display:flex}.header-nav{display:none}.brand-name{font-size:14px}.brand-subtitle{font-size:10px}.status-text{display:none}.mobile-nav-backdrop{display:block;position:fixed;inset:64px 0 0;background:#0000004d;z-index:199;animation:fadeIn .2s ease-out}.mobile-nav{display:flex;flex-direction:column;position:fixed;top:64px;left:0;right:0;background:#fff;box-shadow:0 12px 40px #1b433226;z-index:200;animation:slideDown .2s ease-out;max-height:calc(100vh - 64px);overflow-y:auto}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-nav-link{display:flex;align-items:center;gap:12px;width:100%;padding:16px 24px;border:none;background:none;cursor:pointer;color:#374151;font-size:15px;font-weight:500;text-align:left;transition:background .2s ease;min-height:48px}.mobile-nav-link:hover{background:#f0faf3}.mobile-nav-link.active{color:#2d6a4f;font-weight:600;background:#f0faf3;border-left:3px solid #2D6A4F}.mobile-nav-link.logout{color:#dc2626}.mobile-nav-link.logout:hover{background:#fef2f2}.mobile-nav-link svg{width:20px;height:20px;flex-shrink:0}.mobile-nav-divider{height:1px;background:#e8f2ea;margin:4px 0}.user-avatar{width:40px;height:40px;font-size:15px}}@media(max-width:480px){.main-nav{padding:0 12px;height:56px}.brand-name{font-size:13px}.brand-subtitle{display:none}.mobile-nav-backdrop{top:56px}.mobile-nav{top:56px;max-height:calc(100vh - 56px)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0faf3;padding:1rem}.login-card{width:100%;max-width:420px;background:#fff;border-radius:16px;box-shadow:0 12px 40px #1b43321f;overflow:hidden}.login-header{background:linear-gradient(135deg,#1b4332,#2d6a4f);color:#fff;padding:2rem;text-align:center}.login-logo{width:60px;height:60px;background:#ffffff26;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.login-logo svg{width:32px;height:32px}.login-header h1{margin:0 0 .5rem;font-size:22px;font-weight:700;letter-spacing:1px}.login-header p{margin:0;opacity:.6;font-size:13px}.login-form{padding:2rem}.login-form .form-group{margin-bottom:16px}.login-form .form-group label{display:block;margin-bottom:6px;font-weight:600;color:#6b7f74;font-size:13px}.login-form .form-group input{width:100%;padding:0 14px;height:44px;border:1px solid #D1E7D8;border-radius:8px;font-size:15px;color:#1b2a22;transition:all .2s ease;box-sizing:border-box}.login-form .form-group input:focus{outline:none;border-color:#52b788;box-shadow:0 0 0 3px #52b78826}.login-form .form-group input:disabled{background:#f8fcf9;color:#9ca89f;cursor:not-allowed}.login-form .form-group input::placeholder{color:#9ca89f}.error-message{display:flex;align-items:center;gap:.5rem;padding:10px 14px;background:#fee2e2;border:1px solid #FECACA;border-radius:8px;color:#dc2626;margin-bottom:16px;font-size:13px}.error-message svg{width:18px;height:18px;flex-shrink:0}.login-button{width:100%;height:44px;padding:0 1rem;background:linear-gradient(135deg,#1b4332,#2d6a4f);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1b43324d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-button .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{padding:1rem 2rem 1.5rem;text-align:center;border-top:1px solid #E8F2EA}.login-footer p{margin:0;color:#9ca89f;font-size:13px}@media(max-width:480px){.login-container{padding:0;align-items:flex-start}.login-card{max-width:100%;min-height:100vh;border-radius:0;display:flex;flex-direction:column}.login-header{padding:3rem 1.5rem 2rem}.login-form{padding:1.5rem;flex:1}.login-footer{padding:1rem 1.5rem 2rem}}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:linear-gradient(135deg,#0a1f13,#1b4332,#2d6a4f)}.app-loading .loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:#2d6a4f;border-radius:50%;animation:spin .8s linear infinite}.app-loading p{color:#ffffffb3;font-size:.875rem;margin:0}@keyframes spin{to{transform:rotate(360deg)}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f0faf3}button,input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
