🎨
styles.css
📝 Css Ctrl+S: Save • Ctrl+R: Run • Ctrl+F: Find
/* =========================== Global & Reset =========================== */ * { box-sizing: border-box; } html, body { width: 100%; max-width: 100%; overflow-x: hidden; /* Prevent horizontal scroll */ } body { font-family: system-ui, sans-serif; } /* Media defaults to avoid intrinsic overflow */ img, video, canvas, svg, iframe, table { max-width: 100%; height: auto; } /* =========================== Scrollbars =========================== */ .scrollbar-thin::-webkit-scrollbar { height: 8px; width: 8px; } .scrollbar-thin::-webkit-scrollbar-thumb { background: #9ca3af; border-radius: 8px; } .scrollbar-thin::-webkit-scrollbar-track { background: transparent; } /* =========================== Mobile tweaks =========================== */ @media (max-width: 640px) { .mobile-padding { padding-left: 0.5rem; padding-right: 0.5rem; } .mobile-text { font-size: 0.875rem; } .mobile-compact { gap: 0.25rem; } .mobile-tabs { flex-direction: column; } .mobile-tab-btn { flex: none; width: 100%; text-align: center; } .code-container { margin: 0.5rem 0; } .code-header { padding: 0.25rem 0.5rem; font-size: 0.625rem; } .code-content { padding: 0.5rem; font-size: 0.75rem; } .copy-btn { padding: 0.125rem 0.25rem; font-size: 0.625rem; } .collapse-icon { font-size: 0.625rem; min-width: 0.75rem; } .delete-btn { font-size: 0.625rem; padding: 0.125rem 0.25rem; } .code-header { padding: 0.5rem; min-height: 2rem; } .code-content { padding: 0.5rem; font-size: 0.75rem; min-height: 1.5rem; } .copy-btn { min-height: 1.5rem; min-width: 2rem; } .delete-btn { min-height: 1.5rem; min-width: 1.5rem; } } /* =========================== Transcript & bubbles =========================== */ .message-wrapper { position: relative; display: flex; gap: .5rem; min-width: 0; /* Important for flex shrink */ } .bubble { max-width: 95%; border-radius: 1rem; padding: .5rem .75rem; box-shadow: 0 1px 2px rgba(0,0,0,.05); border: 1px solid rgba(0,0,0,.08); min-width: 0; } @media (min-width: 640px) { .bubble { max-width: 85%; } } /* Make sure content doesn’t overflow */ .bubble, .bubble * { overflow-wrap: anywhere; word-break: break-word; } /* =========================== Code block UI (for chat-rendered <pre><code>) =========================== */ .code-container { position: relative; background: #1f2937; border-radius: 0.75rem; overflow: hidden; margin: 1rem 0; max-width: 100%; } .code-header { background: #374151; padding: 0.5rem 1rem; font-size: 0.75rem; color: #d1d5db; border-bottom: 1px solid #4b5563; display: flex; justify-content: space-between; align-items: center; user-select: none; -webkit-user-select: none; -webkit-tap-highlight-color: transparent; } .code-header:hover { background: #4b5563; } .code-header-left { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; flex: 1; min-width: 0; } .code-header-right { display: flex; align-items: center; gap: 0.5rem; } .collapse-icon { transition: transform 0.2s; font-size: 0.75rem; min-width: 1rem; text-align: center; } .collapse-icon.collapsed { transform: rotate(-90deg); } .copy-btn, .stitch-btn { background: #6b7280; color: white; border: none; padding: 0.25rem 0.5rem; border-radius: 0.25rem; font-size: 0.75rem; cursor: pointer; transition: background-color 0.2s; margin-left: 0.25rem; } .copy-btn:hover, .stitch-btn:hover { background: #9ca3af; } .stitch-btn { background: #059669; } .stitch-btn:hover { background: #047857; } .stitch-btn.added { background: #dc2626; } .stitch-btn.added:hover { background: #b91c1c; } .code-content { padding: 1rem; font-family: 'Courier New', monospace; font-size: 0.875rem; line-height: 1.5; color: #e5e7eb; transition: max-height 0.3s ease, opacity 0.2s ease; min-height: 2rem; max-width: 100%; overflow-x: auto; } /* Collapse behavior */ .code-content.collapsed { max-height: 0 !important; padding-top: 0; padding-bottom: 0; opacity: 0; overflow: hidden; } /* Pre tags should wrap text */ pre, .prose pre { white-space: pre-wrap; word-break: break-word; max-width: 100%; } /* =========================== Delete buttons =========================== */ .message-actions { position: absolute; top: 0.25rem; right: 0.25rem; opacity: 0; transition: opacity 0.2s; z-index: 10; } .message-wrapper:hover .message-actions { opacity: 1; } @media (max-width: 640px) { .message-actions { opacity: 0.7; } .message-wrapper:active .message-actions { opacity: 1; } } .delete-btn { background: #ef4444; color: white; border: none; padding: 0.25rem 0.5rem; border-radius: 0.25rem; font-size: 0.75rem; cursor: pointer; transition: background-color 0.2s; } .delete-btn:hover { background: #dc2626; } /* =========================== Overlays =========================== */ #stitcherOverlay > div > div[role="dialog"], #settingsOverlay > div > div[role="dialog"] { width: 100%; max-width: min(100vw, 64rem); /* Fit mobile viewport */ } /* =========================== Debug area =========================== */ #debugArea { display: block; max-width: 100%; overflow-x: auto; } /* =========================== Tables in prose =========================== */ .prose table { display: block; width: 100%; overflow-x: auto; }