@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg: #0a0a0f;--bg-card: #12121a;--bg-input: #1a1a24;--border: #2a2a3a;--text: #e8e8ed;--text-muted: #8a8a9a;--accent: #00d4aa;--accent-hover: #00f0c0;--accent-dim: rgba(0, 212, 170, .15);--danger: #ef4444;--danger-hover: #f87171;--radius: 12px;--radius-lg: 16px;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--transition: .2s ease}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Outfit,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#app{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}#app.fullscreen{padding:0;align-items:stretch;max-width:none}.screen{width:100%;max-width:480px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.landing__hero{text-align:center;margin-bottom:3rem}.landing__title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing__subtitle{margin:0;color:var(--text-muted);font-size:1.1rem}.landing__cards{display:flex;flex-direction:column;gap:1.25rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;cursor:pointer;transition:var(--transition)}.card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.card__icon{width:48px;height:48px;margin:0 auto 1rem;color:var(--text-muted)}.card__icon svg{width:100%;height:100%;display:block}.card:hover .card__icon{color:var(--accent)}.card h2{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.card p{margin:0 0 1.25rem;color:var(--text-muted);font-size:.95rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:500;border:none;border-radius:var(--radius);cursor:pointer;transition:var(--transition)}.btn--primary{background:var(--accent);color:var(--bg)}.btn--primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn--secondary{background:var(--bg-input);color:var(--accent);border:1px solid var(--accent)}.btn--secondary:hover:not(:disabled){background:var(--accent-dim)}.btn--ghost{background:transparent;color:var(--text-muted)}.btn--ghost:hover:not(:disabled){color:var(--text)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--danger-hover)}.btn--lg{padding:1rem 2rem;font-size:1.1rem;width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.back-btn{margin-bottom:1.5rem;padding:.5rem 0}.create-room__form,.create-room__success,.join-room__form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}.create-room h1,.join-room h1{margin:0 0 .5rem;font-size:1.5rem}.create-room__hint,.join-room__hint{margin:0 0 1.5rem;color:var(--text-muted);font-size:.95rem}.input-group{margin-bottom:1.25rem;text-align:left}.input-group label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:500;color:var(--text-muted)}.input-group__optional{font-weight:400;opacity:.8}.input-group input{width:100%;padding:.875rem 1rem;font-family:inherit;font-size:1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:var(--transition)}.input-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input-group input::placeholder{color:var(--text-muted);opacity:.7}.create-room__success{text-align:center}.room-code-label{margin:0 0 .75rem;color:var(--text-muted);font-size:.9rem}.room-code{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem;padding:1rem 1.5rem;background:var(--bg-input);border-radius:var(--radius);border:1px dashed var(--border)}.room-code__value{font-size:1.5rem;font-weight:600;letter-spacing:.15em;color:var(--accent)}.room-link{margin-bottom:2rem}.room-link__url{word-break:break-all;font-size:.9rem}.create-room__waiting{margin-top:1rem;color:var(--text-muted);font-size:.9rem}.error-msg{margin:1rem 0 0;color:var(--danger);font-size:.9rem;min-height:1.25rem}.host-view{max-width:560px;width:100%}.host-view__header-actions{display:flex;gap:.5rem}.host-view__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border)}.host-view__status{display:flex;align-items:center;gap:.5rem;font-weight:500}.status-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.host-view__viewers{color:var(--text-muted);font-size:.95rem}.viewer-count{color:var(--accent);font-weight:600}.host-view__room-info{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);font-size:.9rem}.host-view__room-code,.host-view__password,.host-view__link{display:flex;align-items:center;gap:.5rem}.host-view__label{color:var(--text-muted)}.host-view__value{font-weight:600;font-family:var(--font-mono, monospace)}.btn--sm{padding:.25rem .5rem;font-size:.8rem}.host-view__dropzone{min-height:200px;padding:2rem;background:var(--bg-card);border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.host-view__dropzone:hover,.host-view__dropzone.dropzone--active{border-color:var(--accent);background:var(--accent-dim)}.dropzone__icon{width:48px;height:48px;color:var(--text-muted)}.host-view__dropzone:hover .dropzone__icon,.host-view__dropzone.dropzone--active .dropzone__icon{color:var(--accent)}.dropzone__text{margin:0;font-weight:500;font-size:1.1rem}.dropzone__hint{margin:0;color:var(--text-muted);font-size:.9rem}.dropzone__files{margin-top:1rem;width:100%;display:flex;flex-direction:column;gap:.5rem}.dropzone__file-item{font-size:.9rem;color:var(--accent)}.file-history{margin-top:1.5rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.file-history__title{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:var(--text-muted)}.file-history__list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.file-history__item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem .75rem;background:var(--bg-input);border-radius:var(--radius);font-size:.9rem}.file-history__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-history__size{flex-shrink:0;color:var(--text-muted);font-size:.85rem}.file-history__empty{margin:0;color:var(--text-muted);font-size:.9rem}.viewer-view{max-width:100%;width:100%;min-height:100vh;display:flex;flex-direction:column;padding:0}.viewer-view__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.viewer-view__header-actions{display:flex;align-items:center;gap:.5rem}.viewer-view__title{font-weight:500}.viewer-view__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);padding:2rem;min-height:0}.viewer-view__ready{text-align:center}.viewer-view__ready-icon{width:64px;height:64px;color:var(--accent);margin-bottom:1rem;opacity:.8}.viewer-view__ready p{margin:0 0 .25rem;font-size:1.1rem}.viewer-view__hint{color:var(--text-muted);font-size:.9rem;margin:0}.viewer-view__downloads{margin-top:2rem;width:100%;max-width:400px;display:flex;flex-direction:column;gap:.5rem}.viewer-view__download-item{padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;color:var(--accent)}.viewer-view__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.join-room__form{margin-top:0}@media(max-width:640px){#app{padding:1rem;padding-top:max(1rem,env(safe-area-inset-top));padding-bottom:env(safe-area-inset-bottom);align-items:flex-start}.landing__title{font-size:1.75rem}.landing__subtitle{font-size:1rem}.landing__cards{gap:1rem}.card{padding:1.5rem 1rem;min-height:44px}.card .btn{min-height:44px;padding:.875rem 1.25rem}.host-view__header{flex-direction:column;align-items:stretch}.host-view__room-info{flex-direction:column}.host-view__dropzone{min-height:160px;padding:1.5rem}.viewer-view__header{padding:.75rem 1rem;padding-top:max(.75rem,env(safe-area-inset-top))}.viewer-view__header .btn{min-height:40px;padding:.5rem 1rem}.create-room__form,.create-room__success,.join-room__form{padding:1.25rem}.input-group input{min-height:48px;font-size:16px}.btn--lg{min-height:48px}.back-btn{min-height:44px;padding:.75rem 0}}
