*{box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{height:100vh}.app-layout{display:flex;flex-direction:column;height:100vh}.app-header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.app-header h1{margin:0;font-size:1.5rem}.home-button{background-color:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.home-button:hover{background-color:#2980b9}.app-main{flex:1;overflow:auto}.home-container{max-width:960px;margin:2rem auto;padding:1rem 2rem 2rem}.hero{text-align:center;margin-bottom:2rem}.hero h1{margin:0}.hero p{margin-top:.5rem;color:#666}.card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem}.card{background:#fff;border:1px solid #e3e3e3;border-radius:10px;padding:1rem;box-shadow:0 2px 8px #0000000d}.card h2{margin-top:0;margin-bottom:.5rem}.card-description{color:#666;margin-bottom:1rem}.card-action{padding:.75rem 1rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer}.card-action:hover{background-color:#218838}.recent-rooms{background:#fff;border:1px solid #e3e3e3;border-radius:10px;padding:1rem}.recent-rooms h3{margin-top:0}.recent-rooms ul{list-style:none;margin:0;padding:0}.recent-rooms li{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:center;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.recent-rooms li:last-child{border-bottom:none}.footer{margin-top:1.5rem;text-align:center;color:#777}.join-room-page,.create-room-page{max-width:500px;margin:2rem auto;padding:2rem}.join-room-page h1{text-align:center;margin-bottom:.5rem}.join-room-page>p{text-align:center;color:#666;margin-bottom:2rem}.share-box{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:.75rem;margin-bottom:1rem}.session-lost-guide{background:#fff4e5;border:1px solid #ffd299;border-radius:6px;padding:.75rem;margin-bottom:1rem}.session-lost-guide h3{margin:0 0 .4rem;color:#8a4b00}.session-lost-guide p{margin:0 0 .5rem;color:#6e3d00}.session-lost-guide ul{margin:0;padding-left:1.2rem;color:#6e3d00}.share-row{display:flex;gap:.5rem}.share-row input{flex:1}.share-copy-button{border:1px solid #ced4da;background:#fff;border-radius:4px;padding:.5rem .75rem;cursor:pointer}.share-copy-button:hover{background:#f2f2f2}.share-status{margin:.5rem 0 0;font-size:.875rem}.qr-box{margin-top:.75rem;text-align:center}.qr-box img{border:1px solid #dee2e6;border-radius:8px;background:#fff;padding:.5rem}.qr-caption{margin:.5rem 0 0;font-size:.85rem;color:#666}.success{color:#198754}.error-text{color:#dc3545}.info-box{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:1rem;margin:1rem 0}.info-box p{margin:0 0 .5rem;font-weight:700}.info-box ul{margin:0;padding-left:1.5rem}.error-page{max-width:500px;margin:2rem auto;padding:2rem;text-align:center}.chat-room-page{display:flex;flex-direction:column;height:100%}.chat-header{background-color:#34495e;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.chat-header h1{margin:0;font-size:1.25rem}.connection-status{font-size:.875rem}.chat-header-actions{display:flex;align-items:center;gap:.75rem}.export-actions{display:flex;gap:.4rem}.export-button{border:1px solid #9fb2c8;background:#fff;color:#2d3e50;border-radius:4px;padding:.35rem .55rem;cursor:pointer;font-size:.8rem}.export-button:hover:not(:disabled){background:#f1f5f9}.export-button:disabled{opacity:.6;cursor:not-allowed}.leave-room-button{background-color:#dc3545;color:#fff;border:none;border-radius:4px;padding:.4rem .8rem;cursor:pointer}.leave-room-button:hover{background-color:#b32d3b}.chat-container{display:flex;flex:1;overflow:hidden}.ws-error-banner{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.6rem 1rem;background:#fff3cd;border-bottom:1px solid #f5c95d;color:#664d03}.ws-reconnect-button{border:1px solid #d9b04f;background:#fff;border-radius:4px;padding:.35rem .6rem;cursor:pointer}.export-error-banner{padding:.6rem 1rem;background:#f8d7da;border-bottom:1px solid #f1aeb5;color:#842029}.ws-reconnect-button:hover{background:#f7f7f7}.participants-sidebar{width:250px;background-color:#f8f9fa;border-right:1px solid #dee2e6;overflow-y:auto}.chat-main{flex:1;display:flex;flex-direction:column}.participant-list{padding:1rem}.participant-list h3{margin:0 0 1rem;font-size:1rem}.participant-list ul{list-style:none;padding:0;margin:0}.participant-item{display:flex;align-items:center;padding:.5rem;margin-bottom:.25rem;border-radius:4px}.participant-item:hover{background-color:#e9ecef}.participant-status{margin-right:.5rem}.message-list{flex:1;overflow-y:auto;padding:1rem;background-color:#fff}.message{margin-bottom:1rem;padding:.75rem;border-radius:8px;max-width:70%}.system-message{text-align:center;color:#6c757d;font-size:.875rem;max-width:100%;background-color:transparent;padding:.5rem}.own-message{margin-left:auto;background-color:#007bff;color:#fff}.other-message{margin-right:auto;background-color:#e9ecef;color:#212529}.message-header{display:flex;justify-content:space-between;margin-bottom:.25rem;font-size:.875rem}.message-nickname{font-weight:700}.message-time{opacity:.7;font-size:.75rem}.message-content{word-wrap:break-word}.message-input{display:flex;padding:1rem;background-color:#f8f9fa;border-top:1px solid #dee2e6}.message-input input{flex:1;padding:.75rem;border:1px solid #ced4da;border-radius:4px;margin-right:.5rem}.message-input button{padding:.75rem 1.5rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.message-input button:hover:not(:disabled){background-color:#0056b3}.message-input button:disabled{background-color:#6c757d;cursor:not-allowed}form{display:flex;flex-direction:column;gap:1rem}form>div{display:flex;flex-direction:column}label{margin-bottom:.25rem;font-weight:500}input,select{padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem}button[type=submit]{padding:.75rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;margin-top:.5rem}button[type=submit]:hover:not(:disabled){background-color:#218838}button[type=submit]:disabled{background-color:#6c757d;cursor:not-allowed}.error{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:4px}@media(max-width:768px){.chat-container{flex-direction:column}.participants-sidebar{width:100%;max-height:150px;border-right:none;border-bottom:1px solid #dee2e6}.message{max-width:85%}.home-container,.create-room-page,.join-room-page{padding:1rem}.card-grid{grid-template-columns:1fr}.recent-rooms li{grid-template-columns:1fr;gap:.25rem}.app-header{padding:.75rem 1rem}.header-content h1{font-size:1.25rem}}@media(max-width:480px){.message-input input{font-size:16px}.participant-list,.message-list{padding:.5rem}}
