.hapsp-section{margin:24px 0;padding:16px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;font-size:15px}.hapsp-header{display:flex;gap:14px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.hapsp-title{margin:0 0 4px;font-size:22px;line-height:1.15}.hapsp-subtitle{margin:0;color:#475569;font-size:14px}.hapsp-source{margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.hapsp-source-label{font-size:13px;color:#64748b;font-weight:700}.hapsp-source-logo{height:22px;width:auto;display:block}.hapsp-badge{border:1px solid #e2e8f0;border-radius:12px;padding:8px 10px;min-width:160px;text-align:center;background:#f8fafc}.hapsp-rating{font-weight:800;font-size:20px}.hapsp-rating-max{font-weight:700;color:#64748b}.hapsp-count{color:#475569;margin-top:4px;font-size:13px}.hapsp-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.hapsp-card{border:1px solid #e2e8f0;border-radius:14px;padding:12px;background:#fff;box-shadow:0 4px 14px rgb(15 23 42 / .05);display:flex;flex-direction:column;gap:10px}.hapsp-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.hapsp-date{color:#64748b;font-size:12px}.hapsp-stars{display:flex;gap:2px;align-items:center}.hapsp-star{font-size:16px;line-height:1}.hapsp-star.is-full{color:#ff8a00}.hapsp-star.is-empty{color:#e5e7eb}.hapsp-text{color:#0f172a;font-size:14px}.hapsp-card-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:auto}.hapsp-name{font-weight:700;color:#334155;font-size:13px}.hapsp-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.hapsp-more{border:none;background:none;color:#0ea5e9;font-weight:800;padding:0;cursor:pointer;font-size:13px}.hapsp-verify{color:#64748b;text-decoration:none;font-weight:700;font-size:12px}.hapsp-footer{display:flex;justify-content:flex-start;margin-top:12px}.hapsp-cta{display:inline-block;padding:10px 14px;border-radius:12px;background:#0f172a;color:#fff;border:none;cursor:pointer;font-weight:800;font-size:13px}.hapsp-empty{margin-top:12px;padding:12px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa}.hapsp-modal{position:relative}.hapsp-modal.is-open{position:fixed;inset:0;z-index:99999}.hapsp-modal-backdrop{display:none}.hapsp-modal.is-open .hapsp-modal-backdrop{display:block;position:absolute;inset:0;background:rgb(15 23 42 / .55)}.hapsp-modal-card{display:none}.hapsp-modal.is-open .hapsp-modal-card{display:block;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(760px, calc(100vw - 24px));max-height:calc(100vh - 24px);overflow:auto;background:#fff;border-radius:16px;padding:14px;border:1px solid #e2e8f0}.hapsp-modal-close{position:sticky;top:0;float:right;border:none;background:#fff;font-size:28px;line-height:1;cursor:pointer}.hapsp-modal-content{padding:10px 6px 8px;color:#0f172a}.hapsp-modal-text{white-space:pre-wrap;font-size:14px;color:#0f172a}.hapsp-modal-list{display:flex;flex-direction:column;gap:14px}.hapsp-modal-item{border:1px solid #e2e8f0;border-radius:12px;padding:12px}.hapsp-modal-item-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.hapsp-modal-verify a{font-weight:800;color:#0ea5e9;text-decoration:none;font-size:13px}@media (max-width:980px){.hapsp-grid{grid-template-columns:1fr}}