:root{--navy:#16283c;--navy-2:#1f3650;--navy-deep:#0f1d2c;--gold:#c9a94e;--gold-deep:#8a6e2a;--gold-grad:linear-gradient(135deg, #e2c87d 0%, #c9a94e 55%, #ae8a38 100%);--navy-grad:linear-gradient(150deg, #24405e 0%, #16283c 60%, #0f1d2c 100%);--accent:var(--gold);--accent-strong:var(--gold-deep);--accent-hover:#b8983f;--accent-glow:#c9a94e29;--ink:var(--navy);--ink-hover:var(--navy-2);--backdrop:#e7eaee;--backdrop-grad:radial-gradient(900px 480px at 85% -10%, #c9a94e24, transparent 60%), radial-gradient(800px 500px at -10% 110%, #16283c1a, transparent 55%), linear-gradient(160deg, #ebedf1 0%, #e5e8ed 100%);--bg:var(--backdrop);--surface:#fff;--surface-2:#eef1f4;--surface-hover:#f5f7f9;--canvas:#f7f5f1;--canvas-dot:#16283c0e;--text-primary:#19242f;--text-secondary:#5d6876;--text-tertiary:#98a1ac;--text-inverse:#fff;--border:#e1e5ea;--border-light:#ebeef2;--panel-border:#16283c14;--bubble-in:#fff;--bubble-in-text:#19242f;--bubble-own:#1c3146;--bubble-own-text:#f2f5f8;--bubble-ai:#efe9fb;--bubble-ai-text:#2c2347;--bubble-system:#fbf5e3;--draft-accent:#7c5cc4;--draft-bg:#f5f0fd;--role-captain-bg:#e3eefa;--role-captain-text:#1d5a96;--role-provider-bg:#e4f3e8;--role-provider-text:#226b36;--role-reseller-bg:#eaeef3;--role-reseller-text:#2c3a4b;--role-endclient-bg:#f7efda;--role-endclient-text:#7a5e1e;--success:#1e9e50;--danger:#d43a3a;--danger-bg:#fcebeb;--warning:#b97612;--warning-bg:#fbf3df;--info:#2563eb;--info-bg:#e9f0fd;--status-open:#2dbe66;--status-idle:#e8a33d;--status-closed:#a6adb8;--unread-badge:var(--gold-grad);--unread-badge-text:#231b05;--receipt-read:#3b82f6;--shadow-sm:0 1px 2px #0f1d2c0f;--shadow-md:0 6px 18px #0f1d2c17;--shadow-lg:0 16px 44px #0f1d2c29;--shadow-panel:0 10px 34px #0f1d2c1a;--shadow-card:0 1px 3px #0f1d2c0d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:22px;--radius-panel:20px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.22s ease;--transition-smooth:.32s cubic-bezier(.4, 0, .2, 1);--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display:"Sora", "Inter", sans-serif;--ring:0 0 0 3px #c9a94e66;--logo-filter:none}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:16px}body{font-family:var(--font-body);background:var(--backdrop);color:var(--text-primary);height:100dvh;line-height:1.5;overflow:hidden}#app{background:var(--backdrop-grad);background-attachment:fixed;flex-direction:column;height:100dvh;display:flex;overflow:hidden}button{font-family:inherit}button:not(:disabled){cursor:pointer}:focus-visible{box-shadow:var(--ring);border-radius:var(--radius-sm);outline:none}::selection{background:var(--accent-glow)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);background-clip:padding-box;border:2px solid #0000;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary);background-clip:padding-box}.app-shell{min-height:0;padding:14px;padding-top:max(14px, env(safe-area-inset-top));padding-bottom:max(14px, env(safe-area-inset-bottom));flex:1;gap:14px;display:flex;overflow:hidden}.sidebar{background:var(--surface);border:1px solid var(--panel-border);border-radius:var(--radius-panel);width:380px;min-width:380px;box-shadow:var(--shadow-panel);flex-direction:column;height:100%;display:flex;overflow:hidden}.main-panel{background:var(--surface);border:1px solid var(--panel-border);border-radius:var(--radius-panel);height:100%;box-shadow:var(--shadow-panel);flex-direction:column;flex:1;display:flex;overflow:hidden}.app-bar{background:var(--surface);color:var(--text-primary);flex-shrink:0;align-items:center;gap:12px;min-height:58px;padding:14px 16px 10px;display:flex}.app-bar h1{font-family:var(--font-display);letter-spacing:-.01em;flex:1;font-size:16px;font-weight:700}.app-bar .logo{border-radius:var(--radius-md);object-fit:contain;background:var(--navy-grad);filter:brightness(0)invert();width:36px;height:36px;padding:5px}.app-bar-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-full);width:38px;height:38px;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.app-bar-btn:hover{background:var(--surface-2);color:var(--text-primary)}.app-bar-btn .material-icons-round{font-size:22px}.type-tabs{background:var(--surface-2);border-radius:var(--radius-md);flex-shrink:0;gap:4px;margin:4px 14px 0;padding:4px;display:flex}.type-tab{text-align:center;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 0;font-size:13px;font-weight:600;display:flex}.type-tab:hover{color:var(--text-primary)}.type-tab.active{color:var(--text-inverse);background:var(--navy-grad);box-shadow:var(--shadow-sm)}.status-tabs{flex-shrink:0;gap:6px;padding:12px 14px 4px;display:flex}.status-tab{text-align:center;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);background:0 0;border:1px solid #0000;padding:5px 14px;font-size:12px;font-weight:600}.status-tab:hover{background:var(--surface-2);color:var(--text-primary)}.status-tab.active{color:var(--accent-strong);background:var(--accent-glow)}.search-bar{background:var(--surface);flex-shrink:0;padding:10px 14px 8px}.search-input-wrapper{background:var(--surface-2);border-radius:var(--radius-full);transition:border-color var(--transition-fast), background var(--transition-fast);border:1px solid #0000;align-items:center;gap:8px;padding:9px 14px;display:flex}.search-input-wrapper:focus-within{border-color:var(--accent);background:var(--surface)}.search-input-wrapper .material-icons-round{color:var(--text-tertiary);font-size:19px}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13.5px}.search-input::placeholder{color:var(--text-tertiary)}.conversation-list{flex:1;padding:6px 10px 14px;overflow:hidden auto}.conversation-item{cursor:pointer;border-radius:var(--radius-lg);transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);border:1px solid #0000;align-items:flex-start;gap:12px;margin-bottom:2px;padding:12px;display:flex;position:relative}.conversation-item:hover{background:var(--surface-hover)}.conversation-item.active{background:var(--accent-glow);border-color:#c9a94e59}.conversation-item.active .conv-name{color:var(--accent-strong)}.conv-avatar{border-radius:var(--radius-full);width:48px;height:48px;font-family:var(--font-display);color:#f2f5f8;text-transform:uppercase;letter-spacing:.02em;box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.conv-avatar.helpdesk{background:var(--navy-grad)}.conv-avatar.charter{background:var(--gold-grad);color:#2a2105}.conv-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.conv-header{align-items:center;gap:8px;display:flex}.conv-name{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;flex:1;font-size:13.5px;font-weight:600;overflow:hidden}.conv-time{color:var(--text-tertiary);white-space:nowrap;flex-shrink:0;font-size:11px}.conv-preview{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:13px;display:flex;overflow:hidden}.conv-meta{align-items:center;gap:6px;margin-top:3px;display:flex}.status-dot{border-radius:var(--radius-full);flex-shrink:0;width:7px;height:7px}.status-dot.open{background:var(--status-open)}.status-dot.idle{background:var(--status-idle)}.status-dot.closed{background:var(--status-closed)}.member-key{letter-spacing:.03em;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent-strong);white-space:nowrap;vertical-align:1px;flex-shrink:0;padding:1px 7px;font-size:10.5px;font-weight:700;display:inline-block}.unread-badge{background:var(--gold-grad);color:var(--unread-badge-text);border-radius:var(--radius-full);text-align:center;min-width:20px;box-shadow:var(--shadow-sm);flex-shrink:0;padding:1px 7px;font-size:11px;font-weight:700}.chat-header{background:var(--surface);color:var(--text-primary);border-bottom:1px solid var(--border-light);flex-shrink:0;align-items:center;gap:12px;min-height:64px;padding:12px 18px;display:flex}.chat-avatar{border-radius:var(--radius-full);background:var(--navy-grad);color:#f2f5f8;width:40px;height:40px;font-family:var(--font-display);text-transform:uppercase;box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.chat-avatar:empty{display:none}.chat-avatar.charter{background:var(--gold-grad);color:#2a2105}.chat-header-info{flex:1;min-width:0}.chat-header-name{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;font-size:15px;font-weight:600;overflow:hidden}.chat-header-sub{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.chat-messages{background:radial-gradient(var(--canvas-dot) 1px, transparent 1.5px) 0 0 / 18px 18px, var(--canvas);flex-direction:column;flex:1;gap:8px;padding:20px 22px;display:flex;overflow-y:auto}.message-row{flex-direction:column;max-width:70%;animation:.18s msgFadeIn;display:flex;position:relative}@keyframes msgFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.message-row.reseller{align-self:flex-start}.message-row.agent{align-self:flex-end}.message-row.system{align-self:center;max-width:85%}.message-row.ai{align-self:flex-end}.message-row.with-avatar{padding-left:40px}.message-row.with-avatar:before{content:attr(data-initials);border-radius:var(--radius-full);background:var(--navy-grad);color:#f2f5f8;width:30px;height:30px;font-family:var(--font-display);text-transform:uppercase;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:10.5px;font-weight:700;display:flex;position:absolute;top:20px;left:0}.message-row.captain.with-avatar:before{background:var(--role-captain-text)}.message-row.provider.with-avatar:before{background:var(--role-provider-text)}.message-sender{color:var(--text-secondary);margin-bottom:3px;padding:0 10px;font-size:11px;font-weight:600}.message-row.agent .message-sender{color:var(--accent-strong);text-align:right}.message-bubble{border-radius:var(--radius-lg);word-break:break-word;white-space:pre-wrap;padding:9px 14px;font-size:14px;line-height:1.5;position:relative}.message-bubble a{color:inherit;text-underline-offset:2px;word-break:break-all;text-decoration:underline}.message-row.reseller .message-bubble{background:var(--bubble-in);color:var(--bubble-in-text);box-shadow:var(--shadow-sm);border-bottom-left-radius:6px}.message-row.agent .message-bubble{background:var(--bubble-own);color:var(--bubble-own-text);box-shadow:var(--shadow-sm);border-bottom-right-radius:6px}.message-row.system .message-bubble{background:var(--bubble-system);color:var(--text-primary);text-align:center;border-radius:var(--radius-md);font-size:12px}.message-row.ai .message-bubble{background:var(--bubble-ai);color:var(--bubble-ai-text);box-shadow:var(--shadow-sm);border-bottom-right-radius:6px}.message-row.ai .message-time{text-align:right}.message-row.ai.draft .message-bubble{border:1.5px dashed var(--draft-accent);background:var(--draft-bg);box-shadow:none}.draft-label{color:var(--draft-accent);justify-content:flex-end;align-items:center;gap:4px;margin-bottom:2px;padding:0 8px;font-size:11px;font-weight:600;display:flex}.draft-label .material-icons-round{font-size:14px}.draft-actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.draft-btn{border-radius:var(--radius-full);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);border:none;align-items:center;gap:4px;padding:7px 14px;font-size:12px;font-weight:600;display:inline-flex}.draft-btn .material-icons-round{font-size:16px}.draft-btn:hover{opacity:.85}.draft-btn:active{transform:scale(.97)}.draft-btn:disabled{opacity:.5;cursor:default}.draft-btn.approve{background:var(--draft-accent);color:#fff}.draft-btn.discard{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.app-bar-btn.ai-toggle.active{color:var(--accent-strong);background:var(--accent-glow)}.app-bar-btn.ai-toggle.unavailable{opacity:.35;cursor:not-allowed}.message-time{color:var(--text-tertiary);margin-top:3px;padding:0 10px;font-size:10.5px}.message-row.agent .message-time{text-align:right}.msg-receipt{vertical-align:middle;margin-left:4px;display:inline-flex}.msg-receipt .material-icons-round{font-size:14px;line-height:1}.msg-receipt.sent{color:var(--text-tertiary)}.msg-receipt.delivered{color:var(--text-secondary)}.msg-receipt.read{color:var(--receipt-read)}.msg-receipt.failed{color:var(--danger)}.chat-input-area{background:var(--surface);border-top:1px solid var(--border-light);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 14px;display:flex}.chat-input{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface-2);color:var(--text-primary);resize:none;max-height:120px;transition:border-color var(--transition-fast), background var(--transition-fast);outline:none;flex:1;padding:12px 18px;font-family:inherit;font-size:14px;line-height:1.4}.chat-input:focus{border-color:var(--accent);background:var(--surface)}.chat-input::placeholder{color:var(--text-tertiary)}.send-btn{border-radius:var(--radius-full);background:var(--surface-2);width:46px;height:46px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-btn.active{background:var(--gold-grad);color:#231b05;box-shadow:var(--shadow-md)}.send-btn.active:hover{filter:brightness(1.05)}.send-btn.sending{opacity:.6;pointer-events:none}.attach-btn{border-radius:var(--radius-full);width:46px;height:46px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.attach-btn:hover{background:var(--surface-2);color:var(--text-primary)}.attach-preview{background:var(--surface);border-top:1px solid var(--border-light);align-items:center;gap:10px;padding:10px 16px;display:flex}.attach-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:48px;height:48px}.attach-icon{color:var(--text-secondary);text-align:center;flex-shrink:0;width:48px;font-size:36px!important}.attach-meta{flex:1;min-width:0}.attach-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.attach-size{color:var(--text-secondary);margin-top:2px;font-size:11px}.attach-remove{border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.attach-remove:hover{background:var(--surface-2);color:var(--text-primary)}.message-bubble-wrap{max-width:100%;display:inline-block}.message-bubble-wrap[data-deletable="1"]{-webkit-touch-callout:none}.message-bubble.deleted{opacity:.65;align-items:center;gap:6px;font-style:italic;display:inline-flex}.message-bubble.deleted .deleted-icon{font-size:16px!important}.msg-menu{z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);flex-direction:column;min-width:200px;padding:4px;display:flex;position:fixed}.msg-menu-item{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);text-align:left;transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-size:14px;display:flex}.msg-menu-item:hover{background:var(--surface-2)}.msg-menu-item .material-icons-round{color:var(--text-secondary);font-size:18px}.message-bubble.has-media{padding:4px;overflow:hidden}.media-image-link{line-height:0;display:block}.media-image{border-radius:var(--radius-md);cursor:zoom-in;width:auto;max-width:320px;height:auto;max-height:320px;display:block}.media-video,.media-audio{border-radius:var(--radius-md);max-width:320px;display:block}.media-audio{width:280px}.media-file{border-radius:var(--radius-md);color:inherit;min-width:220px;max-width:320px;transition:background var(--transition-fast);background:#7f7f7f14;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;display:flex}.media-file:hover{background:#7f7f7f24}.message-row.agent .media-file{background:#ffffff1a}.message-row.agent .media-file:hover{background:#ffffff29}.media-file>.material-icons-round:first-child{flex-shrink:0;font-size:32px}.media-file-meta{flex:1;min-width:0}.media-file-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.media-file-type{opacity:.7;margin-top:2px;font-size:11px}.media-file-dl{opacity:.7;flex-shrink:0}.media-caption{white-space:pre-wrap;padding:6px 10px 4px;font-size:14px}.empty-state{color:var(--text-tertiary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;display:flex}.empty-state .material-icons-round{border-radius:var(--radius-full);background:var(--surface-2);width:92px;height:92px;color:var(--accent-strong);opacity:.9;justify-content:center;align-items:center;font-size:40px;display:flex}.empty-state p{font-size:14.5px}.login-page{background:var(--backdrop-grad);grid-template-columns:1.05fr 1fr;height:100dvh;display:grid}.login-hero{border-radius:var(--radius-panel);background:var(--navy-grad);box-shadow:var(--shadow-panel);align-items:flex-end;margin:16px 0 16px 16px;display:flex;position:relative;overflow:hidden}.login-hero-inner{z-index:1;color:#f2f5f8;padding:48px;position:relative}.login-hero-logo{object-fit:contain;filter:brightness(0)invert();opacity:.95;width:64px;height:64px;margin-bottom:22px}.login-hero-title{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:14px;font-size:clamp(28px,3.2vw,42px);font-weight:700;line-height:1.12}.login-hero-sub{color:#f2f5f8b8;max-width:380px;font-size:15px;line-height:1.6}.login-hero-wave{pointer-events:none;background:radial-gradient(circle at 88% 10%,#c9a94e66 0 2px,#0000 3px),radial-gradient(520px 520px at 110% -20%,#c9a94e38,#0000 60%),repeating-radial-gradient(circle at 110% -20%,#0000 0 64px,#c9a94e1a 64px 66px),radial-gradient(420px 420px at -10% 110%,#c9a94e1a,#0000 65%);position:absolute;inset:0}.login-side{justify-content:center;align-items:center;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--panel-border);border-radius:var(--radius-panel);width:100%;max-width:420px;box-shadow:var(--shadow-panel);text-align:center;padding:44px 40px;animation:.4s cardSlideUp}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-logo{background:var(--navy-grad);border-radius:var(--radius-lg);width:72px;height:72px;box-shadow:var(--shadow-md);justify-content:center;align-items:center;margin:0 auto 16px;padding:15px;display:flex}.login-logo img{filter:brightness(0)invert();width:100%}.login-title{font-family:var(--font-display);letter-spacing:-.015em;color:var(--text-primary);margin-bottom:4px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-secondary);margin-bottom:26px;font-size:13.5px}.form-group{text-align:left;margin-bottom:16px}.form-input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:12px 16px;font-family:inherit;font-size:14px}.form-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-tertiary)}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-md);margin-bottom:16px;padding:10px 14px;font-size:13px;display:none}.form-error.visible{display:block}.btn{border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition-fast);border:none;padding:13px;font-family:inherit;font-size:15px;font-weight:600}.btn-primary{background:var(--navy-grad);color:#f2f5f8}.btn-primary:hover:not(:disabled){filter:brightness(1.12);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-accent{background:var(--gold-grad);color:#231b05}.btn-accent:hover:not(:disabled){filter:brightness(1.05)}.btn-outline{color:var(--text-primary);border:1px solid var(--border);background:0 0}.btn-outline:hover{background:var(--surface-2)}.btn-danger-outline{color:var(--danger);border:1px solid var(--danger);opacity:.9;background:0 0}.btn-danger-outline:hover{background:var(--danger-bg);opacity:1}.settings-page{flex:1;width:100%;max-width:640px;margin:0 auto;padding:26px 24px;overflow-y:auto}.settings-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-bottom:14px;padding:20px}.settings-card h3{font-family:var(--font-display);color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:12px;font-weight:700}.settings-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-label{color:var(--text-secondary);font-size:13px}.settings-value{font-size:14px;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;opacity:0;visibility:hidden;transition:opacity var(--transition-normal), visibility var(--transition-normal);background:#080e1699;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1;visibility:visible}.modal{background:var(--surface);border:1px solid var(--panel-border);border-radius:var(--radius-panel);width:90%;max-width:400px;box-shadow:var(--shadow-lg);transition:transform var(--transition-smooth);padding:24px;transform:scale(.96)}.modal-overlay.visible .modal{transform:scale(1)}.modal h2{font-family:var(--font-display);text-align:center;margin-bottom:16px;font-size:18px;font-weight:600}.modal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-header h3{font-family:var(--font-display);font-size:17px;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-full);transition:background var(--transition-fast);background:0 0;border:none;align-items:center;padding:6px;display:flex}.modal-close:hover{background:var(--surface-2)}.modal-body{max-height:60vh;overflow-y:auto}.loading-spinner{color:var(--text-secondary);justify-content:center;align-items:center;gap:12px;padding:32px;font-size:14px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.charter-form{flex:1;width:100%;max-width:620px;margin:0 auto;padding:24px;overflow-y:auto}.charter-form h2{font-family:var(--font-display);margin-bottom:24px;font-size:20px;font-weight:700}.participant-list{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.participant-row{align-items:flex-end;gap:8px;display:flex}.participant-row .form-group{flex:1;margin-bottom:0}.remove-participant{background:var(--danger-bg);width:40px;height:40px;color:var(--danger);border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.remove-participant:hover{opacity:.8}.toast{bottom:max(24px, env(safe-area-inset-bottom));background:var(--navy-deep);color:#f2f5f8;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:2000;transition:transform var(--transition-smooth);white-space:nowrap;text-overflow:ellipsis;max-width:calc(100vw - 32px);padding:11px 22px;font-size:13.5px;font-weight:500;position:fixed;left:50%;overflow:hidden;transform:translate(-50%)translateY(100px)}.toast.visible{transform:translate(-50%)translateY(0)}.toast.error{background:var(--danger);color:#fff;border:none}.toast.success{background:var(--success);color:#fff;border:none}.fab{background:var(--gold-grad);color:#231b05;border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--transition-fast);z-index:10;border:none;align-items:center;gap:8px;padding:14px 20px;font-family:inherit;font-size:14px;font-weight:600;display:flex;position:absolute;bottom:20px;right:20px}.fab:hover{filter:brightness(1.05);box-shadow:var(--shadow-lg)}.date-separator{text-align:center;color:var(--text-secondary);padding:10px 0 4px;font-size:11px}.date-separator span{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);padding:3px 14px;font-weight:600}.user-info-bar{background:var(--surface);border-bottom:1px solid var(--border-light);flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.message-row.captain,.message-row.provider{align-self:flex-start}.message-row.captain .message-bubble{background:var(--role-captain-bg);color:var(--text-primary);box-shadow:var(--shadow-sm);border-bottom-left-radius:6px}.message-row.captain .message-sender{color:var(--role-captain-text)}.message-row.provider .message-bubble{background:var(--role-provider-bg);color:var(--text-primary);box-shadow:var(--shadow-sm);border-bottom-left-radius:6px}.message-row.provider .message-sender{color:var(--role-provider-text)}@media (width<=768px){.app-shell{gap:0;padding:0}.sidebar{width:100%;min-width:100%;box-shadow:none;border:none;border-radius:0}.main-panel{z-index:100;transition:transform var(--transition-smooth);box-shadow:none;border:none;border-radius:0;position:fixed;inset:0;transform:translate(100%)}.main-panel.open{transform:translate(0)}.message-row{max-width:85%}.app-bar{padding-top:max(14px, env(safe-area-inset-top))}.chat-header{padding-top:max(12px, env(safe-area-inset-top))}.chat-input-area{padding-bottom:max(12px, env(safe-area-inset-bottom))}.login-page{grid-template-columns:1fr}.login-hero{display:none}}.pm-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2000;opacity:0;visibility:hidden;transition:opacity var(--transition-normal), visibility var(--transition-normal);background:#080e1699;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pm-overlay.visible{opacity:1;visibility:visible}.pm-modal{background:var(--surface);border:1px solid var(--panel-border);border-radius:var(--radius-panel);width:92%;max-width:460px;max-height:86vh;box-shadow:var(--shadow-lg);transition:transform var(--transition-smooth);flex-direction:column;display:flex;overflow:hidden;transform:translateY(14px)scale(.98)}.pm-overlay.visible .pm-modal{transform:none}.pm-head{border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pm-head h2{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:8px;font-size:17px;font-weight:700;display:flex}.pm-head h2 .material-icons-round{color:var(--accent-strong);font-size:21px}.pm-icon-btn{border-radius:var(--radius-full);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.pm-icon-btn:hover{background:var(--surface-2)}.pm-icon-btn .material-icons-round{font-size:20px}.pm-body{flex-direction:column;flex:1;gap:20px;padding:16px 20px 20px;display:flex;overflow-y:auto}.pm-section{flex-direction:column;gap:10px;display:flex}.pm-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-size:11.5px;font-weight:700}.pm-list{flex-direction:column;gap:4px;display:flex}.pm-person{border-radius:var(--radius-md);transition:background var(--transition-fast);align-items:center;gap:11px;padding:8px;display:flex}.pm-person:hover{background:var(--surface-hover)}.pm-avatar{border-radius:var(--radius-full);width:38px;height:38px;font-family:var(--font-display);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.pm-avatar.reseller{background:var(--role-reseller-bg);color:var(--role-reseller-text)}.pm-avatar.provider{background:var(--role-provider-bg);color:var(--role-provider-text)}.pm-avatar.captain{background:var(--role-captain-bg);color:var(--role-captain-text)}.pm-avatar.endclient{background:var(--role-endclient-bg);color:var(--role-endclient-text)}.pm-person-info{flex:1;min-width:0}.pm-person-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.pm-person-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:5px;margin-top:2px;font-size:12px;display:flex}.pm-dot{opacity:.5}.pm-role-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-full);padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.pm-role-badge.reseller{background:var(--role-reseller-bg);color:var(--role-reseller-text)}.pm-role-badge.provider{background:var(--role-provider-bg);color:var(--role-provider-text)}.pm-role-badge.captain{background:var(--role-captain-bg);color:var(--role-captain-text)}.pm-role-badge.endclient{background:var(--role-endclient-bg);color:var(--role-endclient-text)}.pm-action{flex-shrink:0;align-items:center;gap:6px;display:flex}.pm-add,.pm-remove,.pm-confirm-yes,.pm-confirm-no{border-radius:var(--radius-full);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex}.pm-add,.pm-remove,.pm-confirm-no{background:0 0}.pm-add .material-icons-round,.pm-remove .material-icons-round,.pm-confirm-yes .material-icons-round,.pm-confirm-no .material-icons-round{font-size:19px}.pm-add{background:var(--accent-glow);color:var(--accent-strong)}.pm-add:hover{background:var(--accent);color:#231b05}.pm-remove{color:var(--text-secondary)}.pm-remove:hover{background:var(--danger-bg);color:var(--danger)}.pm-confirm-yes{background:var(--danger);color:#fff}.pm-confirm-yes:hover{opacity:.85}.pm-confirm-no{border:1px solid var(--border);color:var(--text-secondary)}.pm-confirm-no:hover{background:var(--surface-hover)}.pm-rolepick{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);padding:6px 11px;font-size:11.5px;font-weight:600}.pm-rolepick:hover{background:var(--accent);color:#231b05;border-color:var(--accent)}.pm-locked{color:var(--text-tertiary);padding:7px;display:flex}.pm-locked .material-icons-round{font-size:17px}.pm-added{color:var(--success);display:flex}.pm-added .material-icons-round{font-size:22px}.pm-search{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);height:42px;transition:border-color var(--transition-fast);align-items:center;gap:8px;padding:0 13px;display:flex}.pm-search:focus-within{border-color:var(--accent)}.pm-search .material-icons-round{color:var(--text-tertiary);font-size:20px}.pm-search input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.pm-search input::placeholder{color:var(--text-tertiary)}.pm-filters{flex-wrap:wrap;gap:7px;display:flex}.pm-chip{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 13px;font-size:12.5px;font-weight:600}.pm-chip:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.pm-chip.active{background:var(--navy-grad);color:#f2f5f8;border-color:#0000}.pm-empty{color:var(--text-tertiary);justify-content:center;align-items:center;padding:26px 16px;font-size:13px;display:flex}.pm-spin{border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);width:20px;height:20px;animation:.7s linear infinite pmspin}@keyframes pmspin{to{transform:rotate(360deg)}}@media (width<=768px){.pm-modal{border-radius:0;width:100%;max-width:100%;height:100%;max-height:100%}}.push-banner{border-radius:var(--radius-lg);background:var(--warning-bg);color:var(--warning);z-index:10;box-shadow:var(--shadow-md);border:1px solid #b9761240;align-items:center;gap:12px;margin:12px 14px 0;padding:10px 16px;font-size:13px;display:flex;position:relative}.push-banner-denied{background:var(--danger-bg);color:var(--danger);border-color:#d43a3a40}.push-banner-ios-install,.push-banner-unsupported{background:var(--info-bg);color:var(--info);border-color:#2563eb38}.push-banner-icon{flex-shrink:0;font-size:22px}.push-banner-text{flex-direction:column;flex:1;min-width:0;display:flex}.push-banner-text strong{font-size:13px;font-weight:600}.push-banner-text span{opacity:.85;font-size:12px}.push-banner-text em{font-style:normal;font-weight:600}.push-banner-btn{background:var(--surface);color:inherit;border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-fast);border:1px solid;flex-shrink:0;padding:6px 12px;font-size:12px;font-weight:600}.push-banner-btn.primary{background:var(--gold-grad);color:#231b05;border-color:#0000}.push-banner-btn:hover{opacity:.88}.push-banner-close{color:inherit;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:0;align-items:center;padding:4px;display:flex}.push-banner-close:hover{opacity:1}.push-banner-close .material-icons-round{font-size:18px}@media (width<=600px){.push-banner{gap:8px;margin:8px 8px 0;padding:8px 12px}.push-banner-text span{display:none}.push-banner-icon{font-size:20px}}.howto-list{margin:0;padding-left:20px}.howto-list li{margin-bottom:12px;font-size:14px;line-height:1.5}.howto-list code{background:var(--surface-2);border-radius:4px;padding:2px 6px;font-size:12px}.settings-link-row{border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;color:var(--text-primary);transition:background var(--transition-fast);background:0 0;border:0;align-items:center;gap:14px;padding:12px 14px;display:flex}.settings-link-row:hover{background:var(--surface-2)}.settings-link-row>.material-icons-round{color:var(--accent-strong)}.settings-link-text{flex-direction:column;flex:1;min-width:0;display:flex}.settings-link-text strong{font-size:14px;font-weight:600}.settings-link-text span{color:var(--text-secondary);font-size:12px}.push-admin-body{height:calc(100% - 64px);padding:14px;overflow-y:auto}.push-admin-summary{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.summary-chip{border-radius:var(--radius-full);background:var(--surface-2);align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:flex}.summary-chip .material-icons-round{font-size:16px}.summary-chip strong{font-size:13px;font-weight:700}.push-admin-section{margin-bottom:22px}.push-admin-section h4{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin:0 0 8px;padding:0 4px;font-size:12px}.push-admin-list{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.push-admin-row{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:10px 14px;display:flex}.push-admin-row:last-child{border-bottom:0}.push-admin-row-main{flex:1;min-width:0}.push-admin-row-name{font-size:14px;font-weight:500}.push-admin-row-sub{color:var(--text-secondary);font-size:11px}.push-admin-row-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.push-admin-row-platform{color:var(--text-secondary);font-size:11px}.push-admin-row-time{color:var(--text-tertiary);font-size:11px}.status-pill{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-pill .material-icons-round{font-size:14px}.st-granted{background:var(--role-provider-bg);color:var(--role-provider-text)}.st-denied{background:var(--danger-bg);color:var(--danger)}.st-default{background:var(--warning-bg);color:var(--warning)}.st-unsupported,.st-unknown{background:var(--surface-2);color:var(--text-secondary)}.summary-chip.st-granted{background:var(--role-provider-bg);color:var(--role-provider-text)}.summary-chip.st-denied{background:var(--danger-bg);color:var(--danger)}.summary-chip.st-default{background:var(--warning-bg);color:var(--warning)}.summary-chip.st-unsupported,.summary-chip.st-unknown{background:var(--surface-2);color:var(--text-secondary)}@media (width<=600px){.push-admin-row{flex-direction:column;align-items:stretch;gap:6px}.push-admin-row-meta{align-items:flex-start}}.message-row.own{align-self:flex-end;padding-left:0}.message-row.own:before{display:none}.message-row.own .message-sender{color:var(--accent-strong);text-align:right}.message-row.own .message-bubble{background:var(--bubble-own);color:var(--bubble-own-text);box-shadow:var(--shadow-sm);border-bottom-right-radius:6px;border-bottom-left-radius:var(--radius-lg)}.message-row.own .message-time{text-align:right}.message-row.own .media-file{background:#ffffff1a}.message-row.own .media-file:hover{background:#ffffff29}
