*{box-sizing:border-box}html{margin:0;padding:0;width:100%;min-height:100vh;background:var(--bg-primary)}body{margin:0;padding:0;width:100%;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}.confirm-modal-overlay{position:fixed;inset:0;background:var(--modal-overlay);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:10001;animation:confirm-fade-in .15s ease-out}.confirm-modal{background:var(--modal-bg);border-radius:12px;max-width:440px;width:100%;box-shadow:0 20px 40px #2d1a544d;animation:confirm-scale-in .2s ease-out;overflow:hidden}.confirm-modal-header{padding:1.25rem 1.5rem 0}.confirm-modal-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.confirm-modal-body{padding:.75rem 1.5rem 1.25rem}.confirm-modal-message{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0;white-space:pre-line}.confirm-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:0 1.5rem 1.25rem}.confirm-modal-btn{padding:.5rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;border:1px solid var(--border-color);transition:background-color .15s,border-color .15s,color .15s}.confirm-modal-btn-cancel{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-color)}.confirm-modal-btn-cancel:hover{background:var(--surface-hover)}.confirm-modal-btn-confirm{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.confirm-modal-btn-confirm:hover{opacity:.9}.confirm-modal-btn-confirm.confirm-danger{background:var(--danger);border-color:var(--danger)}.confirm-modal-btn-confirm.confirm-danger:hover{opacity:.9}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes confirm-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.confirm-modal{max-width:calc(100% - 2rem)}.confirm-modal-footer{flex-direction:column-reverse}.confirm-modal-btn{width:100%;text-align:center}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;max-width:420px;width:calc(100% - 2rem);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-radius:8px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-left:4px solid var(--border-color);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toast-slide-in .3s ease-out;transition:opacity .2s ease,transform .2s ease}.toast.toast-exiting{animation:toast-slide-out .25s ease-in forwards}.toast.toast-success{border-left-color:#22c55e}.toast.toast-error{border-left-color:#ef4444}.toast.toast-warning{border-left-color:#f59e0b}.toast.toast-info{border-left-color:#3b82f6}.toast-icon{flex-shrink:0;font-size:1.1rem;line-height:1.4}.toast-message{flex:1;font-size:.875rem;line-height:1.4;word-break:break-word}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem;line-height:1;padding:0;margin-left:auto;opacity:.6;transition:opacity .15s}.toast-close:hover{opacity:1;color:var(--text-primary)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media(max-width:480px){.toast-container{top:.5rem;right:.5rem;left:.5rem;max-width:none;width:auto}.toast{font-size:.8rem}}.product-tour-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none}.tour-backdrop{position:fixed;inset:0;background:#0f172a57;pointer-events:auto}.product-tour-overlay-desktop .tour-backdrop{background:#0f172a14;pointer-events:none}.tour-tooltip,.tour-mobile-header,.tour-mobile-footer{background:var(--bg-card, #ffffff);border:1px solid rgba(196,45,120,.16);box-shadow:0 18px 48px #0f172a2e}.tour-tooltip{position:fixed;top:1rem;right:1rem;width:min(420px,calc(100vw - 2rem));max-height:min(560px,calc(100vh - 2rem));border-radius:18px;pointer-events:auto;overflow:hidden;z-index:10001;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.product-tour-overlay-desktop .tour-tooltip{box-shadow:0 22px 54px #0f172a2e}.tour-content{padding:1.05rem 1.05rem .95rem;overflow-y:auto;flex:1 1 auto;min-height:0}.tour-tooltip .tour-content{display:flex;flex-direction:column;gap:.75rem}.tour-header,.tour-mobile-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.tour-header{margin-bottom:0;align-items:center}.tour-kicker{display:inline-block;margin-bottom:.25rem;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#c42d78}.tour-title{margin:0;font-size:1rem;font-weight:700;color:var(--brand-primary, #2d1a54)}.tour-tooltip .tour-title{font-size:1.05rem}.tour-close{width:2rem;height:2rem;border:none;border-radius:999px;background:var(--surface-muted, #f1f5f9);color:var(--text-secondary, #64748b);cursor:pointer;flex:0 0 auto}.tour-close:hover{background:var(--border-color, #e2e8f0)}.tour-text{margin:0;font-size:.9375rem;line-height:1.55;color:var(--text-secondary, #475569)}.tour-waiting,.tour-complete{margin:.875rem 0 0;padding:.625rem .75rem;border-radius:10px;font-size:.8125rem;font-weight:600}.tour-waiting{background:#fef3c7;color:#92400e}.tour-complete{background:#d1fae5;color:#065f46}.tour-footer,.tour-mobile-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem 1rem 1rem;border-top:1px solid var(--surface-muted, #f1f5f9);background:var(--bg-secondary, #fafafa);flex:0 0 auto}.tour-tooltip .tour-footer{gap:.9rem;padding:.95rem 1.05rem 1.05rem;flex-wrap:wrap}.tour-progress{font-size:.8125rem;font-weight:600;color:var(--text-muted, #94a3b8)}.tour-tooltip .tour-progress{display:inline-flex;align-items:center;padding:.42rem .72rem;border-radius:999px;background:#fff5fa;color:#7b5ba6}.tour-nav{display:flex;gap:.625rem}.tour-tooltip .tour-nav{margin-left:auto}.tour-btn{min-height:40px;padding:.625rem .95rem;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;appearance:none;-webkit-appearance:none;opacity:1}.tour-tooltip .tour-back,.tour-tooltip .tour-next{min-width:96px}.tour-back{background:var(--surface-muted, #f1f5f9);color:var(--text-secondary, #64748b)}.tour-back:hover:not(:disabled){background:var(--border-color, #e2e8f0)}.tour-next{background:#7b5ba6;color:#fff!important}.tour-next,.tour-next *{color:#fff!important}.tour-next:hover:not(:disabled){background:#2d1a54}.tour-footer .tour-back:not(:disabled){background:#eef2ff!important;color:#334155!important;-webkit-text-fill-color:#334155!important}.tour-footer .tour-next:not(:disabled){background:#2d1a54!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important;box-shadow:0 10px 22px #2d1a543d;opacity:1!important}.tour-btn:disabled{cursor:not-allowed;opacity:.5}body.tour-lock-active{overflow:hidden}.tour-target-active,.tour-target-secondary{position:relative;z-index:10000!important;border-radius:12px;isolation:isolate;pointer-events:auto}.product-tour-overlay-desktop~* .tour-target-active,.product-tour-overlay-desktop~* .tour-target-secondary{opacity:1!important}.tour-target-active,.tour-target-active *,.tour-target-secondary,.tour-target-secondary *{opacity:1!important;filter:none!important}.tour-target-active>*,.tour-target-secondary>*{position:relative;z-index:1}.tour-target-active{box-shadow:0 0 0 3px #c42d78,0 0 0 7px #c42d782e,0 12px 28px #c42d7829}.product-tour-overlay-desktop .tour-target-active{box-shadow:0 0 0 3px #c42d78,0 0 0 8px #c42d781f,0 18px 34px #2d1a541f}.tour-target-secondary{box-shadow:0 0 0 2px #c42d78bf,0 8px 22px #c42d781f}.tour-mobile-shell{position:fixed;inset:0;z-index:10001;pointer-events:none}.product-tour-overlay-request-mobile{background:transparent}body.tour-request-mobile-active .request .request-header,body.tour-request-mobile-active .request .request-form .form-row,body.tour-request-mobile-active .request .request-form .nearby-stores,body.tour-request-mobile-active .request .request-form .selected-store-summary,body.tour-request-mobile-active .request .request-form .add-item-controls,body.tour-request-mobile-active .request .request-form .tour-photo-required,body.tour-request-mobile-active .request .request-form .mobile-photo-upload,body.tour-request-mobile-active .request .request-form .cart-photo-upload-btn,body.tour-request-mobile-active .request .request-form .form-actions,body.tour-request-mobile-active .request .request-form .items-table{opacity:.32;filter:grayscale(.08);pointer-events:none;transition:opacity .18s ease,filter .18s ease}body.tour-request-mobile-active .request .tour-request-mobile-focus,body.tour-request-mobile-active .request .tour-request-mobile-focus-secondary{opacity:1!important;filter:none!important;pointer-events:auto!important}body.tour-request-mobile-active .request .tour-target-active{z-index:5!important}body.tour-request-mobile-active .request .tour-target-secondary{z-index:6!important}body.tour-request-mobile-active .request .tour-request-mobile-focus{position:relative;z-index:5!important}body.tour-request-mobile-active .request .tour-request-mobile-focus-secondary{position:relative;z-index:6!important}.tour-request-inline-card{margin-top:.85rem;padding:.95rem;border-radius:18px;background:#fffffffa;border:1px solid rgba(196,45,120,.18);box-shadow:0 16px 34px #0f172a24;pointer-events:auto;position:relative;z-index:6}.tour-request-inline-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.tour-request-inline-bottom{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.9rem}.tour-end-chip{border:1px solid rgba(196,45,120,.18);background:#fff5fa;padding:.5rem .75rem;border-radius:999px;font-size:.8125rem;font-weight:600;color:#7b5ba6;cursor:pointer;white-space:nowrap}.tour-mobile-header,.tour-mobile-footer{position:fixed;left:.75rem;right:.75rem;border-radius:18px;pointer-events:auto}.tour-mobile-header{top:calc(env(safe-area-inset-top,0px) + .5rem);padding:.95rem;max-height:min(28vh,220px);overflow-y:auto}.tour-mobile-footer{bottom:calc(env(safe-area-inset-bottom,0px) + .75rem)}@media(max-width:1024px)and (min-width:769px){.tour-tooltip{width:min(380px,calc(100vw - 1.5rem));max-height:min(72vh,560px)}.tour-tooltip .tour-footer{align-items:stretch}.tour-tooltip .tour-progress{align-self:flex-start}.tour-tooltip .tour-nav{width:100%;justify-content:flex-end}}@media(max-width:768px){.tour-backdrop{background:transparent}.tour-request-inline-card{margin-top:.75rem;padding:.9rem}.tour-request-inline-top .tour-title,.tour-mobile-header .tour-title{font-size:.95rem}.tour-request-inline-top .tour-kicker,.tour-mobile-header .tour-kicker{font-size:.6875rem;margin-bottom:.125rem}.tour-request-inline-card .tour-text,.tour-mobile-header .tour-text{font-size:.875rem;line-height:1.45;margin-top:.625rem}.tour-mobile-header .tour-waiting,.tour-mobile-header .tour-complete{margin-top:.625rem;padding:.55rem .65rem;font-size:.75rem}.tour-mobile-footer{padding:.75rem .9rem .9rem}.tour-request-inline-bottom{flex-wrap:wrap}.tour-request-inline-bottom .tour-progress{order:1;width:100%}.tour-request-inline-bottom .tour-nav{order:2;width:100%;justify-content:space-between}.tour-request-inline-bottom .tour-back,.tour-request-inline-bottom .tour-next,.tour-mobile-footer .tour-back,.tour-mobile-footer .tour-next{flex:1 1 0}.tour-request-inline-bottom .tour-back:not(:disabled){background:#eef2ff!important;color:#334155!important;-webkit-text-fill-color:#334155!important}.tour-request-inline-bottom .tour-next:not(:disabled){background:#2d1a54!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important;box-shadow:0 10px 22px #2d1a543d;opacity:1!important}.tour-request-inline-bottom .tour-next:disabled{opacity:.45!important}.tour-mobile-footer .tour-nav{margin-left:auto}.tour-mobile-footer .tour-back,.tour-mobile-footer .tour-next{min-width:88px;opacity:1!important}.tour-mobile-footer .tour-back:not(:disabled){background:#eef2ff!important;color:#334155!important;-webkit-text-fill-color:#334155!important}.tour-mobile-footer .tour-next:not(:disabled){background:#2d1a54!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important;box-shadow:none}}.viewas-banner{background:var(--warning-bg, #fff3cd);color:var(--warning-text, #856404);border-bottom:2px solid var(--warning-border, #ffc107);padding:6px 16px;display:flex;align-items:center;gap:8px;font-size:13px;z-index:10000}.viewas-exit{margin-left:auto;background:var(--warning-text, #856404);color:#fff;border:none;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer}.viewas-exit:hover{opacity:.85}.viewas-trigger-wrap{position:relative;display:inline-flex;margin-left:.5rem}.viewas-trigger{width:34px;height:34px;border-radius:50%;background:#ffffff1f;color:#fff;border:1.5px solid rgba(255,255,255,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.viewas-trigger:hover{background:#ffffff40;border-color:#ffffff80}.viewas-backdrop{position:fixed;inset:0;z-index:9998}.viewas-picker{position:absolute;top:100%;left:0;right:auto;margin-top:8px;background:var(--bg-card, white);border:1px solid var(--border-color, #ddd);border-radius:10px;box-shadow:0 8px 24px #00000026;padding:14px;z-index:9999;min-width:240px;max-width:min(300px,calc(100vw - 16px))}.viewas-picker-title{font-weight:700;font-size:13px;margin-bottom:12px;color:var(--text-primary, #333);display:flex;align-items:center;gap:8px}.viewas-back{background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-secondary, #888);padding:0 4px;line-height:1}.viewas-back:hover{color:var(--text-primary, #333)}.viewas-list{display:flex;flex-direction:column;gap:4px}.viewas-org-list{max-height:300px;overflow-y:auto}.viewas-btn{background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:6px;padding:8px 12px;font-size:13px;cursor:pointer;color:var(--text-primary, #555);text-align:left;transition:all .15s;display:flex;align-items:center;gap:8px}.viewas-btn:hover{background:var(--primary-color, #6c5ce7);color:#fff;border-color:var(--primary-color, #6c5ce7)}.viewas-btn-icon{font-size:15px;flex-shrink:0}.viewas-org-btn{font-size:12px;padding:6px 10px}.viewas-empty{font-size:12px;color:var(--text-secondary, #999);text-align:center;padding:12px}@media(max-width:768px){.viewas-picker{position:fixed;inset:auto 8px 8px;width:auto;max-width:none;border-radius:12px;padding:16px}.viewas-org-list{max-height:50vh}}.error-boundary-overlay{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;background:var(--bg-primary, #f5f5f5)}.error-boundary-card{background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:12px;box-shadow:var(--shadow, 0 2px 12px rgba(0, 0, 0, .08));padding:2.5rem 2rem;max-width:420px;width:100%;text-align:center}.error-boundary-logo{width:160px;height:auto;margin-bottom:1.5rem}.error-boundary-heading{font-size:1.375rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin:0 0 .75rem}.error-boundary-message{font-size:.925rem;line-height:1.5;color:var(--text-muted, #6b7280);margin:0 0 2rem}.error-boundary-actions{display:flex;flex-direction:column;align-items:center;gap:.875rem}.error-boundary-refresh{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.5rem;font-size:.925rem;font-weight:500;color:#fff;background:var(--brand-primary, #2563eb);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s ease;width:100%;max-width:200px}.error-boundary-refresh:hover{opacity:.88}.error-boundary-dashboard{font-size:.875rem;color:var(--brand-primary, #2563eb);text-decoration:none;cursor:pointer}.error-boundary-dashboard:hover{text-decoration:underline}@media(max-width:480px){.error-boundary-card{padding:2rem 1.25rem}.error-boundary-logo{width:130px}.error-boundary-heading{font-size:1.25rem}}.announcement-bar-container{z-index:50}.announcement-bar{background:var(--accent-color, #2563eb);color:#fff;font-size:13px;border-bottom:1px solid rgba(255,255,255,.15)}.announcement-bar-content{display:flex;align-items:center;gap:8px;padding:6px 16px;cursor:pointer;min-height:32px;-webkit-user-select:none;user-select:none}.announcement-bar-content:hover{background:#ffffff14}.announcement-bar-icon{font-size:14px;flex-shrink:0}.announcement-bar-title{white-space:nowrap;flex-shrink:0}.announcement-bar-preview{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.85;flex:1;min-width:0}.announcement-bar-expand{flex-shrink:0;font-size:10px;opacity:.6;margin-left:auto}.announcement-bar-expanded{padding:8px 16px 12px 40px;font-size:13px;line-height:1.5;border-top:1px solid rgba(255,255,255,.15);background:#0000001a}.announcement-bar-expanded a{color:inherit;text-decoration:underline}.announcement-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.announcement-popup{background:var(--modal-bg, #fff);border-radius:12px;max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.announcement-popup-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--surface-border, #e5e7eb)}.announcement-popup-header h3{flex:1;margin:0;font-size:1.1rem;color:var(--text-primary, #111)}.announcement-popup-icon{font-size:20px}.announcement-popup-close{background:var(--surface-muted, #f3f4f6);border:none;font-size:16px;cursor:pointer;padding:6px 10px;border-radius:6px;color:var(--text-secondary, #666);line-height:1}.announcement-popup-close:hover{background:var(--surface-border, #e5e7eb)}.announcement-popup-body{padding:20px;font-size:14px;line-height:1.6;color:var(--text-primary, #333);overflow-y:auto;flex:1}.announcement-popup-body a{color:var(--accent-color, #2563eb);text-decoration:underline}.announcement-popup-footer{padding:12px 20px;border-top:1px solid var(--surface-border, #e5e7eb);display:flex;justify-content:flex-end}.announcement-popup-btn{background:var(--accent-color, #2563eb);color:#fff;border:none;padding:8px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.announcement-popup-btn:hover{opacity:.9}@media(max-width:768px){.announcement-bar-content{padding:6px 12px}.announcement-bar-preview{display:none}.announcement-bar-expanded{padding:8px 12px 12px}.announcement-popup-overlay{padding:0;align-items:flex-end}.announcement-popup{max-width:100%;max-height:85vh;border-radius:16px 16px 0 0}.announcement-popup-btn{width:100%;padding:12px}}:root,[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f7fc;--bg-tertiary: #f0edf5;--bg-card: #ffffff;--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e5ef;--brand-primary: #2D1A54;--brand-secondary: #7B5BA6;--brand-accent: #C42D78;--brand-orange: #FFA600;--header-bg: #2D1A54;--header-bg-light: #3D2A6E;--header-text: #ffffff;--input-bg: #ffffff;--input-border: #d1d5db;--shadow: 0 1px 3px rgba(0,0,0,.1);--shadow-lg: 0 4px 20px rgba(0,0,0,.15);--table-stripe: #f8f7fc;--table-header-bg: #f8fafc;--hover-bg: #f3f0ff;--success: #10b981;--success-bg: #d1fae5;--success-text: #065f46;--warning: #f59e0b;--warning-bg: #fef3c7;--warning-text: #92400e;--danger: #ef4444;--danger-bg: #fee2e2;--danger-text: #991b1b;--skeleton-bg: #e5e5ef;--skeleton-shine: #f0edf5;--surface-hover: #f8fafc;--surface-muted: #f1f5f9;--surface-border: #e2e8f0;--footer-bg: #f1f5f9;--footer-text: #64748b;--footer-border: #e2e8f0;--modal-overlay: rgba(45, 26, 84, .6);--modal-bg: #ffffff;--code-bg: #f0f0f0;--pagination-bg: #fafafa}[data-theme=dark]{--bg-primary: #0f0a1e;--bg-secondary: #1a1333;--bg-tertiary: #251d42;--bg-card: #1a1333;--text-primary: #e8e2f4;--text-secondary: #a89cc4;--text-muted: #7b6f99;--border-color: #332a52;--brand-primary: #9b7cd4;--brand-secondary: #b49ae0;--brand-accent: #e84f9a;--brand-orange: #FFB830;--header-bg: #150f2a;--header-bg-light: #1e1639;--header-text: #e8e2f4;--input-bg: #1a1333;--input-border: #332a52;--shadow: 0 1px 3px rgba(0,0,0,.4);--shadow-lg: 0 4px 20px rgba(0,0,0,.4);--table-stripe: #1f1838;--table-header-bg: #1a1333;--hover-bg: #251d42;--success: #34d399;--success-bg: #064e3b;--success-text: #6ee7b7;--warning: #fbbf24;--warning-bg: #78350f;--warning-text: #fde68a;--danger: #f87171;--danger-bg: #7f1d1d;--danger-text: #fca5a5;--skeleton-bg: #251d42;--skeleton-shine: #332a52;--surface-hover: #251d42;--surface-muted: #1f1838;--surface-border: #332a52;--footer-bg: #150f2a;--footer-text: #7b6f99;--footer-border: #332a52;--modal-overlay: rgba(0, 0, 0, .7);--modal-bg: #1a1333;--code-bg: #251d42;--pagination-bg: #1a1333}:root,[data-theme=light]{--primary: #2D1A54;--primary-light: #3D2A6E;--primary-dark: #1E0F3D;--accent-pink: #C42D78;--accent-purple: #7B5BA6;--accent-orange: #F5A623;--text-dark: #1E1E2F;--bg-light: #F8F7FC;--bg-white: #FFFFFF;--border: #E5E5EF;--bg-primary: #ffffff;--bg-secondary: #f8f7fc;--bg-card: #ffffff;--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e5ef;--surface-border: #e2e8f0;--surface-hover: #f3f0ff;--surface-muted: #f1f5f9;--brand-primary: #2D1A54;--brand-secondary: #7B5BA6;--header-bg: #2D1A54;--header-bg-light: #3D2A6E;--header-text: #ffffff;--input-bg: #ffffff;--input-border: #d1d5db;--shadow: 0 1px 3px rgba(0,0,0,.1);--shadow-lg: 0 4px 12px rgba(0,0,0,.15);--table-stripe: #f8f7fc;--table-header-bg: #f8f7fc;--hover-bg: #f3f0ff;--modal-bg: #ffffff;--modal-overlay: rgba(0,0,0,.5);--pagination-bg: #f8f7fc;--footer-bg: #f8f7fc;--footer-border: #e5e5ef;--footer-text: #6b7280;--skeleton-bg: #e2e8f0;--skeleton-shine: #f1f5f9;--danger: #ef4444;--danger-bg: #fef2f2;--row-selected-bg: #fce7f3;--row-selected-hover: #fbcfe8}[data-theme=dark]{--primary: #9b7cd4;--primary-light: #b49ae0;--primary-dark: #150f2a;--accent-pink: #e84f9a;--accent-purple: #b49ae0;--accent-orange: #FFB830;--text-dark: #e8e2f4;--bg-light: #1a1333;--bg-white: #0f0a1e;--border: #332a52;--bg-primary: #0f0a1e;--bg-secondary: #1a1333;--bg-card: #1a1333;--text-primary: #e8e2f4;--text-secondary: #a89cc4;--text-muted: #7b6f99;--border-color: #332a52;--surface-border: #332a52;--surface-hover: #251d42;--surface-muted: #1f1838;--brand-primary: #9b7cd4;--brand-secondary: #b49ae0;--header-bg: #150f2a;--header-bg-light: #1a1333;--header-text: #e8e2f4;--input-bg: #1a1333;--input-border: #332a52;--shadow: 0 1px 3px rgba(0,0,0,.4);--shadow-lg: 0 4px 12px rgba(0,0,0,.5);--table-stripe: #1f1838;--table-header-bg: #1a1333;--hover-bg: #251d42;--modal-bg: #1a1333;--modal-overlay: rgba(0,0,0,.7);--pagination-bg: #1a1333;--footer-bg: #150f2a;--footer-border: #332a52;--footer-text: #7b6f99;--skeleton-bg: #251d42;--skeleton-shine: #332a52;--danger: #f87171;--danger-bg: #3b1111;--row-selected-bg: #2d1a3d;--row-selected-hover: #3a2350;--season-gradient: linear-gradient(135deg, #1f1838, #251d42);--season-border: #4c3a7a;--info-gradient: linear-gradient(135deg, #1a1333, #1f1838);--info-border: #332a52;--info-heading: #7dd3fc;--info-text: #a89cc4;--success-text: #34d399;--warning-text: #fbbf24;--toggle-off: #4c3a7a;--toggle-on: #9b7cd4;--flagged-bg: #3b1111;--flagged-bg-hover: #4a1515}.app{display:flex;flex-direction:column;min-height:100vh;width:100%;background:var(--bg-primary)}.header{background:linear-gradient(135deg,var(--header-bg) 0%,var(--header-bg-light) 100%);color:var(--header-text);padding:.875rem 1.5rem;padding-top:calc(.875rem + env(safe-area-inset-top,0px));box-shadow:var(--shadow);width:100%;position:sticky;top:0;z-index:100}.header-sides{position:relative;min-height:72px}.header-side{position:absolute;top:0;display:flex;align-items:flex-start;gap:.5rem;z-index:2}.header-side-left{left:0}.header-side-right{right:0}.header-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.6rem;width:100%}.header-row-1,.header-left-group{display:contents}.logo{z-index:1;display:flex;justify-content:center}.help-nav-wrapper{position:relative;display:flex;align-items:center}.nav .help-nav-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;cursor:pointer;font-family:inherit;outline:none;margin:0}.nav .help-nav-link:focus{outline:none}.help-dropdown-backdrop{position:fixed;inset:0;z-index:99}.help-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-lg);min-width:240px;z-index:100;overflow:hidden}.help-dropdown-portal{position:fixed;z-index:10001}@media(max-width:768px){.help-dropdown{position:fixed;bottom:auto;left:1rem;right:1rem;transform:none;min-width:auto;top:140px}.help-dropdown-portal{transform:none!important;min-width:auto}}.help-dropdown-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;cursor:pointer;transition:background .15s}.help-dropdown-item:hover{background:var(--surface-hover)}.help-dropdown-icon{font-size:1.25rem;line-height:1}.help-dropdown-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.help-dropdown-desc{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.notification-bell{margin-left:0}.logo-full{height:32px;width:auto}.logo-icon{height:28px;width:auto;display:none}.nav{display:flex;align-items:center;justify-content:center;gap:.5rem}.nav a,.nav .help-nav-link{color:#ffffffd9;text-decoration:none;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.9375rem;transition:all .2s;line-height:1.5;display:flex;align-items:center}.nav a:hover,.nav .help-nav-link:hover{background:#ffffff1a;color:#fff}.nav .help-nav-link.disabled,.nav .help-nav-link:disabled{opacity:.55;cursor:not-allowed;background:transparent;color:#ffffffbf}.nav .help-nav-link.disabled:hover,.nav .help-nav-link:disabled:hover{background:transparent;color:#ffffffbf}.nav a.active{background:#fff3;color:#fff}.theme-toggle-btn{width:34px;height:34px;border-radius:50%;background:#ffffff1f;color:#fff;border:1.5px solid rgba(255,255,255,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;margin-left:.5rem}.theme-toggle-btn:hover{background:#ffffff40;border-color:#ffffff80}.user-menu{position:relative;margin-left:.5rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.user-avatar:hover{background:#ffffff4d;border-color:#fff9}.user-menu-backdrop{position:fixed;inset:0;z-index:99}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-lg);min-width:200px;z-index:100;overflow:hidden}.user-dropdown-header{padding:1rem;border-bottom:1px solid var(--border-color)}.user-dropdown-name{font-weight:600;color:var(--text-primary);font-size:.9375rem}.user-dropdown-email{font-size:.8125rem;color:var(--text-muted);margin-top:.25rem}.user-dropdown-meta{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.user-dropdown-role{text-transform:capitalize}.user-dropdown-divider{height:1px;background:var(--border-color);margin:0}.user-dropdown-item{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:background .15s}.user-dropdown-item:hover{background:var(--hover-bg)}.user-dropdown-signout{color:var(--danger)}.user-dropdown-signout:hover{background:var(--danger-bg)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--brand-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{margin-top:1rem;color:var(--text-muted)}.main{flex:1;padding:1.5rem 2rem;max-width:1600px;margin:0 auto;width:100%;background:var(--bg-secondary)}.footer{background:var(--footer-bg);color:var(--footer-text);text-align:center;padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));font-size:.8125rem;width:100%;border-top:1px solid var(--footer-border);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.footer-link{color:var(--brand-secondary);text-decoration:underline;transition:color .15s}.footer-link:hover{color:var(--brand-primary)}.footer-divider{color:var(--text-muted)}button{padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}button.primary{background:var(--brand-primary);color:#fff}button.primary:hover{background:var(--brand-secondary)}button.primary:disabled{background:#94a3b8;cursor:not-allowed}button:not(.primary){background:var(--surface-muted);color:var(--text-primary)}button:not(.primary):hover{background:var(--surface-border)}input,select,textarea{padding:.625rem .875rem;border:1px solid var(--input-border);border-radius:8px;font-size:.9375rem;width:100%;background:var(--input-bg);color:var(--text-primary)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-secondary);box-shadow:0 0 0 3px #7b5ba626}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.error{background:var(--danger-bg);color:var(--danger);padding:1rem;border-radius:8px;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:var(--modal-overlay);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100}.modal{background:var(--modal-bg);padding:0;border-radius:12px;max-width:500px;width:100%;box-shadow:0 20px 40px #2d1a544d}@media(max-width:768px){.header{padding:.85rem 1rem .35rem}.header-sides{min-height:96px}.header-side{top:.15rem;gap:.4rem}.header-center{min-height:96px;justify-content:flex-start;gap:.2rem}.nav.header-row-2{margin-top:auto;transform:translateY(-4px)}.logo-full{display:block;height:32px}.logo-icon{display:none}.nav.header-row-2{width:100%;display:flex;flex-wrap:nowrap;justify-content:center;gap:.45rem;overflow-x:auto;overflow-y:hidden;padding:.05rem 3.75rem .1rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}.nav.header-row-2::-webkit-scrollbar{display:none}.nav.header-row-2 a,.nav.header-row-2 .help-nav-link{width:auto;flex:0 0 auto;justify-content:center;padding:.48rem .8rem;font-size:.8125rem;min-height:36px;text-align:center;white-space:nowrap;border-radius:999px;background:#ffffff14}.nav.header-row-2 a.active{background:#ffffff2e}.help-nav-wrapper{width:auto;flex:0 0 auto}.notification-btn,.viewas-trigger,.theme-toggle-btn,.user-avatar{width:34px;height:34px}.notification-btn{padding:.375rem;border-radius:8px}.notification-btn svg,.viewas-trigger svg{width:16px;height:16px}.notification-dropdown{right:auto;left:0;width:min(360px,calc(100vw - 1rem))}.user-dropdown{right:0;left:auto;width:min(280px,calc(100vw - 1rem));max-width:calc(100vw - 1rem)}.main{padding:.9rem}.mobile-full-width{width:100%;padding:.75rem 1rem}.modal{margin:1rem;max-height:90vh;overflow-y:auto}}@media(max-width:480px){.logo img{height:24px}.header{padding:.75rem .75rem .3rem}.header-sides{min-height:88px}.header-side{gap:.35rem}.header-center{min-height:88px;gap:.15rem}.nav.header-row-2{padding-left:3.35rem;padding-right:3.35rem;transform:translateY(-3px)}.nav.header-row-2 a,.nav.header-row-2 .help-nav-link{padding:.44rem .72rem;font-size:.78rem;min-height:34px}.main{padding:.7rem}}@media(max-width:768px){.user-menu{margin-left:0;position:relative}.theme-toggle-btn{margin-left:0;margin-right:.25rem}.logo{order:0}.notification-bell{margin-left:0;order:0}}.notification-bell{position:relative}.notification-btn{background:#fff3;border:none;padding:.5rem;margin:0;cursor:pointer;position:relative;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s;color:#fff}.notification-btn:hover{background:#ffffff4d}.notification-btn svg{display:block}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:.625rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notification-backdrop{position:fixed;inset:0;z-index:99}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;display:flex;flex-direction:column}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid var(--surface-border);font-weight:600;color:var(--brand-primary)}.mark-all-read{background:none;border:none;color:var(--brand-secondary);font-size:.75rem;cursor:pointer;font-weight:500}.mark-all-read:hover{text-decoration:underline}.notification-list{overflow-y:auto;flex:1}.notification-empty{padding:2rem;text-align:center;color:var(--text-muted);font-size:.875rem}.notification-item{padding:.875rem 1rem;border-bottom:1px solid var(--surface-border);cursor:pointer;transition:background .15s}.notification-item:hover{background:var(--surface-hover)}.notification-item.unread{background:var(--hover-bg);border-left:3px solid var(--brand-secondary)}.notification-item.unread:hover{background:var(--surface-hover)}.notification-message{font-size:.8125rem;color:var(--text-primary);line-height:1.4;margin-bottom:.375rem}.notification-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.notification-order{font-weight:500;color:var(--brand-secondary)}.notification-footer{border-top:1px solid var(--border-color);padding:.5rem}.notification-view-all{width:100%;padding:.5rem;background:none;border:none;color:var(--brand-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;border-radius:6px;transition:background .15s}.notification-view-all:hover{background:var(--bg-secondary)}.email-verify-gate{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary);padding:2rem}.verify-gate-card{background:var(--bg-card);border-radius:16px;padding:3rem;max-width:440px;width:100%;text-align:center;box-shadow:0 4px 24px #00000014}.verify-gate-icon{font-size:3rem;margin-bottom:1rem}.verify-gate-card h2{font-size:1.4rem;color:var(--text-primary);margin:0 0 .75rem}.verify-gate-card p{color:var(--text-secondary);font-size:.925rem;line-height:1.6;margin:0 0 .5rem}.verify-gate-spam{color:#8e8ea0!important;font-size:.825rem!important;margin-bottom:1.5rem!important}.verify-gate-actions{margin-bottom:1.25rem}.btn-resend{background:#220b60;color:#fff;border:none;padding:.7rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-resend:hover{background:#3b2570}.btn-resend:disabled{opacity:.6;cursor:not-allowed}.verify-sent{font-weight:600;color:#065f46;font-size:.9rem}.verify-error{font-weight:600;color:#dc2626;font-size:.9rem}.verify-gate-logout{background:none;border:none;color:#8e8ea0;font-size:.825rem;cursor:pointer;text-decoration:underline;padding:0}.verify-gate-logout:hover{color:#5a5a72}.verified-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#d1fae5;color:#065f46;padding:12px 24px;border-radius:8px;font-size:.875rem;font-weight:600;box-shadow:0 4px 12px #00000026;z-index:10000;animation:toastFadeIn .3s ease}@keyframes toastFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.idle-warning-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100000;animation:fadeIn .2s ease}.idle-warning-modal{background:var(--modal-bg, #fff);border-radius:12px;padding:2rem;max-width:400px;width:90%;text-align:center;box-shadow:0 8px 32px #0000004d}.idle-warning-icon{font-size:2.5rem;margin-bottom:.5rem}.idle-warning-modal h3{color:var(--text-primary);margin:0 0 .75rem;font-size:1.25rem}.idle-warning-modal p{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.idle-warning-btn{background:var(--brand-primary, #2D1A54);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.idle-warning-btn:hover{opacity:.9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
