*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,sans-serif;background-color:#0d1117;color:#c9d1d9;height:100vh;width:100vw;overflow:hidden}.app-container{display:grid;grid-template-rows:60px 1fr 80px;grid-template-areas:"header" "main" "controls";height:100vh;width:100vw;background-color:#161b22}.app-header{grid-area:header;background-color:#21262d;padding:15px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #30363d}.app-header h1{font-size:1.4rem;color:#58a6ff}.status-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:16px;font-size:.9em}.status-dot{width:10px;height:10px;border-radius:50%}.status-indicator.connected{background-color:#2d3748;color:#48bb78}.status-indicator.connected .status-dot{background-color:#48bb78}.status-indicator.disconnected{background-color:#4a5568;color:#f56565}.status-indicator.disconnected .status-dot{background-color:#f56565}.status-indicator.connecting{background-color:#4a5568;color:#ed8936}.status-indicator.connecting .status-dot{background-color:#ed8936;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.main-content-area{grid-area:main;display:grid;grid-template-columns:1fr 1fr;overflow:hidden}.video-preview-area{background-color:#000;display:flex;justify-content:center;align-items:center;border-right:1px solid #30363d}.video-element{max-width:100%;max-height:100%;object-fit:contain}.communication-area{display:grid;grid-template-rows:1fr 80px;background-color:#161b22}.messages-container{padding:15px;max-height:calc(100vh - 200px);overflow-y:auto}.message-list{display:flex;flex-direction:column;gap:12px}.message-item{padding:12px;border-radius:8px;max-width:75%;word-wrap:break-word;transition:transform .2s}.message-item:hover{transform:scale(1.02)}.message-item.sender-user{background-color:#238636;color:#fff;align-self:flex-end}.message-item.sender-gemini{background-color:#30363d;color:#c9d1d9;align-self:flex-start}.message-item audio{max-width:250px;border-radius:5px}.message-item .status-text,.message-item .error-text{color:#c9d1d9;font-style:italic}.text-input-container{padding:15px;background-color:#21262d;border-top:1px solid #30363d;display:flex;align-items:center}.text-input-container form{display:flex;width:100%;gap:10px}.text-input-container input[type=text]{flex-grow:1;padding:12px;border-radius:20px;background-color:#0d1117;color:#c9d1d9;border:1px solid #30363d;outline:none;font-size:1rem;transition:border-color .2s}.text-input-container input[type=text]:focus{border-color:#58a6ff}.text-input-container input:disabled{background-color:#2d3748;cursor:not-allowed}.text-input-container button{padding:12px 20px;background-color:#238636;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:1rem;transition:background-color .2s}.text-input-container button:hover:not(:disabled){background-color:#2ea043}.text-input-container button:disabled{background-color:#4a5568;cursor:not-allowed}.controls-section{grid-area:controls;padding:15px;background-color:#21262d;border-top:1px solid #30363d;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}.controls-section select,.controls-section button{padding:12px 15px;font-size:1rem;border:none;border-radius:20px;background-color:#0d1117;color:#c9d1d9;border:1px solid #30363d;transition:background-color .2s,transform .2s}.controls-section select:disabled,.controls-section button:disabled{background-color:#2d3748;cursor:not-allowed}.controls-section button:hover:not(:disabled){background-color:#2ea043;transform:scale(1.03)}.controls-section button:last-of-type{background-color:#f56565}.controls-section button:last-of-type:hover:not(:disabled){background-color:#dc2626}.flip-btn{background-color:#6b46c1;transition:background-color .2s,transform .2s}.flip-btn:hover:not(:disabled){background-color:#805ad5;transform:rotate(10deg)}@media (max-width: 768px){.app-container{grid-template-rows:auto 80px 1fr;grid-template-areas:"header" "controls" "main"}.main-content-area{grid-template-columns:1fr;grid-template-rows:40vh 60vh}.video-preview-area{height:auto;border-right:none;border-bottom:1px solid #30363d}.communication-area{height:auto}.messages-container{max-height:calc(60vh - 150px)}.controls-section{flex-direction:row;gap:15px}.controls-section select,.controls-section button{width:90%;font-size:1.1rem}}.canvas-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.canvas-container{background-color:#21262d;border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:15px;max-width:90%;max-height:90%}.canvas-container canvas{border:2px solid #30363d;background-color:#000;width:100%;max-width:600px;height:400px;touch-action:none}.canvas-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}.canvas-controls button{padding:10px 20px;border-radius:20px;border:none;background-color:#238636;color:#fff;cursor:pointer;transition:background-color .2s}.canvas-controls button:hover:not(:disabled){background-color:#2ea043}.canvas-controls button:disabled{background-color:#4a5568;cursor:not-allowed}.canvas-controls button:last-child{background-color:#f56565}.canvas-controls button:last-child:hover:not(:disabled){background-color:#dc2626}.canvas-controls span{color:#c9d1d9;font-size:1rem;flex-grow:1;text-align:center}.controls-section{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}.controls-section button:nth-child(4){background-color:#d69e2e}.controls-section button:nth-child(4):hover:not(:disabled){background-color:#f6ad55}@media (max-width: 768px){.canvas-container canvas{height:300px}.canvas-controls{flex-direction:column;align-items:stretch}.canvas-controls button,.canvas-controls span{width:100%;text-align:center}.controls-section{flex-direction:column;align-items:stretch}.controls-section select,.controls-section button{width:100%}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#161b22;color:#f56565;text-align:center;padding:20px}.error-boundary h2{font-size:1.8rem;margin-bottom:10px}.error-boundary p{font-size:1.2rem;margin-bottom:20px}.error-boundary button{padding:10px 20px;background-color:#238636;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:1rem}.error-boundary button:hover{background-color:#2ea043}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
