@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.block{display:block}.flex{display:flex}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}}*{box-sizing:border-box;margin:0;padding:0}html,body{overscroll-behavior:none;-moz-text-size-adjust:100%;text-size-adjust:100%;height:100dvh}html{overflow:hidden}body{color:#f1f5f9;background:#0f172a;flex-direction:column;font-family:-apple-system,sans-serif;display:flex;overflow:hidden}button,a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}input,textarea{touch-action:manipulation}.screen{z-index:999;background:#0f172a;flex-direction:column;justify-content:center;align-items:center;gap:1.2rem;padding:2rem;display:flex;position:fixed;inset:0}.screen h1{color:#38bdf8;font-size:2rem;font-weight:800}.screen p{color:#94a3b8;text-align:center;font-size:.9rem}.screen input{color:#f1f5f9;text-align:center;background:#1e293b;border:2px solid #334155;border-radius:10px;outline:none;width:260px;padding:.65rem 1rem;font-size:1.1rem}.screen input:focus{border-color:#38bdf8}.btn-primary{color:#0f172a;cursor:pointer;background:#38bdf8;border:none;border-radius:10px;width:260px;padding:.7rem 2rem;font-size:1rem;font-weight:700}.btn-secondary{color:#94a3b8;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:10px;width:260px;padding:.65rem 2rem;font-size:.95rem}.btn-primary:hover{background:#7dd3fc}.divider{color:#334155;font-size:.85rem}#active-rooms{flex-direction:column;gap:.5rem;width:260px;max-height:200px;display:flex;overflow-y:auto}.room-card{cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:10px;justify-content:space-between;align-items:center;padding:.6rem 1rem;transition:border-color .15s;display:flex}.room-card:hover{border-color:#38bdf8}.room-card .rcode{color:#38bdf8;font-size:.95rem;font-weight:700}.room-card .rnames{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.75rem;overflow:hidden}.room-card .rcnt{color:#4ade80;flex-shrink:0;font-size:.75rem}#share-box{background:#1e293b;border:1px solid #334155;border-radius:10px;flex-direction:column;gap:.5rem;width:260px;padding:.9rem 1rem;display:flex}#share-box p{color:#94a3b8;text-align:left;font-size:.75rem}#share-link{color:#38bdf8;word-break:break-all;font-size:.75rem;line-height:1.4}.copy-btn{color:#f1f5f9;cursor:pointer;background:#334155;border:none;border-radius:6px;align-self:flex-start;padding:.3rem .8rem;font-size:.8rem}.copy-btn.copied{color:#fff;background:#22c55e}#app{flex-direction:column;height:100dvh;display:none;position:relative}#share-photo-btn{color:#0f172a;cursor:pointer;background:#0ea5e9;border:none;border-radius:6px;flex-shrink:0;margin-left:.4rem;padding:.15rem .55rem;font-size:.85rem}#photo-thumbs::-webkit-scrollbar{width:0}.photo-thumb-wrap{background:#334155;border:2px solid #1e293b;border-radius:10px;width:25vw;min-width:120px;max-width:220px;position:relative;overflow:hidden;box-shadow:0 4px 14px #0000008c}.photo-thumb-wrap:hover{border-color:#38bdf8}.photo-thumb{object-fit:cover;cursor:zoom-in;width:100%;height:auto;max-height:25vh;display:block}.photo-thumb-close{color:#f87171;cursor:pointer;background:#0f172ad9;border:1px solid #f87171;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:14px;font-weight:700;line-height:1;display:flex;position:absolute;top:4px;right:4px}.photo-thumb-close:hover{color:#0f172a;background:#f87171}#map{flex:1;min-height:0}#gps-bar{color:#94a3b8;background:#1e293b;flex-shrink:0;justify-content:space-between;align-items:center;min-height:22px;padding:.25rem .75rem;font-size:.75rem;display:flex}#gps-bar.ok{color:#4ade80}#gps-bar.err{color:#f87171}#dest-btn{color:#000;cursor:pointer;white-space:nowrap;background:#f59e0b;border:none;border-radius:6px;flex-shrink:0;padding:.15rem .6rem;font-size:.72rem;font-weight:700}#panel{background:#1e293b;border-top:1px solid #334155;flex-direction:column;height:230px;display:flex}#tabs{border-bottom:1px solid #334155;flex-shrink:0;display:flex}.tab{text-align:center;cursor:pointer;color:#94a3b8;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.5rem;font-size:.85rem}.tab.active{color:#38bdf8;border-bottom-color:#38bdf8}.tab-panel{flex-direction:column;flex:1;min-height:0;display:none;overflow:hidden}.tab-panel.active{display:flex}#chat-msgs{flex-direction:column;flex:1;gap:.3rem;min-height:0;padding:.5rem .75rem;display:flex;overflow-y:auto}.msg{word-break:break-all;font-size:.85rem;line-height:1.5}.msg .who{margin-right:.4rem;font-weight:700}.msg .ts{color:#64748b;margin-left:.4rem;font-size:.65rem;font-weight:400}#chat-form{border-top:1px solid #334155;flex-shrink:0;gap:.5rem;padding:.5rem;display:flex}#chat-input{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:8px;outline:none;flex:1;padding:.45rem .7rem;font-size:16px}#chat-input:focus{border-color:#38bdf8}#chat-send{color:#0f172a;cursor:pointer;background:#38bdf8;border:none;border-radius:8px;flex-shrink:0;padding:.45rem 1rem;font-weight:700}#call-panel{flex-direction:column;gap:.7rem;padding:.75rem;display:flex;overflow-y:auto}.call-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.call-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}#group-call-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:8px;padding:.5rem 1.2rem;font-size:.9rem;font-weight:700}#group-call-btn.in-call{background:#ef4444}#mute-btn{color:#f1f5f9;cursor:pointer;background:#334155;border:none;border-radius:8px;padding:.5rem .9rem;font-size:.85rem;display:none}#mute-btn.muted{background:#ef4444}.peer-status{flex-wrap:wrap;gap:.4rem;margin-top:.2rem;display:flex}.peer-tag{color:#94a3b8;border:1px solid #334155;border-radius:4px;padding:.2rem .5rem;font-size:.75rem}.peer-tag.in-call{color:#22c55e;border-color:#22c55e}#dest-dialog{z-index:999;background:#0009;justify-content:center;align-items:center;padding:1.5rem;display:none;position:fixed;inset:0}#dest-dialog.open{display:flex}#dest-box{background:#1e293b;border:1px solid #334155;border-radius:12px;flex-direction:column;gap:.75rem;width:100%;max-width:380px;padding:1.25rem;display:flex}#dest-box h3{font-size:1rem}#dest-box p{color:#94a3b8;font-size:.8rem}#dest-url,#dest-name,#dest-coord{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:8px;outline:none;width:100%;padding:.5rem .7rem;font-size:16px}#dest-url:focus,#dest-name:focus,#dest-coord:focus{border-color:#f59e0b}.dest-mode-toggle{border:1px solid #334155;border-radius:8px;gap:0;display:flex;overflow:hidden}.dest-mode-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;flex:1;padding:.4rem;font-size:.8rem}.dest-mode-btn.active{color:#f1f5f9;background:#334155}.dest-dialog-btns{gap:.5rem;display:flex}#dest-confirm{color:#000;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;flex:1;padding:.55rem;font-weight:700}#dest-clear,#dest-cancel{color:#f1f5f9;cursor:pointer;background:#334155;border:none;border-radius:8px;padding:.55rem .9rem;font-size:.85rem}#dest-err{color:#f87171;font-size:.8rem}#create-dialog{z-index:999;background:#0009;justify-content:center;align-items:center;padding:1.5rem;display:none;position:fixed;inset:0}#create-dialog.open{display:flex}#create-box{background:#1e293b;border:1px solid #334155;border-radius:12px;flex-direction:column;gap:.75rem;width:100%;max-width:380px;padding:1.25rem;display:flex}#create-box h3{font-size:1rem}#create-room-name,#create-user-name{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:8px;outline:none;width:100%;padding:.55rem .75rem;font-size:16px}#create-room-name:focus,#create-user-name:focus{border-color:#38bdf8}#create-public-row{color:#f1f5f9;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.88rem;display:flex}#create-public-row input{cursor:pointer;accent-color:#38bdf8;width:16px;height:16px}#create-public-hint{color:#94a3b8;margin-top:-.4rem;margin-left:1.6rem;font-size:.72rem}#create-confirm{color:#0f172a;cursor:pointer;background:#38bdf8;border:none;border-radius:8px;flex:1;padding:.55rem;font-weight:700}#create-confirm:disabled{opacity:.6;cursor:not-allowed}#create-cancel{color:#f1f5f9;cursor:pointer;background:#334155;border:none;border-radius:8px;padding:.55rem .9rem;font-size:.85rem}#create-err{color:#f87171;font-size:.8rem}.car-label,.dest-label{white-space:nowrap;border-radius:4px;padding:2px 7px;font-size:.75rem;font-weight:700;box-shadow:0 1px 4px #0006}.dest-label{color:#000;background:#f59e0b}.av-sm{object-fit:cover;border-radius:50%;flex-shrink:0;width:22px;height:22px}.av-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;display:flex}#rec-btn{color:#fff;cursor:pointer;background:#a855f7;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:700}#rec-btn.recording{background:#ef4444}#rec-list{flex-direction:column;gap:.3rem;margin-top:.4rem;display:flex}.rec-row{background:#0f172a;border:1px solid #334155;border-radius:6px;align-items:center;gap:.4rem;padding:.3rem .5rem;font-size:.75rem;display:flex}.rec-row .rec-time{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.rec-row audio{flex-shrink:0;max-width:140px;height:28px}.rec-row a,.rec-row button{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.15rem .4rem;font-size:.95rem;text-decoration:none}.rec-row a{color:#38bdf8}.rec-row button{color:#f87171}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
