.dir-hero{background:var(--bg-2);border-bottom:1px solid var(--border)}.dir-hero__in{padding:36px 0 30px}.dir-breadcrumb{color:var(--fg-2);align-items:center;gap:8px;font-size:13.5px;display:flex}.dir-breadcrumb a:hover{color:var(--brand-strong)}.dir-hero h1{text-wrap:balance;margin:12px 0 0;font-size:clamp(26px,4.4vw,38px);font-weight:800}.dir-hero h1 .grad-text{background:var(--brand-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.dir-hero__sub{color:var(--fg-2);margin:10px 0 0;font-size:16px}.filterbar{z-index:30;-webkit-backdrop-filter:saturate(180%)blur(10px);border-bottom:1px solid var(--border);background:#ffffffe0;position:sticky;top:64px}.filterbar__in{align-items:center;gap:12px;padding:12px 0;display:flex}.field{align-items:center;display:inline-flex;position:relative}.field--grow{flex:1;min-width:0}.field__ic{color:var(--fg-2);pointer-events:none;display:inline-flex;position:absolute;left:14px}.field__chev{color:var(--fg-2);pointer-events:none;display:inline-flex;position:absolute;right:12px}.input,.select{font-family:var(--font-body);color:var(--fg-1);background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-pill);width:100%;height:46px;transition:border-color .16s var(--ease), box-shadow .16s var(--ease);appearance:none;padding:0 16px 0 40px;font-size:14.5px}.select{cursor:pointer;padding-right:38px}.input::placeholder{color:var(--fg-2)}.input:focus,.select:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #16b87729}.filterbar__fields{display:none}.filterbar__fields .field--select{width:190px}.filter-trigger{border:1px solid var(--border);background:var(--bg-1);border-radius:var(--radius-pill);height:46px;font-family:var(--font-body);color:var(--fg-1);cursor:pointer;flex:none;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-size:14.5px;font-weight:600;display:inline-flex}.filter-trigger .count{background:var(--brand-grad);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.chips-row{flex-wrap:wrap;gap:8px;padding:0 0 14px;display:flex}.chips-row:empty{display:none}.fchip{background:var(--bg-1);border:1px solid var(--border);color:var(--fg-1);border-radius:999px;align-items:center;gap:7px;padding:6px 8px 6px 13px;font-size:13px;font-weight:600;display:inline-flex}.fchip__x{background:var(--bg-2);width:20px;height:20px;color:var(--fg-2);cursor:pointer;transition:background-color .15s var(--ease), color .15s var(--ease);border:none;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.fchip__x:hover{background:var(--brand);color:#fff}.fchip--clear{color:var(--brand-strong);cursor:pointer;background:0 0;border-color:#0000}.fchip--clear:hover{text-decoration:underline}.results{padding:26px 0 80px}.results__meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}.results__count{color:var(--fg-2);font-size:14.5px}.results__count b{color:var(--fg-1);font-weight:700}.dir-grid{grid-template-columns:1fr;gap:18px;display:grid}@media (min-width:560px){.dir-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:860px){.dir-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1120px){.dir-grid{grid-template-columns:repeat(4,1fr)}}.skel-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-1);overflow:hidden}.skel{background:#eef4f1;position:relative;overflow:hidden}.skel:after{content:"";background:linear-gradient(90deg,#0000,#ffffffb3,#0000);animation:1.3s infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}@keyframes shimmer{to{transform:translate(100%)}}@media (prefers-reduced-motion:reduce){.skel:after{animation:none}}.skel-media{aspect-ratio:4/3}.skel-body{padding:16px}.skel-line{border-radius:6px;height:12px;margin-bottom:10px}.state{text-align:center;max-width:460px;margin:28px auto;padding:48px 24px}.state__ill{width:96px;height:96px;color:var(--brand-strong);background:var(--bg-2);border:1px solid var(--border);border-radius:28px;justify-content:center;align-items:center;margin:0 auto 22px;display:flex}.state--error .state__ill{color:#c2410c;background:#fff4ed;border-color:#fcd9bd}.state h3{font-size:22px;font-weight:800}.state p{color:var(--fg-2);text-wrap:pretty;margin:12px 0 0;font-size:15.5px}.state__actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px;display:flex}.loadmore{flex-direction:column;align-items:center;gap:14px;margin-top:36px;display:flex}.loadmore__spin{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:26px;height:26px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loadmore__end{color:var(--fg-2);font-size:14px}.loadmore__count{color:var(--fg-2);font-size:13.5px;font-weight:500}.sheet-root{z-index:70;pointer-events:none;visibility:hidden;position:fixed;inset:0}.sheet-root.is-open{pointer-events:auto;visibility:visible}.sheet__scrim{opacity:0;transition:opacity .28s var(--ease);background:#0c1a146b;position:absolute;inset:0}.sheet-root.is-open .sheet__scrim{opacity:1}.sheet{background:var(--bg-1);padding:8px 20px max(24px, env(safe-area-inset-bottom));transition:transform .32s var(--ease);border-radius:24px 24px 0 0;max-height:88vh;position:absolute;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.sheet-root.is-open .sheet{transform:translateY(0)}.sheet__grip{background:var(--border);border-radius:999px;width:42px;height:5px;margin:8px auto 6px}.sheet__head{justify-content:space-between;align-items:center;padding:8px 0 16px;display:flex}.sheet__head h3{font-size:19px;font-weight:800}.sheet__close{background:var(--bg-2);cursor:pointer;width:40px;height:40px;color:var(--fg-1);border:none;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.sheet__group{border-top:1px solid var(--border);padding:16px 0}.sheet__label{font-family:var(--font-head);margin:0 0 12px;font-size:14px;font-weight:700}.sheet__opts{flex-wrap:wrap;gap:8px;display:flex}.opt-pill{font-family:var(--font-body);border:1px solid var(--border);background:var(--bg-1);color:var(--fg-1);cursor:pointer;min-height:42px;transition:all .15s var(--ease);border-radius:999px;padding:9px 15px;font-size:14px;font-weight:500}.opt-pill.is-on{background:var(--brand-grad);color:#fff;border-color:#0000;font-weight:600}.sheet__actions{background:var(--bg-1);gap:10px;padding-top:18px;display:flex;position:sticky;bottom:0}.sheet__actions .btn{flex:1}.demo-switch{z-index:80;background:var(--fg-1);color:#fff;border-radius:999px;align-items:center;gap:4px;padding:5px;font-size:12.5px;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0c1a1447}.demo-switch__lbl{opacity:.7;padding:0 8px 0 10px;font-weight:600}.demo-switch button{color:#fffc;font-family:var(--font-body);cursor:pointer;transition:background-color .15s var(--ease), color .15s var(--ease);background:0 0;border:none;border-radius:999px;padding:7px 13px;font-size:12.5px;font-weight:600}.demo-switch button.is-on{background:var(--brand-grad);color:#fff}@media (min-width:900px){.filterbar{top:76px}.filterbar__fields{align-items:center;gap:12px;display:flex}.filter-trigger{display:none}.dir-hero__in{padding:48px 0 36px}}
