:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-elevated: #22222d;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #6b6b7b;--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-secondary: #10b981;--accent-danger: #ef4444;--accent-warning: #f59e0b;--border-color: #2a2a3a;--border-light: #3a3a4a;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-panel: 100;--z-modal: 200;--z-toast: 300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:var(--accent-primary);text-decoration:none}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-base);transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-primary-hover);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-light)}.btn-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.btn-small{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm)}.btn-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-icon svg{flex-shrink:0}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--font-size-lg)}.btn-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.badge-host{background:var(--accent-primary);color:#fff}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.input-group input{padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f133}.input-group input::placeholder{color:var(--text-muted)}.code-input{text-align:center;font-size:var(--font-size-2xl)!important;font-weight:700;letter-spacing:.3em;text-transform:uppercase}.landing{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-primary) 0%,#0f0f18 100%)}.landing-container{width:100%;max-width:420px;display:flex;flex-direction:column;gap:var(--space-xl)}.landing-hero{text-align:center}.logo{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md)}.logo-icon{font-size:2.5rem}.logo h1{font-size:var(--font-size-3xl);font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-secondary);font-size:var(--font-size-lg)}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);background:#ef44441a;border:1px solid var(--accent-danger);border-radius:var(--radius-md);color:var(--accent-danger);cursor:pointer;transition:background var(--transition-fast)}.error-banner:hover{background:#ef444426}.landing-main{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-lg)}.home-view,.join-view{display:flex;flex-direction:column;gap:var(--space-lg)}.back-btn{align-self:flex-start;color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--space-sm) 0;transition:color var(--transition-fast)}.back-btn:hover{color:var(--text-primary)}.action-buttons{display:flex;flex-direction:column;gap:var(--space-md)}.divider{display:flex;align-items:center;gap:var(--space-md);color:var(--text-muted);font-size:var(--font-size-sm)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.feature{text-align:center;padding:var(--space-md) var(--space-sm)}.feature-icon{font-size:1.75rem;display:block;margin-bottom:var(--space-sm)}.feature h3{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-xs)}.feature p{font-size:var(--font-size-xs);color:var(--text-muted);line-height:1.4}.landing-footer{text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.chat-room{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg-primary)}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.header-left,.header-right{display:flex;align-items:center;gap:var(--space-sm)}.room-info h1{font-size:var(--font-size-lg);font-weight:600}.room-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.peer-count{color:var(--text-muted)}.connection-indicator{display:flex;align-items:center}.indicator-dot{width:8px;height:8px;border-radius:50%;transition:background var(--transition-normal)}.connection-indicator.connected .indicator-dot{background:var(--accent-secondary);box-shadow:0 0 8px var(--accent-secondary)}.connection-indicator.reconnecting .indicator-dot{background:var(--accent-warning);animation:pulse 1.5s ease infinite}.connection-indicator.disconnected .indicator-dot{background:var(--accent-danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.panel{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--space-md);flex-shrink:0;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.panel-header h2{font-size:var(--font-size-lg);font-weight:600}.panel-content{display:flex;flex-direction:column;gap:var(--space-md);align-items:center}.room-code-display{text-align:center}.room-code-display .label{display:block;font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-xs)}.room-code-display .code{font-size:var(--font-size-3xl);font-weight:800;letter-spacing:.15em;color:var(--accent-primary)}.share-link-group{display:flex;gap:var(--space-sm);width:100%}.share-link-group input{flex:1;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-primary)}.share-link-group input:focus{outline:none;border-color:var(--accent-primary)}.qr-container{padding:var(--space-md);background:#fff;border-radius:var(--radius-md)}.qr-code{width:160px;height:160px}.users-list{width:100%}.user-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.user-item.is-me{background:#6366f126;border:1px solid var(--accent-primary)}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--accent-secondary)}.status-dot.connecting{background:var(--accent-warning);animation:pulse 1.5s ease infinite}.user-name{flex:1;font-size:var(--font-size-sm)}.messages-container{flex:1;overflow-y:auto;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);overscroll-behavior:contain}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.message{max-width:85%}.message-system{align-self:center;max-width:100%;text-align:center;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--text-muted)}.message-bubble{padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.message-bubble.own{align-self:flex-end;background:var(--accent-primary);border-color:var(--accent-primary)}.message-meta{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xs)}.message-sender{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary)}.message-bubble.own .message-sender{color:#fffc}.message-time{font-size:var(--font-size-xs);color:var(--text-muted)}.message-bubble.own .message-time{color:#fff9}.message-text{font-size:var(--font-size-base);word-break:break-word;white-space:pre-wrap}.file-attachment{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0}.file-icon{font-size:1.5rem}.file-details{flex:1;min-width:0}.file-name{display:block;font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:var(--font-size-xs);color:var(--text-muted)}.message-bubble.own .file-size{color:#ffffffb3}.transfers-bar{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--space-sm) var(--space-md);flex-shrink:0}.transfer-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0}.transfer-icon{font-size:var(--font-size-sm)}.transfer-name{font-size:var(--font-size-sm);max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transfer-progress{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.transfer-bar{height:100%;background:var(--accent-secondary);transition:width .2s ease}.transfer-percent{font-size:var(--font-size-xs);color:var(--text-muted);min-width:35px;text-align:right}.composer{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.btn-attach{color:var(--text-secondary)}.composer input[type=text]{flex:1;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--font-size-base)}.composer input[type=text]:focus{outline:none;border-color:var(--accent-primary)}.btn-send{border-radius:var(--radius-full);padding:var(--space-sm) var(--space-md)}.btn-send .btn-text{display:none}@media(min-width:640px){.landing-container{max-width:480px}.features{gap:var(--space-md)}.feature{padding:var(--space-lg) var(--space-md)}.feature h3{font-size:var(--font-size-base)}.feature p{font-size:var(--font-size-sm)}.message{max-width:70%}.qr-code{width:180px;height:180px}.btn-send .btn-text{display:inline}.btn-send svg{display:none}}@media(min-width:768px){.chat-room{max-width:800px;margin:0 auto;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color)}.chat-header{padding:var(--space-md) var(--space-lg)}.messages-container{padding:var(--space-lg)}.composer{padding:var(--space-md) var(--space-lg)}.panel{padding:var(--space-lg)}}@media(min-width:1024px){.landing{padding:var(--space-2xl)}.landing-container{max-width:520px}}@supports (padding-top: env(safe-area-inset-top)){.chat-header{padding-top:max(var(--space-md),env(safe-area-inset-top))}.composer{padding-bottom:max(var(--space-md),env(safe-area-inset-bottom))}.landing{padding-top:max(var(--space-lg),env(safe-area-inset-top));padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom))}}@media(hover:none)and (pointer:coarse){.btn,.btn-icon{-webkit-tap-highlight-color:transparent}.btn:active:not(:disabled),.btn-icon:active{transform:scale(.97)}.btn-icon{min-width:48px;min-height:48px}.user-item{min-height:52px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
