:root{--primary:#19a66a;--primary-dark:#087246;--text-strong:#162019;--text:#35433b;--text-muted:#64736b;--text-subtle:#8a9890;--control-bg:#f0f5f2;--soft-shadow:0 10px 30px #19533412;--card-shadow:0 18px 50px #1953341a;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8faf8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;margin:0}button,input,select,textarea{font:inherit}button:focus-visible,a:focus-visible{outline-offset:3px;outline:3px solid #19a66a57}#root{min-height:100svh}.app-shell{background:#f8fafc;min-height:100svh}.list-page{width:min(1600px,100%);margin:0 auto;padding:0 32px 32px}.topbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:24px;min-height:70px;margin:0 -32px;padding:0 32px;display:flex}.brand{color:#0f172a;align-items:center;gap:30px;min-width:0;text-decoration:none;display:inline-flex}.brand img{object-fit:contain;width:132px;height:auto;display:block}.brand span{color:#0f172a;font-size:15px;font-weight:750;line-height:1.2}.filter-select,.filter-options button,.clear-filters,.done-filters,.empty-state button,.pagination button{color:#0f172a;font:inherit;cursor:pointer;background:#fff;border:1px solid #dbe3ee;transition:transform .16s,border-color .16s,background .16s,color .16s,box-shadow .16s}.city-select{color:#0f172a;align-items:center;gap:8px;min-height:42px;padding:0 12px;font-size:15px;font-weight:750;display:inline-flex}svg{display:block}.city-select svg,.event-card-line svg,.page-footer svg,.pagination svg,.filter-label svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.content-layout{grid-template-columns:330px minmax(0,1fr);align-items:start;gap:24px;padding-top:34px;display:grid}.content-layout.is-detail-route{padding-top:24px;display:block}.filter-bar{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:22px;position:sticky;top:22px;box-shadow:0 14px 36px #0f172a0f}.filter-summary{cursor:pointer;grid-template-columns:auto minmax(0,1fr);justify-content:space-between;align-items:center;gap:12px;list-style:none;display:grid}.filter-summary::-webkit-details-marker{display:none}.filter-body{gap:22px;padding-top:22px;display:grid}.filter-summary strong{color:#0f172a;font-size:17px;font-weight:850}.filter-summary span{color:#64748b;text-align:right;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;font-weight:750;overflow:hidden}.filter-group{gap:10px;display:grid}.filter-label{color:#0f172a;font-size:15px;font-weight:800}.filter-select{color:#0f172a;appearance:none;background:linear-gradient(45deg,#0000 50%,#0f172a 50%) right 17px center/6px 6px no-repeat,linear-gradient(135deg,#0f172a 50%,#0000 50%) right 12px center/6px 6px no-repeat,#fff;border-radius:10px;width:100%;min-height:44px;padding:0 36px 0 14px;font-size:14px;font-weight:650}.filter-options{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.filter-options.is-compact{grid-template-columns:repeat(3,minmax(0,1fr))}.filter-options button{border-radius:10px;min-height:38px;padding:7px 8px;font-size:14px;font-weight:750}.filter-options button:hover,.pagination button:hover:not(:disabled){border-color:#10b981;transform:translateY(-1px)}.filter-options button.is-selected,.pagination button.is-active{color:#fff;background:linear-gradient(#16c98d 0%,#10b981 100%);border-color:#10b981;box-shadow:0 12px 24px #10b98138}.check-row{color:#334155;align-items:center;gap:10px;min-height:26px;font-size:14px;font-weight:650;display:flex}.check-row input{accent-color:#10b981;width:16px;height:16px;margin:0}.filter-actions{gap:10px;display:grid}.clear-filters,.done-filters{border:0;border-radius:10px;min-height:44px;font-size:14px;font-weight:850}.clear-filters{color:#fff;background:linear-gradient(#18c48a 0%,#10b981 100%)}.done-filters{color:#0f172a;background:#fff;border:1px solid #dbe3ee;display:none}.results-column{min-width:0}.results-toolbar{justify-content:space-between;align-items:start;gap:24px;margin-bottom:26px;display:flex}.page-title h1{color:#0f172a;letter-spacing:0;margin:0;font-size:clamp(30px,3vw,42px);font-weight:900;line-height:1.13}.page-title p{color:#64748b;margin:9px 0 0;font-size:16px;line-height:1.55}.result-count{color:#475569;margin:0 0 18px 4px;font-size:15px;font-weight:650}.event-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;display:grid}.event-card a{width:100%;height:100%;min-height:326px;color:inherit;text-align:left;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:18px;grid-template-rows:45% minmax(0,1fr);padding:0;text-decoration:none;display:grid;overflow:hidden;box-shadow:0 12px 28px #0f172a12}.event-card a:hover{border-color:#10b9815c;transform:translateY(-3px);box-shadow:0 18px 42px #0f172a1c}.event-card-art{min-height:0;position:relative;overflow:hidden}.illustration{height:100%}.illustration svg{width:100%;height:100%;display:block}.event-card-art img{object-fit:cover;width:100%;height:100%;display:block}.category-badge{color:#fff;background:#10b981;border-radius:8px;align-items:center;min-height:28px;padding:5px 10px;font-size:13px;font-weight:850;display:inline-flex;position:absolute;top:14px;left:14px;box-shadow:0 8px 18px #0f172a1f}.favorite-button{color:#475569;background:#ffffffe0;border-radius:999px;place-items:center;width:34px;height:34px;display:grid;position:absolute;top:12px;right:12px;box-shadow:0 8px 18px #0f172a1f}.favorite-button.is-interested{color:#e11d48;background:#fff1f2f5}.favorite-button.is-interested svg path{fill:currentColor;stroke:currentColor}.favorite-button svg{width:22px;height:22px}.event-card-body{align-content:start;gap:10px;padding:17px 18px 18px;display:grid}.event-card h2{color:#0f172a;margin:0 0 2px;font-size:18px;font-weight:850;line-height:1.3}.event-card-intro{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:39px;margin:-2px 0 1px;font-size:13px;font-weight:600;line-height:1.5;display:-webkit-box;overflow:hidden}.event-card-context{flex-wrap:wrap;gap:6px;margin:-2px 0 0;display:flex}.event-card-context span{color:#475569;-webkit-line-clamp:1;background:#f1f5f9;border-radius:7px;-webkit-box-orient:vertical;max-width:100%;min-height:24px;padding:3px 8px;font-size:12px;font-weight:750;line-height:1.45;display:-webkit-box;overflow:hidden}.event-card-line{color:#475569;align-items:center;gap:8px;min-width:0;margin:0;font-size:14px;font-weight:600;line-height:1.35;display:flex}.event-card-line span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.event-card-line svg{color:#334155;flex:none;width:16px;height:16px}.tag-row{flex-wrap:wrap;gap:8px;padding-top:3px;display:flex}.tag-row span{color:#0f766e;background:#e8fbf3;border-radius:8px;align-items:center;min-height:26px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-flex}.category-family,.category-community{background:#10b981}.category-exhibition{background:#0fb981}.category-performance{background:#7c3aed}.category-sports{background:#3b82f6}.category-food{background:#f97316}.category-workshop{background:#6366f1}.category-market{background:#ec4899}.category-other{background:#64748b}.tone-green{--illus-a:#d7f6df;--illus-b:#92d7b6}.tone-beige{--illus-a:#ffe4b5;--illus-b:#f7c77e}.tone-purple{--illus-a:#d8c2ff;--illus-b:#8b5cf6}.tone-orange{--illus-a:#ffd6b0;--illus-b:#fb9a5f}.tone-cyan{--illus-a:#d7f2e9;--illus-b:#83cbbd}.tone-indigo{--illus-a:#d9d5ff;--illus-b:#9b8cf3}.tone-rose{--illus-a:#ffe1e9;--illus-b:#ff9db4}.tone-blue{--illus-a:#dff4ff;--illus-b:#93c5fd}.tone-gray{--illus-a:#eef2f7;--illus-b:#cbd5e1}.pagination{justify-content:center;align-items:center;gap:10px;margin:26px 0 24px;display:flex}.pagination button{color:#334155;border-radius:10px;justify-content:center;align-items:center;gap:6px;min-width:40px;min-height:40px;padding:0 12px;font-size:14px;font-weight:750;display:inline-flex}.pagination button:disabled{cursor:not-allowed;opacity:.45}.pagination-ellipsis{color:#64748b;justify-content:center;align-items:center;min-width:24px;min-height:40px;font-size:14px;font-weight:750;display:inline-flex}.page-footer{color:#64748b;background:#fff;border:1px solid #e5e7eb;border-radius:12px;justify-content:space-between;align-items:center;gap:18px;margin-top:6px;padding:15px 22px;display:flex;box-shadow:0 10px 24px #0f172a0a}.page-footer p{align-items:center;gap:10px;min-width:0;margin:0;font-size:13px;line-height:1.5;display:flex}.page-footer svg{color:#2563eb;flex:none}.page-footer span{flex:none;font-size:13px;font-weight:650}.empty-state{text-align:center;background:#fff;border:1px dashed #10b98147;border-radius:18px;padding:48px 28px}.empty-state h2{color:#0f172a;margin:0 0 8px}.empty-state p{color:#64748b;margin:0}.empty-state button{color:#fff;background:#10b981;border:0;border-radius:10px;min-height:40px;margin-top:16px;padding:0 16px;font-weight:850}.detail-route-state{width:min(760px,100%);margin:0 auto;padding:44px 0 120px}.detail-route-back{color:#334155;font:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;margin-bottom:18px;padding:0;font-size:15px;font-weight:750;display:inline-flex}.detail-route-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:18px;justify-items:center;gap:12px;padding:54px 28px;display:grid;box-shadow:0 18px 42px #0f172a12}.detail-route-card h1{color:#0f172a;margin:6px 0 0;font-size:28px;font-weight:900;line-height:1.2}.detail-route-card p{color:#64748b;max-width:440px;margin:0;font-size:15px;font-weight:600;line-height:1.65}.detail-route-card button{color:#fff;min-height:42px;font:inherit;cursor:pointer;background:#10b981;border:0;border-radius:10px;margin-top:8px;padding:0 18px;font-size:14px;font-weight:850}.detail-route-icon,.detail-route-spinner{color:#10b981;background:#e8fbf3;border-radius:999px;place-items:center;width:48px;height:48px;display:grid}.detail-route-spinner{animation:1.2s linear infinite detail-spin}@keyframes detail-spin{to{transform:rotate(360deg)}}.event-detail{color:#0f172a;width:min(1180px,100%);margin:0 auto}.event-detail svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.event-detail-hero{grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);align-items:center;gap:48px;margin-bottom:36px;padding:28px 24px 4px;display:grid}.event-detail-copy{justify-items:start;gap:18px;min-width:0;display:grid}.detail-back-button{color:#334155;font:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;padding:0;font-size:15px;font-weight:750;transition:color .16s,transform .16s;display:inline-flex}.detail-back-button:hover{color:#10b981;transform:translate(-2px)}.category-tag{color:#047857;background:#d7f8e8;border-radius:9px;align-items:center;min-height:28px;padding:5px 11px;font-size:13px;font-weight:850;display:inline-flex}.event-detail-copy h1{color:#111827;letter-spacing:0;max-width:660px;margin:0;font-size:clamp(34px,4vw,56px);font-weight:900;line-height:1.06}.hero-fact-list{gap:10px;margin:0;display:grid}.hero-fact-list p,.contact-list li{color:#334155;align-items:center;gap:10px;min-width:0;margin:0;font-size:15px;font-weight:650;line-height:1.45;display:flex}.hero-fact-list svg{color:#0f172a;flex:none}.detail-pill-row{flex-wrap:wrap;gap:9px;display:flex}.detail-pill-row span{color:#334155;background:#ffffffc7;border:1px solid #dbe3ee;border-radius:999px;align-items:center;min-height:30px;padding:5px 12px;font-size:13px;font-weight:750;display:inline-flex}.hero-intro{color:#334155;max-width:610px;margin:0;font-size:16px;font-weight:550;line-height:1.8}.detail-cta-row{flex-wrap:wrap;align-items:center;gap:14px;padding-top:10px;display:flex}.primary-action,.secondary-action,.outline-link-button{min-height:46px;font:inherit;cursor:pointer;border-radius:11px;justify-content:center;align-items:center;gap:9px;padding:0 24px;font-size:15px;font-weight:850;text-decoration:none;transition:transform .16s,border-color .16s,background .16s,color .16s,box-shadow .16s;display:inline-flex}.primary-action{color:#0f172a;box-shadow:none;background:#fff;border:1px solid #dbe3ee}.primary-action.is-interested{color:#fff;background:linear-gradient(#18c48a 0%,#10b981 100%);border-color:#0000;box-shadow:0 14px 28px #10b98147}.secondary-action,.outline-link-button{color:#0f172a;background:#fff;border:1px solid #dbe3ee}.primary-action:hover,.secondary-action:hover,.outline-link-button:hover{border-color:#10b98173;transform:translateY(-2px);box-shadow:0 16px 32px #0f172a1a}.primary-action:disabled,.secondary-action:disabled{cursor:default;transform:none}.primary-action:disabled:not(.is-interested){opacity:.72}.interest-meter{color:#475569;background:#fffc;border:1px solid #dbe3ee;border-radius:999px;align-items:center;gap:7px;min-height:34px;padding:5px 12px;font-size:13px;font-weight:750;display:inline-flex}.interest-meter svg{color:#10b981;width:16px;height:16px}.event-media-card{aspect-ratio:16/10;background:#fff;border-radius:24px;min-height:340px;position:relative;overflow:hidden;box-shadow:0 18px 42px #0f172a1f}.event-media-card img,.event-media-card .illustration,.event-media-card .illustration svg{width:100%;height:100%;display:block}.event-media-card img{object-fit:cover;position:absolute;inset:0}.event-media-card .illustration{min-height:340px}.event-media-card .illustration svg{transform:scale(1.04)}.media-favorite{color:#0f172a;cursor:pointer;background:#ffffffeb;border:0;border-radius:999px;place-items:center;width:48px;height:48px;transition:transform .16s,color .16s;display:grid;position:absolute;top:18px;right:18px;box-shadow:0 12px 24px #0f172a26}.media-favorite:hover{color:#10b981;transform:translateY(-1px)scale(1.03)}.media-favorite.is-interested{color:#e11d48;background:#fff1f2f5}.media-favorite.is-interested svg path{fill:currentColor;stroke:currentColor}.media-favorite:disabled{cursor:default}.media-favorite:disabled:hover{transform:none}.event-detail-layout{grid-template-columns:minmax(0,1fr) minmax(300px,36%);align-items:start;gap:28px;display:grid}.event-detail-main,.event-detail-sidebar,.event-detail-bottom{gap:24px;display:grid}.event-detail-sidebar{position:sticky;top:90px}.detail-card{background:#fffffff0;border:1px solid #e5e7eb;border-radius:16px;padding:28px 30px;box-shadow:0 12px 30px #0f172a0f}.section-title{color:#0f172a;letter-spacing:0;align-items:center;gap:10px;margin:0 0 22px;font-size:18px;font-weight:900;line-height:1.25;display:flex}.section-title svg{color:#0f766e}.detail-body-copy{color:#334155;margin:0;font-size:15px;font-weight:540;line-height:1.85}.subsection-title{color:#0f172a;margin:28px 0 16px;font-size:17px;font-weight:900;line-height:1.3}.highlight-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.highlight-card{background:linear-gradient(135deg,#effdf6 0%,#f8fffb 58%,#e8f8f1 100%);border:1px solid #10b9811f;border-radius:13px;align-items:flex-start;gap:12px;min-height:76px;padding:17px;display:flex}.highlight-card span{color:#fff;background:#10b981;border-radius:999px;flex:none;place-items:center;width:24px;height:24px;font-size:12px;font-weight:900;display:grid}.highlight-card strong{color:#334155;font-size:14px;font-weight:750;line-height:1.55}.detail-definition-list{border:1px solid #e5e7eb;border-radius:12px;margin:0;overflow:hidden}.detail-definition-list div{border-bottom:1px solid #e5e7eb;grid-template-columns:170px minmax(0,1fr);min-height:42px;display:grid}.detail-definition-list div:last-child{border-bottom:0}.detail-definition-list dt,.detail-definition-list dd{align-items:center;min-width:0;margin:0;padding:10px 16px;font-size:14px;line-height:1.45;display:flex}.detail-definition-list dt{color:#64748b;background:#fbfdff;font-weight:750}.detail-definition-list dd{color:#0f172a;font-weight:650}.timeline-strip{background:linear-gradient(90deg,#effbf5 0%,#f8fffc 100%);border-radius:13px;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin:0;padding:18px 16px 16px;list-style:none;display:grid;overflow:hidden}.timeline-strip li{color:#0f172a;text-align:center;justify-items:center;gap:7px;min-width:0;display:grid;position:relative}.timeline-strip li:before{content:"";background:#d4eee2;width:100%;height:2px;position:absolute;top:8px;left:-50%}.timeline-strip li:first-child:before{display:none}.timeline-strip li:after{content:"";background:#cde7dc;border-radius:999px;width:10px;height:10px;position:absolute;top:4px;left:calc(50% - 5px)}.timeline-strip span{z-index:1;color:#059669;font-size:13px;font-weight:900;position:relative}.timeline-strip strong{color:#334155;font-size:14px;font-weight:750;line-height:1.45}.organizer-profile{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:16px;display:grid}.organizer-avatar{color:#fff;background:#172033;border-radius:999px;place-items:center;width:58px;height:58px;display:grid}.organizer-avatar svg{width:31px;height:31px}.organizer-profile strong{color:#0f172a;margin:2px 0 7px;font-size:16px;font-weight:900;line-height:1.3;display:block}.organizer-profile p,.map-card p{color:#475569;margin:0;font-size:14px;font-weight:550;line-height:1.65}.organizer-card .outline-link-button{width:100%;margin-top:26px}.contact-list,.compact-info-list{gap:13px;margin:0;padding:0;list-style:none;display:grid}.contact-list li{align-items:flex-start}.contact-list a{color:#0f172a;text-decoration:none}.contact-list a:hover,.map-card a:hover{color:#059669}.contact-list svg,.compact-info-list li:before{color:#64748b;flex:none}.map-preview{background:linear-gradient(30deg,#0000 46%,#ffffffd1 47% 52%,#0000 53%) 0 0/92px 92px,linear-gradient(130deg,#0000 44%,#ffffffc7 45% 51%,#0000 52%) 0 0/108px 108px,radial-gradient(circle at 32% 28%,#d8f0dc 0 16%,#0000 17%),radial-gradient(circle at 72% 64%,#cdebd5 0 18%,#0000 19%),#eaf7ef;border-radius:12px;height:140px;position:relative;overflow:hidden}.map-preview span{color:#fff;background:#10b981;border-radius:999px;place-items:center;width:38px;height:38px;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 14px 24px #10b98152}.map-card h2{color:#0f172a;margin:20px 0 6px;font-size:18px;font-weight:900;line-height:1.35}.map-card a{color:#10b981;margin-top:16px;font-size:14px;font-weight:850;text-decoration:none;display:inline-flex}.event-detail-bottom{grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);margin-top:28px}.compact-info-list li{color:#334155;padding-left:26px;font-size:14px;font-weight:650;line-height:1.5;position:relative}.compact-info-list li:before{content:"";background:#10b981;border-radius:999px;width:8px;height:8px;position:absolute;top:7px;left:5px}.detail-disclaimer{color:#94a3b8;border-top:1px solid #e5e7eb;justify-content:space-between;gap:16px;margin:22px 0 0;padding:18px 2px 0;font-size:13px;font-weight:600;line-height:1.5;display:flex}@media (width<=1260px){.content-layout{grid-template-columns:300px minmax(0,1fr)}.event-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.event-detail-hero{gap:30px;padding-left:0;padding-right:0}}@media (width<=960px){.list-page{padding:0 22px 28px}.topbar{margin:0 -22px;padding:0 22px}.content-layout{grid-template-columns:1fr;padding-top:24px}.filter-bar{position:static}.filter-actions{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff0;border:1px solid #e5e7eb;border-radius:14px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);padding:10px;position:sticky;bottom:12px}.done-filters{display:block}.event-detail-hero,.event-detail-layout,.event-detail-bottom{grid-template-columns:1fr}.event-detail-hero{gap:24px;padding-top:8px}.event-detail-sidebar{position:static}.event-media-card,.event-media-card .illustration{min-height:300px}.results-toolbar{flex-direction:column;align-items:stretch;gap:16px}}@media (width<=680px){.list-page{padding:0 16px 24px}.topbar{min-height:66px;margin:0 -16px;padding:0 16px}.brand{gap:12px}.brand img{width:104px}.brand span{max-width:112px;font-size:13px}.city-select{padding:0;font-size:14px}.filter-bar{border-radius:16px;padding:18px}.filter-summary{grid-template-columns:1fr;gap:6px}.filter-summary span{text-align:left;white-space:normal}.filter-body{gap:18px;padding-top:18px}.filter-options{grid-template-columns:repeat(2,minmax(0,1fr))}.event-grid{grid-template-columns:1fr}.page-title h1{font-size:30px}.page-title p{font-size:15px}.event-detail-hero{margin-bottom:24px}.event-detail-copy h1{font-size:34px}.event-media-card,.event-media-card .illustration{border-radius:18px;min-height:230px}.detail-card{border-radius:14px;padding:22px 18px}.highlight-grid,.timeline-strip{grid-template-columns:1fr}.timeline-strip{gap:14px;padding:18px}.timeline-strip li{text-align:left;justify-items:start;padding-left:24px}.timeline-strip li:before{width:2px;height:30px;top:-16px;left:4px}.timeline-strip li:first-child:before{opacity:0;display:block}.timeline-strip li:after{top:6px;left:0}.detail-definition-list div{grid-template-columns:1fr}.detail-definition-list dt{background:#fff;padding-bottom:2px}.detail-definition-list dd{padding-top:2px}.event-card a{min-height:318px}.pagination{flex-wrap:wrap}.pagination button span{display:none}.page-footer{flex-direction:column;align-items:flex-start;padding:14px 16px}}
