*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#f8f9fa;color:#1a1a1a;line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column;padding-bottom:64px}.header{background:#fff;border-bottom:1px solid #e8e8e8;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.logo{font-size:1.1rem;font-weight:700;text-decoration:none;color:#1a1a1a}.header-actions{display:flex;align-items:center;gap:.75rem}.user-email{font-size:.8rem;color:#888;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-link{text-decoration:none;color:#555;font-size:.9rem;font-weight:500;background:none;border:none;cursor:pointer;padding:.25rem 0}.main{flex:1;width:100%;max-width:600px;margin:0 auto;padding:0}.main.no-bottom-nav{padding-bottom:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e8e8e8;display:flex;justify-content:space-around;align-items:center;height:64px;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:#999;flex:1;height:100%;transition:color .15s}.bottom-nav-item.active{color:#1a1a1a}.bottom-nav-icon{font-size:1.4rem;line-height:1}.bottom-nav-label{font-size:.65rem;font-weight:500}.home-page{padding-bottom:1rem}.home-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 1.25rem 1.5rem;text-align:center}.home-title{font-size:1.75rem;font-weight:800;line-height:1.2;margin-bottom:.5rem}.home-subtitle{font-size:.95rem;opacity:.9;margin-bottom:1.25rem}.home-search{display:flex;gap:.5rem;max-width:500px;margin:0 auto}.home-search-input{flex:1;padding:.85rem 1rem;border:none;border-radius:12px;font-size:1rem;background:#fffffff2;color:#333;outline:none}.home-search-input::placeholder{color:#999;font-size:.9rem}.home-search-btn{padding:.85rem 1rem;border:none;border-radius:12px;background:#ffffff40;color:#fff;font-size:1.2rem;cursor:pointer}.home-section{padding:1.25rem 1rem;overflow:visible}.home-section-title{font-size:1.1rem;font-weight:700;margin-bottom:.75rem;color:#1a1a1a}.category-chips{display:flex;gap:.6rem;overflow-x:auto;overflow-y:hidden;padding:.25rem 1rem .75rem;scrollbar-width:none;-ms-overflow-style:none;margin:0 -1rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.category-chips::-webkit-scrollbar{display:none}.category-chip{flex-shrink:0;padding:.6rem 1rem;border:none;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;color:#333;transition:transform .1s,opacity .15s;scroll-snap-align:start}.category-chip:active{transform:scale(.95);opacity:.8}.highlight-list{display:flex;flex-direction:column;gap:.75rem}.highlight-card{background:#fff;border-radius:14px;padding:1rem;border:1px solid #e8e8e8;cursor:pointer;transition:transform .15s,box-shadow .15s}.highlight-card:active{transform:scale(.98)}.highlight-content{display:flex;flex-direction:column;gap:.35rem}.highlight-category{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:#667eea;align-self:flex-start}.highlight-title{font-size:1rem;font-weight:700;line-height:1.3;color:#1a1a1a}.highlight-meta{font-size:.8rem;color:#666;display:flex;gap:.75rem;flex-wrap:wrap}.highlight-price{font-size:.85rem;font-weight:700;color:#2a7;margin-top:.2rem}.highlight-price.free{color:#27c}.sticky-search{position:sticky;top:52px;background:#f8f9fa;padding:.75rem 1rem;z-index:50;border-bottom:1px solid #e8e8e8}.events-search-form{display:flex;gap:.5rem}.events-search-input{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:12px;font-size:1rem;background:#fff;outline:none}.events-search-input:focus{border-color:#667eea}.events-search-btn{padding:.75rem 1rem;border:none;border-radius:12px;background:#1a1a1a;color:#fff;font-size:1.1rem;cursor:pointer}.category-filter-bar{display:flex;gap:.4rem;overflow-x:auto;overflow-y:hidden;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e8e8e8;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.category-filter-bar::-webkit-scrollbar{display:none}.category-filter-chip{flex-shrink:0;padding:.45rem .85rem;border:1px solid #e0e0e0;border-radius:18px;font-size:.8rem;font-weight:500;cursor:pointer;background:#fff;color:#555;transition:all .15s}.category-filter-chip.active{background:#1a1a1a;color:#fff;border-color:#1a1a1a}.page-title{font-size:1.25rem;font-weight:700;padding:1rem 1rem .25rem}.result-count{font-size:.85rem;color:#888;padding:0 1rem .5rem}.event-list{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem 1rem}.event-card{background:#fff;border-radius:14px;padding:1rem;border:1px solid #e8e8e8;text-decoration:none;color:inherit;display:block;transition:transform .1s}.event-card:active{transform:scale(.98)}.event-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.35rem}.event-title{font-size:.95rem;font-weight:700;color:#1a1a1a;line-height:1.3;flex:1}.event-category{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:.15rem .5rem;border-radius:4px;background:#f0f0f0;color:#666;white-space:nowrap}.event-meta{font-size:.8rem;color:#666;display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.35rem}.event-description{font-size:.85rem;color:#555;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.35rem}.event-price{font-size:.85rem;font-weight:700;color:#2a7}.event-price.free{color:#27c}.similarity-badge{font-size:.75rem;color:#667eea;font-weight:600;margin-top:.25rem}.detail-page{background:#fff;min-height:100vh;padding:1rem}.detail-page h1{font-size:1.3rem;font-weight:800;margin-bottom:.75rem;line-height:1.3}.detail-meta{color:#555;font-size:.9rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.35rem}.detail-description{line-height:1.65;margin-bottom:1.5rem;font-size:.95rem;color:#333}.btn{padding:.75rem 1.25rem;border-radius:12px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s;min-height:48px}.btn:hover,.btn:active{opacity:.85}.btn-primary{background:#1a1a1a;color:#fff}.btn-secondary{background:#f0f0f0;color:#333}.btn-success{background:#2a7;color:#fff}.btn-danger{background:#d44;color:#fff}.login-form{background:#fff;border-radius:16px;padding:2rem 1.5rem;margin:2rem 1rem;border:1px solid #e8e8e8}.login-form h2{margin-bottom:1.25rem;font-size:1.4rem}.login-form input{width:100%;padding:.85rem 1rem;margin-bottom:.75rem;border:1px solid #ddd;border-radius:12px;font-size:1rem;outline:none}.login-form input:focus{border-color:#667eea}.login-form button{width:100%;margin-top:.5rem}.error-msg{color:#d44;font-size:.85rem;margin-bottom:.75rem}.empty-state{text-align:center;padding:3rem 1.5rem;color:#888;font-size:.95rem}.loading{text-align:center;padding:2rem;color:#888}@media (min-width: 600px){.home-hero{padding:3rem 2rem 2rem;border-radius:0 0 20px 20px;margin:0 .5rem}.home-title{font-size:2.25rem}.home-section{padding:1.5rem}.main{max-width:600px}}
