
:root{--purple:#832b99;--ink:#1d1326;--plum:#3a2c47;--gold:#fad20a;--pink:#ff2bd6;--cyan:#00f5ff;--blue:#2e3092;--cream:#fffaf5;--cream2:#fff5e8;--line:#e7ddd2;}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Plus Jakarta Sans",system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
a{color:inherit}
.prideline{height:6px;background:linear-gradient(90deg,#e40303,#ff8c00,#ffed00,#008026,#004dff,#750787)}
header.site{background:var(--cream);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.site .wrap{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.site img.logo{height:40px;width:auto}
.site .nav-cta{background:var(--ink);color:#fff;text-decoration:none;font-weight:700;font-size:14px;padding:10px 16px;border-radius:999px;white-space:nowrap}
.site .nav-cta:hover{background:var(--purple)}
.hero{position:relative;overflow:hidden;background:radial-gradient(1200px 500px at 80% -10%,rgba(255,43,214,.18),transparent),radial-gradient(900px 500px at 0% 0%,rgba(0,245,255,.14),transparent),var(--ink);color:#fff}
.hero .wrap{padding:62px 22px 70px;position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(250,210,10,.22)}
h1.big{font-size:clamp(40px,7vw,76px);line-height:1.02;font-weight:800;letter-spacing:-.02em;margin-bottom:18px}
h1.big .grad{background:linear-gradient(90deg,var(--gold),var(--pink),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lede{font-size:clamp(17px,2.3vw,21px);max-width:620px;color:#efe7f2}
.counter{display:flex;align-items:baseline;gap:14px;margin:30px 0 8px}
.counter .num{font-size:clamp(54px,9vw,86px);font-weight:800;line-height:1;color:#fff}
.counter .lab{font-size:16px;color:#efe7f2;max-width:230px}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;text-decoration:none;border-radius:999px;padding:14px 24px;font-size:15px;transition:transform .15s,box-shadow .15s;cursor:pointer;border:none}
.btn:hover{transform:translateY(-2px)}
.btn.primary{background:linear-gradient(90deg,var(--pink),var(--purple));color:#fff;box-shadow:0 10px 30px rgba(255,43,214,.28)}
.btn.ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.32)}
.btn.ghost:hover{background:rgba(255,255,255,.16)}
.seal{position:absolute;right:5%;top:50%;transform:translateY(-50%) rotate(-8deg);width:212px;height:212px;z-index:1;filter:drop-shadow(0 18px 40px rgba(0,0,0,.35))}
.seal .ring{fill:none;stroke:var(--gold);stroke-width:2}.seal text{fill:#fff}
@media(max-width:880px){.seal{display:none}}
.band{background:var(--gold);color:var(--ink)}
.band .wrap{padding:16px 22px;display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;font-weight:700;font-size:15px;flex-wrap:wrap}
.band b{font-weight:800}
.intent{background:var(--cream2);border-bottom:1px solid var(--line)}
.intent .wrap{max-width:880px;padding:30px 22px}
.intent-lead{font-size:clamp(20px,3.2vw,27px);font-weight:800;letter-spacing:-.01em;color:var(--ink);text-align:center;margin-bottom:10px}
.intent-body{font-size:16px;line-height:1.72;color:var(--plum);text-align:center}
.join-cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.controls{position:sticky;top:68px;z-index:30;background:var(--cream);border-bottom:1px solid var(--line);padding:14px 0}
.controls .wrap{display:flex;flex-direction:column;gap:11px}
.searchrow{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
#search{flex:1;min-width:200px;border:1.5px solid var(--line);background:#fff;border-radius:12px;padding:12px 14px;font:inherit;color:var(--ink)}
#search:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(131,43,153,.14)}
.count-live{font-weight:700;font-size:14px;color:var(--plum);white-space:nowrap}
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.chip{flex:0 0 auto;border:1.5px solid var(--line);background:#fff;color:var(--plum);font:inherit;font-weight:600;font-size:13px;padding:8px 14px;border-radius:999px;cursor:pointer;transition:.15s}
.chip[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip:hover{border-color:var(--purple)}
.scopelabel{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#a596ab;align-self:center;margin-right:2px}
main{padding:30px 0 10px}
.catsection{margin-bottom:38px}
.cathead{display:flex;align-items:center;gap:12px;margin:0 0 16px}
.cathead .bar{width:30px;height:5px;border-radius:3px;background:var(--accent,#832b99)}
.cathead h2{font-size:24px;font-weight:800;letter-spacing:-.01em}
.cathead .n{font-size:14px;font-weight:700;color:#a596ab}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:0;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 38px rgba(29,19,38,.13)}
.card:hover .logobar img{transform:scale(1.04)}
.card:focus-visible{outline:3px solid var(--purple);outline-offset:2px}
.logobar{height:200px;display:flex;align-items:center;justify-content:center;background:#fff;border-bottom:3px solid var(--accent,#832b99);padding:24px;flex:0 0 auto;overflow:hidden}
.logobar img{max-height:160px;max-width:88%;object-fit:contain;transition:transform .2s}
.logobar.mono-bar{background:var(--accent,#832b99);border-bottom:none}
.logobar .mono{font-size:86px;font-weight:800;color:#fff;letter-spacing:1px}
.cbody{padding:13px 16px 15px;display:flex;flex-direction:column;gap:5px;flex:1}
.logo{width:54px;height:54px;border-radius:13px;background:var(--cream2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}
.logo img{width:100%;height:100%;object-fit:contain}
.logo .mono{font-weight:800;font-size:20px;color:#fff;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent,#832b99)}
.card .cat{position:absolute;top:12px;left:12px;z-index:2;font-size:10px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--accent,#832b99);background:rgba(255,255,255,.94);padding:5px 10px;border-radius:999px;box-shadow:0 2px 8px rgba(29,19,38,.10)}
.card h3{font-size:17px;font-weight:700;line-height:1.22}
.card .town{display:flex;align-items:center;gap:7px;color:var(--plum);font-size:14px;font-weight:500;margin-top:auto}
.card .more{font-size:13px;font-weight:700;color:var(--purple)}
.empty{text-align:center;padding:60px 20px;color:var(--plum)}
.disclaimer{max-width:780px;margin:40px auto 0;text-align:center;color:var(--plum);font-size:14px;line-height:1.75;border-top:1px solid var(--line);padding-top:24px}
.disclaimer b{color:var(--ink);font-weight:700}
.join{margin:42px 0 0;background:linear-gradient(135deg,var(--purple),var(--blue));color:#fff;border-radius:26px;padding:clamp(30px,5vw,56px);text-align:center;position:relative;overflow:hidden}
.join:after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 90% 0%,rgba(0,245,255,.18),transparent),radial-gradient(500px 300px at 0% 100%,rgba(255,43,214,.22),transparent)}
.join>*{position:relative;z-index:1}
.join h2{font-size:clamp(26px,4vw,40px);font-weight:800;margin-bottom:14px}
.join p{max-width:560px;margin:0 auto 24px;color:#f0ecf6;font-size:17px}
.join .free{display:inline-block;background:var(--gold);color:var(--ink);font-weight:800;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:999px;margin-bottom:18px}
footer.site{margin-top:50px;background:var(--ink);color:#cdbfd4}
footer .wrap{padding:38px 22px;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
footer .addr{font-size:14px;line-height:1.7}footer a{color:var(--gold);text-decoration:none}
footer .small{font-size:12px;color:#8f7f97;width:100%;border-top:1px solid #2a1f2e;padding-top:18px;margin-top:6px}
/* detail page */
.detail .wrap{padding:34px 22px 10px}
.back{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:var(--purple);text-decoration:none;margin-bottom:22px}
.back:hover{text-decoration:underline}
.dhead{display:flex;gap:20px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.dhead .logo{width:112px;height:112px;border-radius:20px;background:#fff}.dhead .logo img{padding:8px}.dhead .logo .mono{font-size:40px;border-radius:0}
.dhead h1{font-size:clamp(28px,4.5vw,42px);font-weight:800;letter-spacing:-.01em;line-height:1.05}
.dhead .meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.tag{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--accent,#832b99);padding:5px 11px;border-radius:999px}
.tag.town{background:var(--cream2);color:var(--plum);border:1px solid var(--line)}
.dgrid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-top:26px}
@media(max-width:820px){.dgrid{grid-template-columns:1fr}}
.panel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px}
.panel h2{font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#a596ab;margin-bottom:14px}
.why{border-left:5px solid var(--accent,#832b99)}
.why blockquote{font-size:20px;line-height:1.45;font-weight:600;color:var(--ink)}
.why blockquote:before{content:"\201C";color:var(--accent,#832b99);font-weight:800}
.why blockquote:after{content:"\201D";color:var(--accent,#832b99);font-weight:800}
.why cite{display:block;margin-top:12px;font-style:normal;font-weight:700;font-size:14px;color:var(--plum)}
.why .srclink{display:inline-block;margin-top:12px;font-weight:700;color:var(--purple);font-size:14px}
.about p{font-size:16px;color:var(--plum)}
.about .attr{margin-top:10px;font-size:12px;color:#a596ab}
.contact ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.contact li{display:flex;gap:11px;align-items:flex-start;font-size:15px}
.contact li svg{flex:0 0 auto;margin-top:2px;color:var(--purple)}
.contact a{color:var(--purple);text-decoration:none;font-weight:600;word-break:break-word}
.contact a:hover{text-decoration:underline}
.nav-btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;margin-top:18px;background:var(--ink);color:#fff;font-weight:700;padding:14px;border-radius:14px;text-decoration:none}
.nav-btn:hover{background:var(--purple)}
.seal-mini{display:flex;align-items:center;gap:12px;background:var(--cream2);border:1px dashed var(--gold);border-radius:16px;padding:14px 16px;margin-top:20px;font-size:14px;font-weight:600;color:var(--plum)}
.seal-mini .b{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;text-align:center;line-height:1;flex:0 0 auto}
@media(max-width:560px){.hero .wrap{padding:44px 22px 52px}.counter{flex-direction:column;gap:6px}}
.modal-ov{position:fixed;inset:0;background:rgba(29,19,38,.62);display:none;align-items:flex-start;justify-content:center;z-index:1000;overflow-y:auto;padding:40px 16px}
.modal-ov.open{display:flex}
.modal{background:#fff;border-radius:22px;max-width:560px;width:100%;padding:30px;position:relative;box-shadow:0 30px 80px rgba(29,19,38,.4)}
.modal h2{font-size:26px;font-weight:800;letter-spacing:-.01em;margin-bottom:6px}
.modal p.sub{color:var(--plum);margin-bottom:20px;font-size:15px}
.modal .x{position:absolute;top:14px;right:16px;background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--plum)}
.modal .x:hover{color:var(--purple)}
.field{margin-bottom:14px}
.field label{display:block;font-weight:700;font-size:13px;margin-bottom:5px;color:var(--ink)}
.field .req{color:var(--pink)}
.field input,.field select{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 12px;font:inherit;color:var(--ink);background:#fff}
.field input:focus,.field select:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(131,43,153,.14)}
.field textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 12px;font:inherit;color:var(--ink);background:#fff;resize:vertical;min-height:74px}
.field textarea:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(131,43,153,.14)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--plum);margin:8px 0 18px}
.consent input{margin-top:3px;flex:0 0 auto;width:18px;height:18px;accent-color:var(--purple)}
.modal .btn.primary{width:100%;justify-content:center;border:none;cursor:pointer;font-size:16px}
.modal .thanks{text-align:center;padding:14px 0}
.modal .thanks .big{font-size:48px;color:var(--gold)}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
