*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--tint-color: #6366f1;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#1f2937;background:#f9fafb}body{display:flex;flex-direction:column;align-items:center;min-height:100svh;padding:2rem 1rem;padding-top:0}.install-banner{width:100%;max-width:640px;margin-block:1rem;padding:.75rem 1rem;border-radius:8px;font-weight:600;font-size:.9rem;text-align:center;transition:background .3s,color .3s}.install-banner--installed{background:#d1fae5;color:#065f46}.install-banner--was-installed{background:#a7f3d0;color:#064e3b;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.install-banner__launch{flex-shrink:0;padding:.35rem 1rem;font-size:.8rem;font-weight:600;border:none;border-radius:6px;background:#065f46;color:#fff;cursor:pointer;transition:background .15s}.install-banner__launch:hover{background:#047857}.install-banner__actions{display:flex;gap:.5rem}.install-banner__reset{flex-shrink:0;padding:.35rem .75rem;font-size:.8rem;font-weight:500;border:1px solid #6b7280;border-radius:6px;background:transparent;color:#6b7280;cursor:pointer;transition:background .15s,color .15s}.install-banner__reset:hover{background:#6b7280;color:#fff}.install-banner--not-installed{background:#fee2e2;color:#991b1b;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.install-banner__guide{flex-shrink:0;padding:.35rem 1rem;font-size:.8rem;font-weight:600;border:none;border-radius:6px;background:#991b1b;color:#fff;cursor:pointer;transition:background .15s}.install-banner__guide:hover{background:#b91c1c}main{max-width:640px;width:100%}h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;color:#111827}p{line-height:1.6;margin-bottom:1.5rem;color:#4b5563}code{background:#e5e7eb;padding:.125rem .375rem;border-radius:4px;font-size:.875em}a{color:var(--tint-color)}.controls{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.controls button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;transition:background .15s,border-color .15s}.controls button:hover{background:#f3f4f6;border-color:var(--tint-color)}.controls button:active{background:#e5e7eb}section{margin-bottom:1.5rem}h2{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:#374151}pre{background:#1f2937;color:#e5e7eb;padding:1rem;border-radius:8px;font-size:.8125rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word}#props-output{min-height:3rem}#events-output{min-height:4rem;max-height:16rem;overflow-y:auto}.guide-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#00000080;align-items:center;justify-content:center;padding:1rem}.guide-overlay--open{display:flex}.guide-modal{background:#fff;border-radius:12px;max-width:560px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.guide-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.guide-header h2{margin:0;font-size:1.1rem}.guide-close{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;color:#6b7280}.guide-close:hover{background:#f3f4f6;color:#111827}.guide-tabs{display:flex;border-bottom:1px solid #e5e7eb}.guide-tab{flex:1;padding:.6rem .5rem;font-size:.85rem;font-weight:600;border:none;background:none;cursor:pointer;color:#6b7280;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.guide-tab:hover{color:#374151}.guide-tab--active{color:var(--tint-color);border-bottom-color:var(--tint-color)}.guide-content{padding:1rem 1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.guide-card{display:flex;gap:.75rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:8px;background:#fafafa}.guide-card__badge{flex-shrink:0;width:2.25rem;height:2.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff}.guide-card__body{flex:1;min-width:0}.guide-card__browser{display:block;font-size:.9rem;margin-bottom:.3rem}.guide-card__steps{padding-left:1.2rem;font-size:.8rem;line-height:1.6;color:#4b5563}.guide-card__steps li::marker{font-weight:600;color:var(--tint-color)}#app-container{width:100%;flex:1;display:flex;margin-top:.5rem}#app-iframe{width:100%;border:none;border-radius:8px;min-height:75vh}body:has(#app-container:not([hidden])){padding-bottom:1rem}
