:root,[data-theme=light]{--bg: #f0f2f5;--bg-gradient: linear-gradient(180deg, #f7fafd 0%, #eef2f7 100%);--surface: #ffffff;--surface-2: #f7f9fa;--surface-glass: rgba(255, 255, 255, .72);--surface-border: rgba(0, 0, 0, .06);--text: #0f172a;--text-strong: #000000;--muted: #64748b;--primary: #0b93f6;--primary-contrast: #ffffff;--primary-shadow: 0 8px 24px rgba(11, 147, 246, .35);--border: #e5e7eb;--bubble-mine: #d9fdd3;--bubble-theirs: #ffffff;--bubble-mine-text: #0f172a;--bubble-theirs-text: #0f172a;--danger: #e53935;--read-tick: #53bdeb;--focus: rgba(11, 147, 246, .35);--blur: blur(20px);--radius-md: 12px;--radius-lg: 16px;--shadow-soft: 0 6px 24px rgba(0, 0, 0, .08);--shadow-hard: 0 12px 40px rgba(0, 0, 0, .15);--transition: .2s cubic-bezier(.4, 0, .2, 1);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}[data-theme=dark]{--bg: #0b141a;--bg-gradient: linear-gradient(180deg, #0b141a 0%, #111b21 100%);--surface: #111b21;--surface-2: #1f2c34;--surface-glass: rgba(31, 44, 52, .72);--surface-border: rgba(255, 255, 255, .06);--text: #e9edef;--text-strong: #ffffff;--muted: #8696a0;--primary: #00a884;--primary-contrast: #ffffff;--primary-shadow: 0 8px 24px rgba(0, 168, 132, .35);--border: #222d34;--bubble-mine: #005c4b;--bubble-theirs: #1f2c34;--bubble-mine-text: #e9edef;--bubble-theirs-text: #e9edef;--shadow-soft: 0 6px 24px rgba(0, 0, 0, .4);--shadow-hard: 0 12px 40px rgba(0, 0, 0, .6)}[data-theme=contrast]{--bg: #000000;--bg-gradient: #000000;--surface: #0a0a0a;--surface-2: #141414;--surface-glass: #0a0a0a;--surface-border: #ffffff;--text: #ffffff;--text-strong: #ffee00;--muted: #f0f0f0;--primary: #ffee00;--primary-contrast: #000000;--primary-shadow: 0 0 0 2px #ffee00;--border: #ffffff;--bubble-mine: #ffee00;--bubble-theirs: #ffffff;--bubble-mine-text: #000000;--bubble-theirs-text: #000000;--danger: #ff4444;--read-tick: #00ff00;--focus: #ffee00;--blur: none;--shadow-soft: 0 0 0 1px #ffffff;--shadow-hard: 0 0 0 2px #ffffff}[data-theme=innovative]{--bg: #1a0b2e;--bg-gradient: radial-gradient(circle at 20% 10%, rgba(255, 0, 229, .25), transparent 40%), radial-gradient(circle at 80% 90%, rgba(0, 245, 255, .22), transparent 45%), radial-gradient(circle at 60% 50%, rgba(120, 0, 255, .18), transparent 50%), linear-gradient(180deg, #12042a 0%, #1a0b2e 100%);--surface: rgba(255, 255, 255, .06);--surface-2: rgba(255, 255, 255, .04);--surface-glass: rgba(26, 11, 46, .55);--surface-border: rgba(255, 255, 255, .14);--text: #f5f3ff;--text-strong: #ffffff;--muted: #b8a9d9;--primary: #ff00e5;--primary-contrast: #ffffff;--primary-shadow: 0 0 20px rgba(255, 0, 229, .5), 0 0 40px rgba(0, 245, 255, .3);--border: rgba(255, 255, 255, .12);--bubble-mine: linear-gradient(135deg, #ff00e5 0%, #7b00ff 100%);--bubble-theirs: rgba(255, 255, 255, .08);--bubble-mine-text: #ffffff;--bubble-theirs-text: #f5f3ff;--read-tick: #00f5ff;--focus: rgba(255, 0, 229, .5);--blur: blur(24px) saturate(1.4);--shadow-soft: 0 8px 32px rgba(0, 0, 0, .37);--shadow-hard: 0 20px 60px rgba(123, 0, 255, .4)}[data-theme=aurora]{--bg: #0d1b3e;--bg-gradient: radial-gradient(ellipse at 15% 10%, rgba(110, 167, 255, .45), transparent 50%), radial-gradient(ellipse at 85% 20%, rgba(195, 163, 255, .38), transparent 55%), radial-gradient(ellipse at 50% 110%, rgba(90, 255, 215, .25), transparent 55%), linear-gradient(180deg, #0a1738 0%, #0d1b3e 100%);--surface: rgba(255, 255, 255, .08);--surface-2: rgba(255, 255, 255, .05);--surface-glass: rgba(13, 27, 62, .55);--surface-border: rgba(255, 255, 255, .2);--text: #eaf1ff;--text-strong: #ffffff;--muted: #9fb3d9;--primary: #6ea7ff;--primary-contrast: #0d1b3e;--primary-shadow: 0 8px 30px rgba(110, 167, 255, .45);--border: rgba(255, 255, 255, .18);--bubble-mine: linear-gradient(135deg, rgba(110,167,255,.85), rgba(195,163,255,.7));--bubble-theirs: rgba(255, 255, 255, .1);--bubble-mine-text: #ffffff;--bubble-theirs-text: #eaf1ff;--danger: #ff7a9f;--read-tick: #c3a3ff;--focus: rgba(110, 167, 255, .45);--blur: blur(28px) saturate(1.6);--shadow-soft: 0 8px 28px rgba(0, 0, 0, .32);--shadow-hard: 0 24px 60px rgba(40, 50, 110, .45)}[data-theme=brutalist]{--bg: #f6f3ea;--bg-gradient: #f6f3ea;--surface: #ffffff;--surface-2: #efe8d6;--surface-glass: #ffffff;--surface-border: #000000;--text: #000000;--text-strong: #000000;--muted: #3a3a3a;--primary: #000000;--primary-contrast: #ffffff;--primary-shadow: 6px 6px 0 #ff5722;--border: #000000;--bubble-mine: #ff5722;--bubble-theirs: #ffffff;--bubble-mine-text: #ffffff;--bubble-theirs-text: #000000;--danger: #c62828;--read-tick: #000000;--focus: #ff5722;--blur: none;--radius-md: 0px;--radius-lg: 4px;--shadow-soft: 4px 4px 0 #000000;--shadow-hard: 8px 8px 0 #000000}[data-theme=cyber]{--bg: #08010c;--bg-gradient: radial-gradient(ellipse at 20% 0%, rgba(255, 43, 214, .35), transparent 45%), radial-gradient(ellipse at 80% 100%, rgba(25, 246, 255, .28), transparent 45%), linear-gradient(180deg, #08010c 0%, #0e0316 100%);--surface: #110320;--surface-2: #1a0630;--surface-glass: rgba(17, 3, 32, .72);--surface-border: rgba(255, 43, 214, .35);--text: #f0e6ff;--text-strong: #ffffff;--muted: #b78fff;--primary: #ff2bd6;--primary-contrast: #ffffff;--primary-shadow: 0 0 16px rgba(255, 43, 214, .75), 0 0 32px rgba(25, 246, 255, .4);--border: rgba(255, 43, 214, .35);--bubble-mine: linear-gradient(135deg, #ff2bd6 0%, #7b00ff 100%);--bubble-theirs: rgba(25, 246, 255, .12);--bubble-mine-text: #ffffff;--bubble-theirs-text: #f0e6ff;--danger: #ff3e66;--read-tick: #19f6ff;--focus: #ff2bd6;--blur: blur(18px);--shadow-soft: 0 0 24px rgba(255, 43, 214, .3);--shadow-hard: 0 0 40px rgba(25, 246, 255, .35)}[data-theme=terrarium]{--bg: #eef4e6;--bg-gradient: radial-gradient(ellipse at 10% 5%, rgba(163, 113, 80, .15), transparent 45%), radial-gradient(ellipse at 90% 90%, rgba(59, 122, 62, .15), transparent 45%), linear-gradient(180deg, #f4f7ec 0%, #eef4e6 100%);--surface: #f8faf2;--surface-2: #e8f0dc;--surface-glass: rgba(248, 250, 242, .8);--surface-border: rgba(59, 122, 62, .18);--text: #2d3a1f;--text-strong: #1b2410;--muted: #6b7a54;--primary: #3b7a3e;--primary-contrast: #ffffff;--primary-shadow: 0 8px 20px rgba(59, 122, 62, .3);--border: rgba(59, 122, 62, .22);--bubble-mine: #3b7a3e;--bubble-theirs: #ffffff;--bubble-mine-text: #ffffff;--bubble-theirs-text: #2d3a1f;--danger: #a33b3b;--read-tick: #a37150;--focus: rgba(59, 122, 62, .35);--blur: blur(12px);--radius-md: 16px;--radius-lg: 22px;--shadow-soft: 0 6px 22px rgba(80, 100, 60, .14);--shadow-hard: 0 14px 40px rgba(80, 100, 60, .22)}[data-theme=papercut]{--bg: #faf7f1;--bg-gradient: #faf7f1;--surface: #ffffff;--surface-2: #f3ece0;--surface-glass: #ffffff;--surface-border: rgba(26, 26, 26, .12);--text: #1a1a1a;--text-strong: #000000;--muted: #6a655c;--primary: #1a1a1a;--primary-contrast: #faf7f1;--primary-shadow: 0 4px 0 #d34f2c;--border: rgba(26, 26, 26, .2);--bubble-mine: #1a1a1a;--bubble-theirs: #ffffff;--bubble-mine-text: #faf7f1;--bubble-theirs-text: #1a1a1a;--danger: #c43a1c;--read-tick: #d34f2c;--focus: #d34f2c;--blur: none;--radius-md: 4px;--radius-lg: 8px;--shadow-soft: 0 1px 0 rgba(26, 26, 26, .12);--shadow-hard: 0 4px 0 rgba(26, 26, 26, .18)}[data-theme=terminal]{--bg: #020a03;--bg-gradient: radial-gradient(ellipse at center, rgba(45, 255, 74, .08), transparent 60%), #020a03;--surface: #021405;--surface-2: #031c07;--surface-glass: rgba(2, 20, 5, .9);--surface-border: #0bdc4c;--text: #2dff4a;--text-strong: #aaffaa;--muted: #0bdc4c;--primary: #2dff4a;--primary-contrast: #020a03;--primary-shadow: 0 0 12px rgba(45, 255, 74, .6);--border: #0bdc4c;--bubble-mine: #041a07;--bubble-theirs: #030f04;--bubble-mine-text: #2dff4a;--bubble-theirs-text: #2dff4a;--danger: #ff3333;--read-tick: #aaffaa;--focus: #2dff4a;--blur: none;--radius-md: 0px;--radius-lg: 2px;--shadow-soft: 0 0 0 1px #0bdc4c;--shadow-hard: 0 0 0 2px #2dff4a}[data-theme=spatial]{--bg: #f1ecff;--bg-gradient: radial-gradient(ellipse at 0% 0%, rgba(90, 75, 230, .16), transparent 55%), radial-gradient(ellipse at 100% 100%, rgba(255, 177, 153, .22), transparent 55%), linear-gradient(180deg, #f6f2ff 0%, #ece6ff 100%);--surface: #ffffff;--surface-2: #ece4ff;--surface-glass: rgba(255, 255, 255, .75);--surface-border: rgba(90, 75, 230, .15);--text: #2a1f63;--text-strong: #1a0f4a;--muted: #7a6fb3;--primary: #5a4be6;--primary-contrast: #ffffff;--primary-shadow: 12px 14px 0 rgba(90, 75, 230, .18);--border: rgba(90, 75, 230, .22);--bubble-mine: linear-gradient(160deg, #5a4be6 0%, #7b68ff 100%);--bubble-theirs: #ffffff;--bubble-mine-text: #ffffff;--bubble-theirs-text: #2a1f63;--danger: #e64b7b;--read-tick: #ffb199;--focus: rgba(90, 75, 230, .35);--blur: blur(10px);--radius-md: 14px;--radius-lg: 20px;--shadow-soft: 8px 10px 0 rgba(90, 75, 230, .12);--shadow-hard: 16px 18px 0 rgba(90, 75, 230, .18)}[data-theme=canvas]{--bg: #fff6e5;--bg-gradient: radial-gradient(ellipse at 15% 20%, rgba(255, 107, 107, .35), transparent 48%), radial-gradient(ellipse at 85% 75%, rgba(91, 140, 255, .3), transparent 52%), radial-gradient(ellipse at 55% 45%, rgba(255, 211, 80, .35), transparent 50%), #fff6e5;--surface: rgba(255, 255, 255, .82);--surface-2: rgba(255, 255, 255, .6);--surface-glass: rgba(255, 246, 229, .8);--surface-border: rgba(0, 0, 0, .08);--text: #2b1f12;--text-strong: #000000;--muted: #7a6a52;--primary: #ff6b6b;--primary-contrast: #ffffff;--primary-shadow: 0 10px 26px rgba(255, 107, 107, .35);--border: rgba(0, 0, 0, .1);--bubble-mine: linear-gradient(135deg, #ff6b6b 0%, #ffc170 100%);--bubble-theirs: rgba(255, 255, 255, .88);--bubble-mine-text: #ffffff;--bubble-theirs-text: #2b1f12;--danger: #d04040;--read-tick: #5b8cff;--focus: rgba(255, 107, 107, .4);--blur: blur(14px) saturate(1.2);--radius-md: 18px;--radius-lg: 26px;--shadow-soft: 0 8px 30px rgba(0, 0, 0, .1);--shadow-hard: 0 22px 60px rgba(0, 0, 0, .2)}[data-theme=aurora],[data-theme=cyber],[data-theme=terminal]{color-scheme:dark}[data-theme=brutalist] .bubble,[data-theme=brutalist] .chat-item,[data-theme=brutalist] .theme-card,[data-theme=brutalist] .profile-card,[data-theme=brutalist] .auth-card,[data-theme=brutalist] .call-bar,[data-theme=brutalist] .call-ring,[data-theme=brutalist] .pwa-guide{border-width:2px!important;border-radius:2px!important}[data-theme=brutalist] .btn,[data-theme=brutalist] .send-btn,[data-theme=brutalist] .attach-btn,[data-theme=brutalist] .voice-rec-btn,[data-theme=brutalist] .voice-play,[data-theme=brutalist] .pref-toggle{border-radius:2px!important;border:2px solid #000000!important;box-shadow:4px 4px #000!important}[data-theme=terminal] body,[data-theme=terminal] textarea,[data-theme=terminal] input,[data-theme=terminal] button,[data-theme=terminal] .text,[data-theme=terminal] .bubble,[data-theme=terminal] .title,[data-theme=terminal] .subtitle,[data-theme=terminal] .chat-item{font-family:SF Mono,Menlo,Consolas,Courier New,monospace!important;letter-spacing:.01em}[data-theme=terminal] .bubble{border:1px solid #0bdc4c!important;border-radius:0!important;box-shadow:inset 0 0 0 1px #0bdc4c4d;text-shadow:0 0 6px rgba(45,255,74,.35)}[data-theme=terminal] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(to bottom,rgba(45,255,74,.045) 0px,rgba(45,255,74,.045) 1px,transparent 1px,transparent 3px);z-index:1}[data-theme=cyber] .bubble{border:1px solid rgba(255,43,214,.5);box-shadow:0 0 14px #ff2bd633}[data-theme=cyber] .msg.mine .bubble{box-shadow:0 0 18px #19f6ff59}[data-theme=papercut] .bubble{box-shadow:2px 2px #1a1a1a1f;border:1px solid rgba(26,26,26,.14)}[data-theme=aurora] .bubble,[data-theme=spatial] .bubble,[data-theme=canvas] .bubble{border-radius:20px}[data-theme=terrarium] .bubble{border-radius:18px;box-shadow:0 2px #3b7a3e1f}[data-theme=aurora] .btn.primary,[data-theme=cyber] .btn.primary,[data-theme=canvas] .btn.primary,[data-theme=spatial] .btn.primary{background:var(--primary);color:var(--primary-contrast);border:0}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}html{color-scheme:light dark;background:var(--bg);background-image:var(--bg-gradient);min-height:100vh;min-height:100dvh;min-height:100lvh}[data-theme=dark],[data-theme=contrast],[data-theme=innovative]{color-scheme:dark}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;background:var(--bg);background-image:var(--bg-gradient);color:var(--text);-webkit-font-smoothing:antialiased;overflow:hidden;min-height:100vh;min-height:100dvh;min-height:100lvh;transition:background var(--transition),color var(--transition)}#root{min-height:100vh;min-height:100dvh;min-height:100lvh}button,input,textarea{font-family:inherit;color:inherit}a{color:var(--primary);text-decoration:none;transition:opacity var(--transition)}a:hover{opacity:.85;text-decoration:none}.screen-center{display:grid;place-items:center;height:100vh;color:var(--muted)}.muted{color:var(--muted)}.center{text-align:center}.p-4{padding:16px}.row{display:flex;align-items:center;justify-content:space-between}.row.gap{gap:8px}button,a,input,textarea,.chat-item,.avatar,.bubble,.tab{transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:24px;padding-top:calc(24px + var(--safe-top));background:var(--bg-gradient)}.auth-card{background:var(--surface-glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:1px solid var(--surface-border);padding:28px;border-radius:20px;width:100%;max-width:400px;box-shadow:var(--shadow-soft)}.auth-card h1{margin:0 0 4px;font-size:28px;letter-spacing:-.02em;background:linear-gradient(135deg,var(--primary),var(--text-strong));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=contrast] .auth-card h1{-webkit-text-fill-color:var(--text-strong);background:none}.form{display:grid;gap:12px;margin-top:12px}.form label{display:grid;gap:4px;font-size:13px;color:var(--muted);font-weight:500}.form input,.form textarea{padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);font-size:16px;color:var(--text)}.form input:focus,.form textarea:focus{outline:2px solid var(--focus);outline-offset:1px;border-color:var(--primary)}.error{background:#e539351f;color:var(--danger);padding:8px 12px;border-radius:8px;font-size:14px;border:1px solid rgba(229,57,53,.3)}.btn{padding:10px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-md);font-size:15px;font-weight:500;cursor:pointer;position:relative;overflow:hidden}.btn:active:not(:disabled){transform:scale(.97)}.btn:hover:not(:disabled){filter:brightness(1.05)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent;box-shadow:var(--primary-shadow)}.btn.primary:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.08)}[data-theme=innovative] .btn.primary{background:linear-gradient(135deg,var(--primary) 0%,#7b00ff 100%);background-size:200% 200%;animation:gradient-shift 4s ease infinite}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.btn.ghost{background:transparent;border-color:transparent}.btn.small{padding:6px 10px;font-size:14px}.btn.primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(255,255,255,.35) 0%,transparent 60%);opacity:0;transition:opacity var(--transition)}.btn.primary:active:after{opacity:1}.app-screen{display:grid;grid-template-rows:auto auto 1fr;min-height:100vh;min-height:100dvh;min-height:100lvh;height:100vh;height:100dvh;height:100lvh}.app-screen.chat-screen{grid-template-rows:auto 1fr auto}.app-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;padding-top:calc(12px + var(--safe-top));padding-right:calc(16px + var(--safe-right));padding-bottom:12px;padding-left:calc(16px + var(--safe-left));background:var(--surface-glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:1px solid var(--surface-border);position:sticky;top:0;z-index:10}.app-header .title{font-weight:600;font-size:18px;letter-spacing:-.01em}.app-header .subtitle{color:var(--muted);font-size:12px}.app-header .chat-title{display:flex;gap:10px;align-items:center}.app-header .actions{display:flex;gap:8px}.subheader{padding:6px 16px;color:var(--muted);font-size:13px;background:var(--surface-glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:1px solid var(--surface-border)}.chat-list{overflow-y:auto;padding-bottom:var(--safe-bottom)}.chat-item{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:12px 14px;background:var(--surface);color:var(--text);border-bottom:1px solid var(--surface-border);text-decoration:none;position:relative}[data-theme=innovative] .chat-item{background:var(--surface-glass)}.chat-item:hover{background:var(--surface-2);text-decoration:none;transform:translate(2px)}.chat-item:active{transform:scale(.99)}.chat-item-body{min-width:0}.chat-item .title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.chat-item .time{color:var(--muted);font-size:12px;margin-left:8px}.chat-item .preview{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}.badge{background:var(--primary);color:var(--primary-contrast);border-radius:999px;font-size:12px;padding:2px 8px;min-width:22px;text-align:center;font-weight:600;box-shadow:var(--primary-shadow)}.empty{display:grid;gap:12px;place-items:center;padding:40px 16px;color:var(--muted)}.avatar{display:inline-grid;place-items:center;border-radius:50%;background:var(--muted);color:#fff;font-weight:700;object-fit:cover;flex-shrink:0;letter-spacing:-.02em}[data-theme=innovative] .avatar{box-shadow:0 0 12px #ff00e54d}.messages{overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:4px;scroll-behavior:auto}.msg{display:flex}.msg.mine{justify-content:flex-end}.msg.theirs{justify-content:flex-start}.bubble{max-width:78%;padding:8px 12px 5px;border-radius:14px;background:var(--bubble-theirs);color:var(--bubble-theirs-text);box-shadow:0 1px 2px #00000014;position:relative;word-wrap:break-word;overflow-wrap:anywhere}.msg.mine .bubble{background:var(--bubble-mine);color:var(--bubble-mine-text);border-bottom-right-radius:4px}.msg.theirs .bubble{border-bottom-left-radius:4px}[data-theme=innovative] .bubble{backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:1px solid var(--surface-border)}[data-theme=innovative] .msg.mine .bubble{border:1px solid rgba(255,0,229,.3);box-shadow:0 4px 20px #ff00e540}.bubble .sender{font-size:12px;color:var(--primary);font-weight:600;margin-bottom:2px}.bubble .text{white-space:pre-wrap;font-size:15px;line-height:1.4}.bubble .meta{display:flex;gap:4px;justify-content:flex-end;align-items:center;margin-top:2px;color:var(--muted);font-size:11px}.msg.mine .bubble .meta{color:#ffffffbf}[data-theme=light] .msg.mine .bubble .meta{color:#0f172a8c}[data-theme=contrast] .msg.mine .bubble .meta{color:#000000b3}.bubble .ticks{letter-spacing:-2px}.bubble .ticks.read{color:var(--read-tick)}.msg-image{max-width:260px;max-height:280px;border-radius:10px;display:block;margin-bottom:4px;transition:transform var(--transition)}.msg-image:hover{transform:scale(1.02)}.msg-image-btn{background:none;border:0;padding:0;margin:0 0 4px;cursor:zoom-in;display:block;border-radius:10px;-webkit-tap-highlight-color:transparent}.msg-image-btn:focus{outline:none}.msg-image-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.msg-image-btn .msg-image{margin-bottom:0}.msg-file{display:inline-block;padding:8px 12px;background:#0000000f;border-radius:10px;font-size:14px;margin-bottom:4px;color:inherit}.msg.mine .msg-file{background:#fff3}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000e0;display:flex;align-items:center;justify-content:center;padding:calc(16px + env(safe-area-inset-top)) 16px calc(16px + env(safe-area-inset-bottom));backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);cursor:zoom-out;touch-action:none}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;cursor:default}.lightbox-close{position:absolute;top:calc(10px + env(safe-area-inset-top));right:calc(12px + env(safe-area-inset-right));width:40px;height:40px;border-radius:50%;border:0;background:#ffffff24;color:#fff;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background var(--transition),transform var(--transition)}.lightbox-close:hover{background:#ffffff3d}.lightbox-close:active{transform:scale(.92)}.lightbox-download{position:absolute;bottom:calc(20px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);padding:10px 20px;background:#ffffff29;color:#fff;border-radius:20px;text-decoration:none;font-size:14px;font-weight:500;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background var(--transition)}.lightbox-download:hover{background:#ffffff42}.msg-input{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:end;padding-top:8px;padding-right:calc(10px + var(--safe-right));padding-bottom:calc(8px + var(--safe-bottom));padding-left:calc(10px + var(--safe-left));background:var(--surface-glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-top:1px solid var(--surface-border)}.msg-input .attach-btn,.msg-input .send-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;font-size:18px;flex-shrink:0}.msg-input .send-btn{background:var(--primary);color:var(--primary-contrast);border-color:transparent;box-shadow:var(--primary-shadow)}.msg-input .send-btn:hover:not(:disabled){transform:scale(1.05) rotate(5deg)}.msg-input .send-btn:active:not(:disabled){transform:scale(.95)}.msg-input .attach-btn:hover{transform:rotate(15deg)}[data-theme=innovative] .msg-input .send-btn{background:linear-gradient(135deg,var(--primary) 0%,#7b00ff 100%)}.msg-input .input-wrap{background:var(--surface-2);border:1px solid var(--border);border-radius:22px;padding:4px 12px;max-height:140px;overflow:auto}.msg-input .input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus)}.msg-input textarea{width:100%;border:0;background:transparent;resize:none;padding:8px 0;outline:none;font-size:16px}.file-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px 10px;font-size:13px;margin:6px 0}.file-chip button{border:0;background:transparent;cursor:pointer;font-size:16px}.typing{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;margin:4px 0;color:var(--muted);font-size:13px;background:var(--surface);border-radius:14px;width:fit-content;box-shadow:0 1px 2px #00000014}.typing .dot{width:6px;height:6px;background:var(--muted);border-radius:50%;animation:typing 1.2s infinite ease-in-out}.typing .dot:nth-child(2){animation-delay:.15s}.typing .dot:nth-child(3){animation-delay:.3s}@keyframes typing{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-4px);opacity:1}}.tabs{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;background:var(--surface-2);padding:4px;border-radius:var(--radius-md);margin-bottom:16px}.tab{background:transparent;border:0;padding:10px;cursor:pointer;border-radius:10px;font-size:14px;color:var(--muted);font-weight:500}.tab.active{background:var(--surface);color:var(--text);font-weight:600;box-shadow:0 1px 3px #0000001a}.member-list{list-style:none;padding:0;margin:0}.member-list li{display:flex;justify-content:space-between;align-items:center;padding:10px 4px;border-bottom:1px solid var(--border)}.new-chat-main{padding:12px 16px calc(16px + var(--safe-bottom));overflow-y:auto;display:flex;flex-direction:column;gap:8px}.new-chat-footer{padding:10px 16px calc(10px + env(safe-area-inset-bottom,0));background:var(--surface);border-top:1px solid var(--border);display:grid}.search-wrap{position:sticky;top:0;background:var(--bg);padding:4px 0 8px;z-index:1}.search-input{width:100%;background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius-md);padding:10px 14px;font-size:15px;color:var(--text);transition:border-color var(--transition),background var(--transition)}.search-input:focus{outline:none;border-color:var(--primary);background:var(--surface)}.chip-row{display:flex;flex-wrap:wrap;gap:6px;padding:2px 0 6px}.chip{background:var(--primary);color:var(--primary-contrast);border:0;border-radius:999px;padding:6px 10px;font-size:13px;font-weight:500;cursor:pointer}.user-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.user-row{border-radius:var(--radius-md);transition:background var(--transition)}.user-row.selected{background:var(--primary-weak, rgba(13,148,136,.12))}.user-row-btn{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;width:100%;padding:10px;background:transparent;border:0;text-align:left;cursor:pointer;border-radius:var(--radius-md)}.user-row-btn:hover:not(:disabled){background:var(--surface-2)}.user-row-btn:disabled{opacity:.6;cursor:default}.user-meta{display:grid;gap:2px;min-width:0}.user-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-sub{color:var(--muted);font-size:13px}.check-box{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:grid;place-items:center;font-size:14px;color:var(--primary-contrast);background:transparent;transition:all var(--transition)}.check-box.on{background:var(--primary);border-color:var(--primary)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:0}.settings-row-title{font-weight:600;color:var(--text)}.settings-row-sub{font-size:13px;margin-top:2px}.pref-toggle{position:relative;width:46px;height:28px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;padding:0;flex-shrink:0;transition:background var(--transition),border-color var(--transition)}.pref-toggle:disabled{opacity:.4;cursor:not-allowed}.pref-toggle.on{background:var(--primary);border-color:var(--primary);box-shadow:var(--primary-shadow)}.pref-toggle-knob{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform var(--transition)}.pref-toggle.on .pref-toggle-knob{transform:translate(18px)}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-top:8px}.theme-card{cursor:pointer;border:2px solid var(--border);border-radius:var(--radius-lg);padding:12px;background:var(--surface);display:grid;gap:8px;position:relative}.theme-card.active{border-color:var(--primary);box-shadow:var(--primary-shadow)}.theme-card .swatches{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;height:60px;border-radius:10px;overflow:hidden}.theme-card .swatch{background:currentColor}.theme-card .label{font-weight:600;font-size:15px}.theme-card .desc{font-size:12px;color:var(--muted)}.theme-card .check{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--primary);color:var(--primary-contrast);display:grid;place-items:center;font-size:14px;opacity:0;transform:scale(0);transition:all var(--transition)}.theme-card.active .check{opacity:1;transform:scale(1)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.profile-card{display:flex;align-items:center;gap:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.profile-avatar{position:relative;width:88px;height:88px;flex-shrink:0}.avatar-edit-btn{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);white-space:nowrap}.profile-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.profile-displayname{font-size:18px;font-weight:600;display:flex;align-items:center}.rename-row{display:flex;gap:6px;align-items:center}.rename-row input{flex:1;min-width:0}.badge-admin{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:999px;background:var(--primary);color:var(--primary-contrast);width:fit-content;margin-top:4px}.admin-main{padding-bottom:32px}.admin-section h3{margin:0 0 8px}.form-row{display:flex;gap:8px;margin-bottom:8px}.form-row input{flex:1}.group-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.group-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.group-name{font-weight:500}.group-actions{display:flex;gap:4px}.admin-user-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.admin-user-row{padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:10px}.admin-user-head{display:flex;align-items:center;gap:12px}.admin-toggles{display:flex;gap:16px;flex-wrap:wrap}.toggle{display:inline-flex;align-items:center;gap:6px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.admin-group-chips{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px;border-top:1px dashed var(--border)}.admin-group-chips .chip{padding:6px 12px;background:transparent;border:1px solid var(--border);color:var(--text);font-size:13px;border-radius:999px;cursor:pointer;transition:all var(--transition)}.admin-group-chips .chip:hover{border-color:var(--primary)}.admin-group-chips .chip-on{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.admin-group-chips .chip:disabled{opacity:.6;cursor:not-allowed}.admin-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:4px;border-top:1px dashed var(--border)}.btn.danger{background:transparent;color:var(--danger, #d94c4c);border:1px solid var(--danger, #d94c4c)}.btn.danger:hover:not(:disabled){background:var(--danger, #d94c4c);color:#fff}.badge-blocked{display:inline-block;padding:2px 8px;border-radius:999px;background:#d94c4c26;color:var(--danger, #d94c4c);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.admin-user-blocked{opacity:.72}.admin-user-blocked .user-name{text-decoration:line-through;text-decoration-color:var(--danger, #d94c4c)}.voice-rec{position:relative;display:flex;align-items:end}.voice-rec-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;font-size:20px;flex-shrink:0;transition:transform .15s ease,background .2s ease;touch-action:none;-webkit-user-select:none;user-select:none}.voice-rec-btn.active{background:var(--primary);color:var(--primary-contrast);border-color:transparent;transform:scale(1.12);box-shadow:0 0 0 6px #0b93f62e,var(--primary-shadow);animation:voice-pulse 1.2s infinite}@keyframes voice-pulse{0%,to{box-shadow:0 0 0 6px #0b93f62e,var(--primary-shadow)}50%{box-shadow:0 0 0 12px #0b93f60a,var(--primary-shadow)}}.voice-rec-bar{position:absolute;right:52px;bottom:0;display:flex;align-items:center;gap:8px;padding:8px 12px;min-width:min(240px,calc(100vw - 84px - var(--safe-left, 0px) - var(--safe-right, 0px)));max-width:calc(100vw - 68px - var(--safe-left, 0px) - var(--safe-right, 0px));box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:22px;box-shadow:0 6px 20px #0000001f;white-space:nowrap;font-size:13px;color:var(--text);pointer-events:none}.voice-rec.locked .voice-rec-bar{pointer-events:auto}.voice-rec-dot{width:10px;height:10px;background:var(--danger, #e43a3a);border-radius:50%;animation:voice-dot 1s infinite}@keyframes voice-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.8)}}.voice-rec-timer{font-variant-numeric:tabular-nums;font-weight:600;min-width:44px}.voice-rec-hint{color:var(--muted);font-size:12px;transition:transform .1s linear}.voice-rec-actions{display:flex;gap:6px;margin-left:auto}.voice-rec-err{position:absolute;right:52px;bottom:52px;background:var(--danger, #e43a3a);color:#fff;padding:6px 10px;border-radius:10px;font-size:12px;white-space:nowrap}.voice-msg{display:grid;grid-template-columns:36px 1fr;gap:10px;align-items:center;padding:4px 0;min-width:220px}.voice-msg .voice-play{width:36px;height:36px;border-radius:50%;border:0;display:grid;place-items:center;background:var(--primary);color:var(--primary-contrast);font-size:14px;cursor:pointer;flex-shrink:0;box-shadow:var(--primary-shadow)}.msg.mine .voice-msg .voice-play{background:#ffffff4d;color:#fff;box-shadow:none}.voice-msg .voice-body{display:flex;flex-direction:column;gap:4px;min-width:0}.voice-msg .voice-wave{display:flex;align-items:center;gap:2px;height:28px;width:100%;cursor:pointer}.voice-msg .voice-bar{flex:1;min-width:2px;background:var(--muted);opacity:.4;border-radius:2px;transition:opacity .15s ease,background .15s ease}.voice-msg .voice-bar.on{opacity:1;background:var(--primary)}.msg.mine .voice-msg .voice-bar{background:#ffffff80}.msg.mine .voice-msg .voice-bar.on{background:#fff}.voice-msg .voice-meta{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--muted)}.msg.mine .voice-msg .voice-meta{color:#ffffffd9}.voice-msg .voice-time{font-variant-numeric:tabular-nums}.voice-msg .voice-speed{border:0;background:var(--surface-2);color:var(--text);padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;cursor:pointer;line-height:1}.msg.mine .voice-msg .voice-speed{background:#ffffff40;color:#fff}.voice-msg .voice-speed:hover{filter:brightness(1.1)}.call-ring,.call-bar{position:fixed;left:0;right:0;margin-inline:auto;top:calc(8px + var(--safe-top, 0px));z-index:120;background:var(--surface);border:1px solid var(--border);box-shadow:0 12px 32px #00000038;border-radius:18px;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);box-sizing:border-box;width:min(420px,calc(100vw - 16px - var(--safe-left, 0px) - var(--safe-right, 0px)));max-width:calc(100vw - 8px);padding:10px 12px}.call-ring{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px}.call-ring-text{min-width:0}.call-ring-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call-ring-text .muted{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}.call-ring-actions{display:flex;gap:6px;flex-shrink:0}.call-ring-actions .btn{white-space:nowrap}.call-bar{display:flex;flex-direction:column;gap:8px}.call-bar-head{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);min-width:0}.call-bar-head .call-dot{width:8px;height:8px;background:#2ecc71;border-radius:50%;animation:voice-dot 1s infinite;flex-shrink:0}.call-bar-head .call-timer{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.call-bar-head .call-count{margin-left:auto;white-space:nowrap}.call-avatars{display:flex;gap:6px;flex-wrap:wrap}.call-avatar{position:relative;border-radius:50%;padding:2px;border:2px solid transparent;transition:border-color .2s ease,opacity .2s ease;flex-shrink:0}.call-avatar.on{border-color:#2ecc71}.call-avatar.pending{opacity:.55}.call-bar-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.call-bar-actions .btn{white-space:nowrap;min-width:0;flex:0 1 auto}@media (max-width: 380px){.call-bar-actions{flex-direction:column;align-items:stretch}.call-bar-actions .btn{width:100%}}.btn.danger{background:var(--danger, #e43a3a);color:#fff;border:0}.pwa-guide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:grid;place-items:center;box-sizing:border-box;padding:calc(16px + var(--safe-top, 0px)) calc(16px + var(--safe-right, 0px)) calc(16px + var(--safe-bottom, 0px)) calc(16px + var(--safe-left, 0px))}.pwa-guide{width:min(440px,100%);max-width:100%;max-height:100%;overflow:auto;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:22px;box-shadow:0 20px 50px #00000059;padding:16px 18px;display:flex;flex-direction:column;gap:14px}.pwa-guide-head{display:flex;align-items:center;justify-content:space-between}.pwa-guide-title{font-weight:700;font-size:17px}.pwa-phone{position:relative;margin:0 auto;width:180px;height:260px;background:var(--surface-2);border:3px solid var(--border);border-radius:28px;overflow:hidden;box-shadow:inset 0 0 0 3px #0000000f}.pwa-phone-screen{position:absolute;top:8px;right:8px;bottom:8px;left:8px;background:var(--surface);border-radius:20px;overflow:hidden}.pwa-phone-url{height:22px;display:grid;place-items:center;font-size:11px;color:var(--muted);border-bottom:1px solid var(--border)}.pwa-phone-content{padding:8px;display:flex;flex-direction:column;gap:6px}.pwa-phone-bubble{height:14px;border-radius:10px}.pwa-phone-bubble.mine{width:65%;background:var(--primary);align-self:flex-end}.pwa-phone-bubble.theirs{width:55%;background:var(--muted);opacity:.5}.pwa-phone-bubble.short{width:40%}.pwa-phone-menu{position:absolute;left:6px;right:6px;bottom:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:6px;font-size:11px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 22px #00000038}.pwa-phone-menu-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:8px}.pwa-phone-menu-icon{width:22px;height:22px;display:grid;place-items:center}.pwa-phone-tap{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.pwa-phone-finger{position:absolute;left:50%;transform:translate(-50%);font-size:22px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.35))}.pwa-guide-steps{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--text)}.pwa-guide-steps li{line-height:1.4}.pwa-guide-steps svg{vertical-align:-4px;margin:0 2px}.pwa-guide-actions{display:flex;justify-content:flex-end;gap:8px}
