:root{--primary:#4f46e5;--primary-hover:#4338ca;--bg:#f1f5f9;--card-bg:#fff;--text:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000d;--radius:12px;--radius-sm:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,sans-serif;line-height:1.6}button{cursor:pointer;font:inherit;background:0 0;border:none}a{color:inherit;text-decoration:none}.page{flex-direction:column;max-width:480px;min-height:100svh;margin:0 auto;display:flex}.page-center{justify-content:center;align-items:center;gap:1rem}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);justify-content:center;align-items:center;width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:background .15s;display:flex}.btn-primary:hover{background:var(--primary-hover)}.btn-large{padding:1rem 1.5rem;font-size:1.05rem}.btn-ghost{color:var(--text-muted);border-radius:var(--radius-sm);text-align:center;width:100%;margin-top:.5rem;padding:.5rem 1rem;font-size:.9rem}.btn-ghost:hover{background:var(--border)}.btn-small{width:auto;padding:.25rem .75rem;font-size:.85rem}.pwa-banner{background:var(--primary);color:#fff;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.875rem;display:flex}.pwa-banner-text{flex:1}.pwa-banner-btn{color:#fff;border-radius:var(--radius-sm);background:#fff3;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.pwa-banner-close{color:#ffffffb3;padding:.25rem;font-size:1rem;line-height:1}.home-header{background:var(--primary);color:#fff;text-align:center;padding:2rem 1.5rem 1.5rem}.app-logo{letter-spacing:-.5px;font-size:2rem;font-weight:800}.app-tagline{opacity:.85;margin-top:.25rem;font-size:.9rem}.home-main{flex-direction:column;flex:1;gap:1.5rem;padding:1.5rem;display:flex}.qr-section{background:var(--card-bg);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;display:flex}.section-title{font-size:1rem;font-weight:700}.section-desc{color:var(--text-muted);font-size:.85rem;line-height:1.5}.qr-wrapper{border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;padding:1rem}.qr-event-name{color:var(--text-muted);font-size:.85rem}.feature-list{flex-direction:column;gap:.75rem;display:flex}.feature-item{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:.75rem;padding:1rem;display:flex}.feature-icon{flex-shrink:0;margin-top:.1rem;font-size:1.25rem}.feature-title{font-size:.9rem;font-weight:600}.feature-desc{color:var(--text-muted);margin-top:.1rem;font-size:.8rem}.feature-item--install{cursor:pointer;border:1.5px solid var(--primary)}.feature-item--install:active{opacity:.75}.feature-install-arrow{color:var(--primary);flex-shrink:0;font-size:1.5rem;font-weight:300;line-height:1}.room-header{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:1rem;padding:1rem 1rem .75rem;display:flex;position:sticky;top:0}.back-btn{color:var(--primary);flex-shrink:0;padding:.25rem .5rem;font-size:1.25rem}.room-title{font-size:1rem;font-weight:700;line-height:1.3}.room-meta{color:var(--text-muted);font-size:.8rem}.room-main{flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex}.attendee-count-bar{background:var(--card-bg);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.875rem;display:flex}.attendee-count-label{color:var(--text-muted)}.attendee-count-num{color:var(--primary);font-weight:700}.attendee-list{flex-direction:column;gap:.5rem;display:flex}.loading-text{text-align:center;color:var(--text-muted);padding:.5rem;font-size:.875rem}.done-text{text-align:center;color:#16a34a;padding:.5rem;font-size:.875rem;font-weight:600}@keyframes cardAppear{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.attendee-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:box-shadow .15s,transform .15s;animation:.3s both cardAppear;display:flex}.attendee-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.attendee-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.9rem;font-weight:700;display:flex}.attendee-info{flex:1;min-width:0}.attendee-name{font-size:.95rem;font-weight:600}.attendee-role{color:var(--text-muted);margin-top:.1rem;font-size:.8rem}.attendee-company{color:var(--text-muted);font-size:.8rem}.attendee-arrow{color:var(--text-muted);flex-shrink:0;font-size:1.25rem}.modal-overlay{z-index:100;background:#00000073;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border-radius:var(--radius) var(--radius) 0 0;text-align:center;flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:480px;margin:0 auto;padding:2rem 1.5rem 2.5rem;display:flex}.modal-icon{font-size:2rem}.modal-title{margin-top:.25rem;font-size:1.1rem;font-weight:700}.modal-desc{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;line-height:1.6}.detail-header{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex;position:sticky;top:0}.detail-main{flex-direction:column;flex:1;align-items:center;gap:.5rem;padding:2rem 1.5rem;display:flex}.detail-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:.5rem;font-size:1.5rem;font-weight:700;display:flex}.detail-name{font-size:1.4rem;font-weight:800}.detail-role{color:var(--text-muted);font-size:.9rem}.detail-company{color:var(--text-muted);font-size:.875rem}.detail-section{background:var(--card-bg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow);margin-top:1rem;padding:1rem}.detail-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:700}.detail-bio{font-size:.9rem;line-height:1.7}.detail-links{flex-wrap:wrap;gap:.5rem;display:flex}.detail-link{background:var(--bg);color:var(--primary);border:1px solid var(--border);border-radius:999px;padding:.4rem .875rem;font-size:.85rem;font-weight:600;display:inline-block}.locked-section{text-align:center;width:100%;color:var(--text-muted);flex-direction:column;gap:1rem;margin-top:1.5rem;font-size:.9rem;display:flex}.qr-share-btn{background:var(--bg);border:1.5px solid var(--primary);color:var(--primary);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;margin-top:.5rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;display:inline-flex}.qr-share-btn:hover{background:#ede9fe}.modal-label{color:var(--text-muted);text-align:center;font-size:.85rem;font-weight:600}.qr-url{color:var(--text-muted);word-break:break-all;text-align:center;padding:0 .5rem;font-size:.75rem}.my-profile-badge{color:var(--primary);background:#ede9fe;border-radius:999px;margin-bottom:.5rem;padding:.2rem .75rem;font-size:.75rem;font-weight:700}.btn-outline{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-muted);cursor:not-allowed;opacity:.6;background:0 0;justify-content:center;align-items:center;padding:.75rem;font-size:.9rem;display:flex}.demo-link-note{text-align:center;color:var(--text-muted);opacity:.6;margin-top:auto;padding-bottom:1rem;font-size:.78rem}.demo-link{color:var(--text-muted);font-size:inherit;cursor:pointer;text-decoration:underline}.demo-link:hover{opacity:1}
