:root{font-size:var(--font-size-base)}*{box-sizing:border-box;margin:0;padding:0;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}*::-webkit-scrollbar-track{background:var(--scrollbar-track)}*::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--scrollbar-radius);border:2px solid var(--scrollbar-track)}*::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}*::-webkit-scrollbar-corner{background:var(--scrollbar-track)}.app-mobile-nav,.mobile-bottom-nav,.pos-cat-bar,.sf-filter-bar{scrollbar-width:thin}.app-mobile-nav::-webkit-scrollbar,.mobile-bottom-nav::-webkit-scrollbar,.pos-cat-bar::-webkit-scrollbar,.sf-filter-bar::-webkit-scrollbar{height:6px}html{font-size:var(--font-size-base);-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base-rem);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--text);background-color:var(--bg-white);min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--text)}h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-lg)}h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm)}h4{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}h5,h6{font-size:var(--font-size-base-rem);margin-bottom:var(--spacing-xs)}p{margin-bottom:var(--spacing-md);color:var(--text)}small{font-size:var(--font-size-sm)}a{color:var(--accent);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}a:hover{color:var(--primary)}input,textarea,select,button{font-family:var(--font-family);font-size:var(--font-size-md)}label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text)}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.toast-container{position:fixed;top:var(--spacing-xl);right:var(--spacing-xl);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-md);max-width:380px;width:100%}.toast{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + 4px);border-radius:var(--radius-lg);background:var(--bg-white);box-shadow:0 4px 20px #0000001f,0 2px 8px #00000014;animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon-wrapper{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-icon{font-size:var(--font-size-lg)}.toast-success .toast-icon-wrapper{background:#10b9811a}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon-wrapper{background:#ef44441a}.toast-error .toast-icon{color:var(--error)}.toast-warning .toast-icon-wrapper{background:#f59e0b1a}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon-wrapper{background:#3b82f61a}.toast-info .toast-icon{color:var(--accent)}.toast-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.toast-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text);line-height:var(--line-height-tight)}.toast-message{font-size:var(--font-size-sm);color:var(--text-muted);line-height:var(--line-height-normal);word-wrap:break-word}.toast-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-light);transition:all var(--transition-fast);flex-shrink:0;font-size:var(--font-size-sm);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;width:24px;height:24px}.toast-close:hover{color:var(--text);background:var(--bg-light)}.toast-progress{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow:hidden}.toast-progress-bar{height:100%;transition:width .1s linear;border-radius:0 2px 2px 0}.toast-success .toast-progress-bar{background:linear-gradient(90deg,var(--success),#34d399)}.toast-error .toast-progress-bar{background:linear-gradient(90deg,var(--error),#f87171)}.toast-warning .toast-progress-bar{background:linear-gradient(90deg,var(--warning),#fbbf24)}.toast-info .toast-progress-bar{background:linear-gradient(90deg,var(--accent),#60a5fa)}@media(max-width:480px){.toast-container{top:var(--spacing-md);right:var(--spacing-md);left:var(--spacing-md);max-width:none}.toast{padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + 4px)}.toast-icon-wrapper{width:32px;height:32px}.toast-icon{font-size:var(--font-size-base-rem)}}.lock-screen-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#6366f1f2,#8b5cf6f2);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--spacing-lg)}.lock-screen-content{background:var(--bg-white);border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:500px;width:100%;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.lock-icon{width:80px;height:80px;background:linear-gradient(135deg,#dc2626,#ef4444);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-lg)}.lock-icon svg{font-size:2rem;color:#fff}.lock-screen-content h1{font-size:1.5rem;color:var(--text-primary);margin-bottom:var(--spacing-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.lock-screen-content h1 svg{color:#f59e0b}.lock-screen-content>p{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.warning-text{background:#fef3c7;border:1px solid #fbbf24;border-radius:var(--radius-md);padding:var(--spacing-md);color:#92400e}.warning-text strong{color:#b45309}.lock-features{background:var(--bg-light);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);text-align:left}.lock-features>p{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.lock-features ul{list-style:none;padding:0;margin:0}.lock-features li{padding:var(--spacing-xs) 0;color:var(--text-secondary)}.lock-screen-content .btn-lg{width:100%;padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem;margin-bottom:var(--spacing-md)}.help-text{font-size:.875rem;color:var(--text-light)}.help-text a{color:var(--brand)}.deactivated-icon{background:linear-gradient(135deg,#6b7280,#9ca3af)!important}@media(max-width:768px){.lock-screen-overlay{padding:var(--spacing-md);align-items:flex-end}.lock-screen-content{padding:var(--spacing-lg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:100%}.lock-icon{width:60px;height:60px}.lock-icon svg{font-size:1.5rem}.lock-screen-content h1{font-size:1.25rem}.lock-features{padding:var(--spacing-md)}.lock-screen-content .btn-lg{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem}}.spinner{display:inline-block;border:3px solid var(--bg-gray, #e5e7eb);border-top-color:var(--primary, #102c57);border-radius:50%;animation:spin .8s linear infinite;box-sizing:border-box}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-md{width:32px;height:32px;border-width:3px}.spinner-lg{width:48px;height:48px;border-width:4px}.spinner-xl{width:64px;height:64px;border-width:5px}.spinner-primary{border-top-color:var(--primary, #102c57);border-right-color:transparent}.spinner-white{border-color:#ffffff4d;border-top-color:var(--text-white, #ffffff)}.spinner-secondary{border-top-color:var(--text-muted, #6b7280)}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md, 1rem);width:100%}.spinner-fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffe6;z-index:9999}.spinner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffffb3;z-index:10;border-radius:inherit}.spinner-flex-fill{flex:1;display:flex;flex-direction:column;justify-content:center;min-height:400px}.spinner-text{font-size:var(--font-size-sm, .875rem);color:var(--text-muted, #6b7280);font-weight:500;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-family-secondary: "Poppins", sans-serif;--font-family-mono: "Fira Code", "Courier New", monospace;--font-size-base: 14px;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-md: .875rem;--font-size-base-rem: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.75rem;--font-size-4xl: 2rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-unit: 4px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--spacing-4xl: 40px;--spacing-5xl: 48px;--padding-input: 10px 12px;--padding-btn: 8px 16px;--padding-btn-sm: 6px 12px;--padding-btn-lg: 12px 24px;--padding-card: 16px;--padding-section: 24px;--primary: #0f6972;--primary-light: #34757e;--primary-dark: #0c5259;--primary-hover: #0a4a50;--secondary: #e3a492;--secondary-light: #f0bcaf;--secondary-dark: #f5a08c;--accent: #97bbbf;--accent-light: #c4e3e5;--accent-dark: #92a7a8;--admin-bg-start: var(--primary-dark);--admin-bg-end: var(--primary);--admin-blue-start: var(--accent);--admin-blue-end: var(--accent-dark);--admin-purple-start: var(--secondary);--admin-purple-end: var(--secondary-dark);--admin-orange-start: var(--secondary-light);--admin-orange-end: var(--secondary-dark);--login-bg-end: var(--admin-blue-end);--login-success: var(--success-bright);--white: #ffffff;--black: #000000;--gray-50: #f2f8f8;--gray-100: #f1fafa;--gray-200: #dbe8e8;--gray-300: #c2cbd3;--gray-400: #91a3ab;--gray-500: #92a7a8;--gray-600: #34757e;--gray-700: #0f6972;--gray-800: #0c5259;--gray-900: #0a4a50;--success: #34757e;--success-light: #c4e3e5;--success-dark: #0f6972;--success-bg: rgba(52, 117, 126, .1);--success-bright: #10b981;--success-bg-bright: #d1fae5;--success-text-bright: #065f46;--warning: #f5a08c;--warning-light: #f3ded6;--warning-dark: #e3a492;--warning-bg: rgba(245, 160, 140, .1);--warning-bright: #f59e0b;--warning-bg-bright: #fef3c7;--warning-text-bright: #92400e;--error: #f5a08c;--error-light: #f3ded6;--error-dark: #e3a492;--error-bg: rgba(245, 160, 140, .1);--error-bright: #ef4444;--error-bg-bright: #fee2e2;--error-text-bright: #991b1b;--info: #97bbbf;--info-light: #c4e3e5;--info-dark: #34757e;--info-bg: rgba(151, 187, 191, .1);--text: #0a4a50;--text-muted: #91a3ab;--text-light: #c2cbd3;--text-white: #ffffff;--bg-white: #ffffff;--bg-light: #f2f8f8;--bg-soft: #f2f8f8;--bg-gray: #dbe8e8;--border: #c2cbd3;--border-dark: #91a3ab;--scrollbar-track: #eaf2f2;--scrollbar-thumb: #8fa8ad;--scrollbar-thumb-hover: #5f7f85;--scrollbar-size: 9px;--scrollbar-radius: 999px;--input-bg: #f1fafa;--input-border: #c2cbd3;--input-focus: rgba(15, 105, 114, .15);--badge-success-bg: rgba(52, 117, 126, .15);--badge-success-text: #0c5259;--badge-danger-bg: rgba(239, 68, 68, .15);--badge-danger-text: #991b1b;--badge-warning-bg: rgba(245, 158, 11, .15);--badge-warning-text: #92400e;--badge-info-bg: rgba(151, 187, 191, .2);--badge-info-text: #0f6972;--badge-pending-bg: rgba(145, 163, 171, .15);--badge-pending-text: #34757e;--badge-default-bg: rgba(145, 163, 171, .1);--badge-default-text: #91a3ab;--badge-trial-bg: rgba(139, 92, 246, .15);--badge-trial-text: #5b21b6;--badge-primary-bg: rgba(15, 105, 114, .15);--badge-primary-text: var(--primary-dark);--badge-secondary-bg: rgba(71, 85, 105, .12);--badge-secondary-text: #334155;--badge-accent-bg: rgba(151, 187, 191, .2);--badge-accent-text: var(--accent-dark);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-card: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .08);--shadow-xl: 0 15px 30px rgba(0, 0, 0, .1);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .2);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--padding-btn);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative;overflow:hidden;white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn:focus{outline:none;box-shadow:0 0 0 3px var(--input-focus)}.btn-primary{background:var(--primary);color:var(--text-white)}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--transition-slow)}.btn-primary:hover:not(:disabled):before{left:100%}.btn-primary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--bg-white);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-light);border-color:var(--border-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-outline{background:transparent;color:var(--primary);border:1px solid var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary);color:var(--text-white)}.btn-outline:active:not(:disabled){background:var(--primary-dark)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--bg-gray);color:var(--text)}.btn-danger{background:var(--error);color:var(--text-white)}.btn-danger:hover:not(:disabled){background:var(--error-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger:active:not(:disabled){transform:translateY(0)}.btn-danger-outline{background:transparent;color:var(--error);border:1px solid var(--error)}.btn-danger-outline:hover:not(:disabled){background:var(--error);color:var(--text-white)}.btn-success{background:var(--success);color:var(--text-white)}.btn-success:hover:not(:disabled){background:var(--success-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success:active:not(:disabled){transform:translateY(0)}.btn-success-outline{background:transparent;color:var(--success);border:1px solid var(--success)}.btn-success-outline:hover:not(:disabled){background:var(--success);color:var(--text-white)}.btn-warning{background:var(--warning);color:var(--text-white)}.btn-warning:hover:not(:disabled){background:var(--warning-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-warning:active:not(:disabled){transform:translateY(0)}.btn-warning-outline{background:transparent;color:var(--warning);border:1px solid var(--warning)}.btn-warning-outline:hover:not(:disabled){background:var(--warning);color:var(--text-white)}.btn-cancel{background:var(--error);color:var(--text-white)}.btn-cancel:hover:not(:disabled){background:var(--error-dark);transform:translateY(-1px)}.btn-sm{padding:var(--padding-btn-sm);font-size:var(--font-size-xs)}.btn-lg{padding:var(--padding-btn-lg);font-size:var(--font-size-base-rem)}.btn-full{width:100%}.btn-icon{padding:var(--spacing-sm);min-width:36px;min-height:36px}.btn-icon.btn-sm{min-width:28px;min-height:28px;padding:var(--spacing-xs)}.btn-icon.btn-lg{min-width:44px;min-height:44px}.btn-social{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-social:hover:not(:disabled){background:var(--bg-light);border-color:var(--border-dark);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.btn-close{width:36px;height:36px;min-width:36px;min-height:36px;border:none;background:var(--bg-light);border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--transition-fast);padding:0}.btn-close:hover:not(:disabled){background:var(--error-bg);color:var(--error)}.btn-loading{cursor:wait;opacity:.8}.btn-spinner{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-group{display:flex;gap:var(--spacing-sm)}.btn-group.vertical{flex-direction:column}.btn-group.centered{justify-content:center}.btn-group.right{justify-content:flex-end}.btn-group.spread{justify-content:space-between}@media(max-width:768px){.btn-group{flex-wrap:wrap}.btn-group.spread{gap:var(--spacing-sm)}.btn-social{flex:1 1 100%}}.access-denied-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:400px;gap:1rem}.access-denied-icon{width:80px;height:80px;border-radius:50%;background:rgba(var(--color-danger-rgb, 239, 68, 68),.1);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--color-danger, #ef4444);margin-bottom:.5rem}.access-denied-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #1e293b);margin:0}.access-denied-desc{font-size:.95rem;color:var(--color-text-muted, #64748b);max-width:420px;margin:0;line-height:1.6}#root{width:100%;min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.read-the-docs{color:#888}
