*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-dark:#0f172a;--color-text:#1e293b;--color-text-light:#64748b;--color-border:#e2e8f0;--color-bg:#f8fafc;--color-white:#fff;--font-sans:"Noto Sans JP", "Inter", sans-serif}html,body{height:100%}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.auth-page{background-color:var(--color-dark);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--color-white);border-radius:16px;width:100%;max-width:400px;padding:40px 36px}.auth-logo{color:var(--color-primary);letter-spacing:-.02em;margin-bottom:8px;font-size:1.4rem;font-weight:800}.auth-title{color:var(--color-text);margin-bottom:28px;font-size:1.3rem;font-weight:700}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--color-text);font-size:.85rem;font-weight:600}.auth-field input,.auth-field select{border:1px solid var(--color-border);border-radius:8px;outline:none;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.auth-field input:focus,.auth-field select:focus{border-color:var(--color-primary)}.auth-error{color:#ef4444;font-size:.85rem}.auth-submit{background-color:var(--color-primary);color:#fff;border:none;border-radius:8px;margin-top:4px;padding:12px;font-size:.95rem;font-weight:600;transition:background-color .2s}.auth-submit:hover{background-color:var(--color-primary-dark)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;color:var(--color-text-light);margin-top:20px;font-size:.85rem}.auth-link a{color:var(--color-primary);font-weight:600}.dt-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dt-modal{color:#fff;background:#1e293b;border-radius:14px;flex-direction:column;width:560px;max-width:95vw;display:flex;overflow:hidden}.dt-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.dt-header h2{font-size:1rem;font-weight:700}.dt-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1rem}.dt-close:hover{color:#fff}.dt-body{gap:20px;padding:20px;display:flex}.dt-preview{flex-shrink:0;width:240px}.dt-video{aspect-ratio:4/3;object-fit:cover;background:#0f172a;border-radius:8px;width:100%}.dt-controls{flex-direction:column;flex:1;gap:16px;display:flex}.dt-field{flex-direction:column;gap:6px;display:flex}.dt-field label{color:#ffffff8c;font-size:.8rem}.dt-field select{color:#fff;background:#ffffff12;border:1px solid #ffffff26;border-radius:6px;outline:none;width:100%;padding:7px 10px;font-size:.8rem}.dt-field select:focus{border-color:#2563eb}.dt-field select option{background:#1e293b}.dt-meter{background:#ffffff1a;border-radius:3px;height:6px;overflow:hidden}.dt-meter-bar{background:#22c55e;border-radius:3px;height:100%;transition:width 50ms}.dt-meter-label{color:#ffffff59;font-size:.7rem}.dt-checking{text-align:center;color:#ffffff80;padding:40px 20px;font-size:.875rem}.dt-denied{flex-direction:column;gap:12px;padding:20px 24px;display:flex}.dt-denied-title{color:#f87171;font-size:.95rem;font-weight:700}.dt-denied-desc{color:#ffffffb3;font-size:.85rem;line-height:1.6}.dt-denied-steps{color:#fffc;padding-left:20px;font-size:.85rem;line-height:2}.dt-denied-steps strong{color:#fff}.dt-denied-img{border-radius:6px;max-width:100%}.dt-retry-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;align-self:flex-start;padding:8px 20px;font-size:.875rem;font-weight:600}.dt-retry-btn:hover{background:#1d4ed8}.dt-footer{border-top:1px solid #ffffff14;justify-content:flex-end;padding:14px 20px;display:flex}.dt-btn-close{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:8px 24px;font-size:.875rem;font-weight:600}.dt-btn-close:hover{background:#ffffff2e}.lobby{flex-direction:column;min-height:100vh;display:flex}.lobby-header{background-color:var(--color-dark);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.lobby-logo{color:#fff;letter-spacing:-.02em;font-size:1.2rem;font-weight:800}.lobby-user{color:#ffffffb3;align-items:center;gap:12px;font-size:.875rem;display:flex}.device-test-btn{color:#ffffffd9;background:#ffffff14;border:1px solid #fff3;border-radius:6px;padding:6px 14px;font-size:.8rem;transition:background .2s}.device-test-btn:hover{background:#ffffff29}.logout-btn{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:6px 14px;font-size:.8rem;transition:background .2s}.logout-btn:hover{background:#fff3}.lobby-main{flex-direction:column;flex:1;gap:40px;width:100%;max-width:800px;margin:0 auto;padding:40px 24px;display:flex}.lobby-create h2,.lobby-rooms h2{margin-bottom:16px;font-size:1.1rem;font-weight:700}.create-form{gap:12px;display:flex}.create-form input{border:1px solid var(--color-border);border-radius:8px;outline:none;flex:1;padding:10px 14px;font-size:.95rem}.create-form input:focus{border-color:var(--color-primary)}.create-form button{background-color:var(--color-primary);color:#fff;white-space:nowrap;border:none;border-radius:8px;padding:10px 20px;font-weight:600}.create-form button:hover{background-color:var(--color-primary-dark)}.room-list{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.room-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.room-info{flex-direction:column;gap:4px;display:flex}.room-name{font-weight:700}.room-host,.room-count{color:var(--color-text-light);font-size:.8rem}.join-btn{background-color:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:8px 20px;font-size:.875rem;font-weight:600}.join-btn:hover{background-color:var(--color-primary-dark)}.refresh-btn{border:1px solid var(--color-border);color:var(--color-text-light);background:0 0;border-radius:6px;padding:8px 16px;font-size:.8rem}.refresh-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.empty{color:var(--color-text-light);font-size:.9rem}.error{color:#ef4444;font-size:.875rem}.admin-link-btn{color:#94a3b8;background:#1e293b;border:1px solid #334155;border-radius:6px;padding:7px 14px;font-size:.8rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.admin-link-btn:hover{color:#fff;border-color:#64748b}.room{color:#fff;background-color:#0f172a;flex-direction:row;display:flex;position:fixed;inset:0;overflow:hidden}.room-videos{flex-direction:column;flex:1;gap:16px;min-width:0;min-height:0;padding:16px;display:flex;overflow:hidden}.video-grid{flex:1;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-content:start;gap:12px;min-height:0;display:grid;overflow-y:auto}.video-tile{aspect-ratio:16/9;background-color:#1e293b;border-radius:10px;justify-self:center;width:min(100%,177.778vh - 195.556px);position:relative;overflow:hidden}.video-tile video{object-fit:cover;width:100%;height:100%}.video-tile--local{border:2px solid var(--color-primary,#2563eb)}.video-tile--speaking{animation:.8s ease-in-out infinite alternate speaking-pulse}@keyframes speaking-pulse{0%{box-shadow:0 0 0 3px #22c55e,0 0 8px #22c55e55}to{box-shadow:0 0 0 3px #4ade80,0 0 16px #22c55e99}}.video-label{background:#0009;border-radius:4px;padding:2px 8px;font-size:.75rem;position:absolute;bottom:8px;left:8px}.room-controls-wrap{position:relative}.room-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:8px 0;display:flex}.ctrl-btn{color:#fff;white-space:nowrap;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:10px 16px;font-size:.875rem;font-weight:600;transition:background .2s}.ctrl-btn:hover{background:#fff3}.ctrl-btn--off{background:#ef44444d;border-color:#ef444480}.ctrl-btn--leave{background:#ef4444;border-color:#ef4444}.ctrl-btn--leave:hover{background:#dc2626}.ctrl-btn--active{background:#fff3;border-color:#fff6}.ctrl-btn--chat-toggle{display:none}.device-panel{z-index:10;background:#1e293b;border:1px solid #ffffff26;border-radius:10px;flex-direction:column;gap:10px;width:min(360px,100vw - 32px);padding:12px 16px;display:flex;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 -4px 24px #00000080}.device-row{grid-template-columns:80px 1fr;align-items:center;gap:8px;display:grid}.device-row label{color:#fff9;white-space:nowrap;font-size:.8rem}.device-row select{color:#fff;background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;outline:none;width:100%;padding:5px 8px;font-size:.8rem}.device-row select:focus{border-color:var(--color-primary,#2563eb)}.device-row select option{color:#fff;background:#1e293b}.device-current{display:none}.device-none{color:#ffffff59;font-size:.8rem}.room-chat{background:#1e293b;border-left:1px solid #ffffff14;flex-direction:column;flex-shrink:0;width:300px;min-height:0;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid #ffffff14;padding:16px;font-size:.875rem;font-weight:700}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.chat-msg{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.chat-msg--me{align-items:flex-end}.chat-text{word-break:break-word;background:#ffffff1a;border-radius:8px;max-width:220px;padding:6px 10px;font-size:.85rem}.chat-msg--me .chat-text{background:var(--color-primary,#2563eb)}.chat-sender{color:#ffffff80;margin-bottom:2px;font-size:.7rem}.chat-time{color:#fff6;font-size:.7rem}.chat-msg--history .chat-text{opacity:.7;border-left:2px solid #fff3;padding-left:8px}.chat-input{border-top:1px solid #ffffff14;gap:8px;padding:12px;display:flex}.chat-input input{color:#fff;background:#ffffff14;border:1px solid #ffffff1a;border-radius:6px;outline:none;flex:1;padding:8px 12px;font-size:.875rem}.chat-input input:focus{border-color:var(--color-primary,#2563eb)}.chat-input button{background:var(--color-primary,#2563eb);color:#fff;border:none;border-radius:6px;padding:8px 12px;font-size:.8rem;font-weight:600}.room-loading,.room-error{color:#fff;background:#0f172a;justify-content:center;align-items:center;gap:16px;height:100vh;display:flex}@media (width<=639px){.room{flex-direction:column}.room-videos{flex:1;gap:8px;padding:8px}.video-grid{grid-template-columns:1fr}.video-tile{width:100%}.ctrl-btn{padding:8px 10px;font-size:.8rem}.ctrl-btn--chat-toggle{align-items:center;display:inline-flex}.room-chat{border-top:1px solid #ffffff14;border-left:none;flex-shrink:0;width:100%;height:240px}.device-panel{width:auto;left:8px;right:8px;transform:none}}.admin{color:#0f172a;background:#f8fafc;min-height:100vh}.admin-header{color:#fff;background:#0f172a;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.admin-logo{align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:flex}.admin-badge{background:#2563eb;border-radius:12px;padding:2px 8px;font-size:.7rem;font-weight:600}.admin-header-actions{gap:8px;display:flex}.admin-main{flex-direction:column;gap:32px;max-width:960px;margin:0 auto;padding:32px 16px;display:flex}.admin-error{color:#dc2626;background:#fee2e2;border-radius:8px;padding:12px 16px;font-size:.875rem}.admin-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.admin-section-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.admin-section-header h2{margin:0;font-size:1rem;font-weight:700}.admin-section-header-right{align-items:center;gap:8px;display:flex}.admin-count{color:#64748b;font-size:.8rem}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table th{text-align:left;color:#64748b;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px 16px;font-size:.75rem;font-weight:600}.admin-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table-row--self td{background:#f0f9ff}.admin-self-label{color:#2563eb;margin-left:6px;font-size:.7rem}.admin-email{color:#64748b;font-size:.8rem}.admin-date{color:#64748b;white-space:nowrap;font-size:.8rem}.admin-empty{text-align:center;color:#94a3b8;padding:32px!important}.admin-role-badge{border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.admin-role-badge--admin{color:#1d4ed8;background:#dbeafe}.admin-role-badge--host{color:#15803d;background:#dcfce7}.admin-role-badge--guest{color:#475569;background:#f1f5f9}.admin-status-badge{border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.admin-status-badge--active{color:#15803d;background:#dcfce7}.admin-status-badge--ended{color:#94a3b8;background:#f1f5f9}.admin-btn{cursor:pointer;border:none;border-radius:6px;padding:7px 14px;font-size:.875rem;font-weight:600;transition:opacity .15s}.admin-btn:hover{opacity:.85}.admin-btn--secondary{color:#0f172a;background:#e2e8f0}.admin-btn--ghost{color:#94a3b8;background:0 0;border:1px solid #334155}.admin-btn--danger{color:#fff;background:#ef4444}.admin-btn--sm{padding:4px 10px;font-size:.8rem}.admin-select{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:4px 8px;font-size:.8rem}.admin-select:disabled{opacity:.4;cursor:not-allowed}.admin-create-form{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 20px}.admin-create-fields{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-input{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;flex:1;min-width:140px;padding:7px 10px;font-size:.875rem}.admin-input:focus{border-color:#2563eb}.admin-create-error{color:#dc2626;margin-top:8px;font-size:.8rem}.admin-btn--primary{color:#fff;white-space:nowrap;background:#2563eb}@media (width<=639px){.admin-header{padding:0 16px}.admin-main{gap:16px;padding:16px 12px}.admin-table th,.admin-table td{padding:10px 12px}}
