:root{--white:#ffffff;--bg-main:#ffffff;--bg-card:#ffffff;--bg-muted:#f5f5f5;--text-main:#111111;--text-sub:#555555;--text-muted:#999999;--primary:#2563eb;--primary-bg:#eff4ff;--red:#dc2626;--red-bg:#fff1f1;--green:#16a34a;--green-bg:#f0fdf4;--amber:#d97706;--amber-bg:#fffbeb;--border:#e8e8e8;--radius:14px;--shadow-xs:0 1px 3px rgba(0,0,0,.06);--shadow-sm:0 2px 8px rgba(0,0,0,.07);--shadow-md:0 6px 20px rgba(0,0,0,.09);--shadow-lift:0 12px 36px rgba(0,0,0,.12)}*,:after,:before{box-sizing:border-box}.activities-page-wrapper{background:var(--bg-main);min-height:100vh;max-width:1180px;margin:0 auto;padding:40px 28px 72px;color:var(--text-main)}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:44px}.page-title{font-size:2.5rem;font-weight:700;margin:0 0 4px;color:var(--text-main);letter-spacing:-.3px;line-height:1.1}.page-subtitle{margin:0;color:var(--text-sub);font-size:.95rem}.location-btn{display:flex;align-items:center;gap:7px;background:var(--white);border:1.5px solid var(--border);padding:9px 16px;border-radius:100px;font-weight:600;font-size:.85rem;color:var(--text-main);cursor:pointer;box-shadow:var(--shadow-xs);transition:border-color .15s,color .15s,background .15s;white-space:nowrap}.location-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.sections-container{display:flex;flex-direction:column;gap:52px}.activity-section{width:100%}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.section-label-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border-radius:100px;font-size:.9rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.section-rule{flex:1;height:1px;background:var(--border)}.see-more-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-ui);font-size:.78rem;font-weight:600;color:var(--text-muted);text-decoration:none;white-space:nowrap;flex-shrink:0;padding:5px 12px;border:1.5px solid var(--border);border-radius:100px;background:var(--white);transition:all .15s}.see-more-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-bg)}.see-more-btn svg{transition:transform .15s}.see-more-btn:hover svg{transform:translateX(3px)}.activity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width:900px){.activity-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.activity-grid{grid-template-columns:1fr}}.plan-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xs);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;cursor:pointer}.plan-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#d0d0d0}.card-thumb{background-size:cover;background-position:50%;background-color:var(--bg-muted)}.card-thumb,.card-thumb-icon{width:100%;aspect-ratio:16/9;position:relative;flex-shrink:0}.card-thumb-icon{background:var(--bg-muted)}.card-icon-wrap,.card-thumb-icon{display:flex;align-items:center;justify-content:center}.card-icon-wrap{width:52px;height:52px;border-radius:14px}.img-date-badge{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.93);backdrop-filter:blur(6px);border-radius:9px;padding:6px 10px;text-align:center;line-height:1;box-shadow:var(--shadow-sm)}.badge-month{font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.badge-day,.badge-month{display:block;font-weight:800}.badge-day{font-size:1.2rem;color:var(--text-main);margin-top:1px}.card-scrim{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(0,0,0,.52) 0,transparent);padding:18px 10px 8px;display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:600;color:#fff}.card-body{padding:13px 14px 14px;display:flex;flex-direction:column;flex:1;gap:6px}.card-name{font-size:.9rem;font-weight:700;color:var(--text-main);line-height:1.3}.card-name,.card-venue{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-venue{display:flex;align-items:center;gap:4px;font-size:.76rem;color:var(--text-sub)}.card-venue svg{flex-shrink:0;color:var(--text-muted)}.card-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}.tag{display:inline-flex;align-items:center;gap:4px;background:var(--bg-muted);border-radius:6px;padding:3px 8px;font-size:.68rem;font-weight:600;color:var(--text-sub)}.card-footer{margin-top:auto;padding-top:10px;border-top:1px solid var(--border);justify-content:space-between}.card-footer,.members-pill{display:flex;align-items:center}.members-pill{gap:5px;font-size:.75rem;font-weight:600}.progress-wrap{margin-top:auto;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:5px}.progress-row{display:flex;justify-content:space-between;font-size:.7rem;font-weight:600;color:var(--text-sub)}.progress-track{height:4px;background:var(--bg-muted);border-radius:10px;overflow:hidden}.progress-fill{height:100%;border-radius:10px;background:var(--red);transition:width .4s ease}.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted);font-size:.9rem}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.38);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadein .18s ease}.modal-box{background:var(--white);border-radius:18px;padding:24px;width:100%;max-width:380px;box-shadow:var(--shadow-lift);animation:slideup .22s cubic-bezier(.175,.885,.32,1.275)}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-head h3{margin:0;font-size:1rem;font-weight:700}.close-btn{background:var(--bg-muted);border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--text-sub);cursor:pointer;transition:background .15s}.close-btn:hover{background:var(--border)}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip.active{background:var(--secondary-1);color:#fff;border-color:var(--text-main)}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes slideup{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:560px){.activities-page-wrapper{padding:24px 16px 56px;margin-top:24px}.page-title{font-size:1.9rem}.sections-container{gap:40px}.page-header{align-items:flex-start}}