
/* ==========================================================================
   dream-hubs.css – tematické huby pro sny (mobile first)
   ========================================================================== */

:root{--hub-brand:#4d5fd6;--hub-brand-dark:#2f3e8c;--hub-accent:#7a37c7;--hub-ink:#23245e;--hub-line:#e7e9f3;--hub-card:#ffffff;--hub-shadow:0 12px 32px rgba(16,24,40,.08)}
.hub-page-main{width:100%;max-width:1120px;margin:0 auto;padding:88px 14px 120px;box-sizing:border-box}.hub-breadcrumb{margin:0 0 16px;color:#6f7594;font-size:13px;line-height:1.5}.hub-breadcrumb a{color:#4d5fd6;text-decoration:none}
.hub-hero{border:1px solid var(--hub-line);background:linear-gradient(180deg,#fbfcff 0%,#f7f8ff 100%);border-radius:24px;padding:20px 16px;box-shadow:var(--hub-shadow)}
.hub-kicker{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;background:#efe8ff;color:#5a2ea6;font-size:12px;font-weight:800;letter-spacing:.2px;text-transform:uppercase}
.hub-title{margin:14px 0 10px;color:var(--hub-ink);font-size:clamp(28px,7vw,44px);line-height:1.12;font-weight:900}.hub-lead{margin:0;color:#39405f;font-size:16px;line-height:1.75}
.hub-cta-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:18px}.hub-cta-card{border:1px solid var(--hub-line);border-radius:18px;padding:16px 14px;background:#fff}.hub-cta-card.free{background:#f7fbff}.hub-cta-card.paid{background:#fbf8ff}
.hub-cta-badge{display:inline-flex;min-height:28px;align-items:center;padding:4px 10px;border-radius:999px;background:#e8f6ee;color:#17603a;font-size:12px;font-weight:800}.hub-cta-card.paid .hub-cta-badge{background:#efe8ff;color:#5a2ea6}
.hub-cta-card h2{margin:12px 0 8px;color:var(--hub-ink);font-size:22px;line-height:1.25}.hub-cta-card p{margin:0 0 14px;color:#4a516f;font-size:15px;line-height:1.65}
.hub-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:46px;padding:11px 16px;border-radius:999px;text-decoration:none;font-size:14px;font-weight:800;box-sizing:border-box}.hub-btn.primary{background:linear-gradient(135deg,var(--hub-accent) 0%,var(--hub-brand) 100%);color:#fff;box-shadow:0 10px 24px rgba(90,46,166,.22)}.hub-btn.secondary{background:#fff;color:var(--hub-brand-dark);border:1px solid #dbe2ff}
.hub-section{margin-top:18px;border:1px solid var(--hub-line);background:var(--hub-card);border-radius:22px;padding:18px 16px;box-shadow:var(--hub-shadow)}.hub-section h2{margin:0 0 8px;color:var(--hub-ink);font-size:24px;line-height:1.25;font-weight:900}.hub-section-intro{margin:0 0 14px;color:#45506d;font-size:15px;line-height:1.72}
.hub-grid{display:grid;grid-template-columns:1fr;gap:12px}.hub-card{border:1px solid var(--hub-line);border-radius:16px;background:#fff;padding:14px 14px}.hub-card h3{margin:0 0 8px;color:var(--hub-ink);font-size:18px;line-height:1.35}.hub-card p{margin:0;color:#4c5574;font-size:14px;line-height:1.65}
.hub-symbols{display:flex;flex-wrap:wrap;gap:8px}.hub-chip{display:inline-flex;align-items:center;min-height:34px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid #dfe5ff;text-decoration:none;color:#3f4e93;font-size:13px;font-weight:700}
.hub-list{margin:0;padding-left:18px;color:#4b5572}.hub-list li{margin-bottom:10px;line-height:1.7}.hub-faq details{border:1px solid var(--hub-line);border-radius:16px;padding:14px 14px;background:#fff}.hub-faq details+details{margin-top:10px}.hub-faq summary{cursor:pointer;color:var(--hub-ink);font-weight:800;line-height:1.55}.hub-faq p{margin:10px 0 0;color:#4c5574;font-size:14px;line-height:1.7}
.hub-closing{display:grid;gap:12px}.hub-note{border-left:4px solid var(--hub-accent);background:#faf7ff;border-radius:14px;padding:14px 14px;color:#50557c;font-size:14px;line-height:1.7}.hub-related{display:grid;gap:10px}.hub-related a{text-decoration:none;color:var(--hub-brand-dark);font-weight:800}
.hub-mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:9990;background:rgba(255,255,255,.96);border-top:1px solid rgba(0,0,0,.08);backdrop-filter:saturate(160%) blur(8px);padding:10px 12px calc(10px + env(safe-area-inset-bottom));box-shadow:0 -10px 28px rgba(16,24,40,.08)}.hub-mobile-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px;color:#5d6688;font-size:12px;font-weight:700}
@media (min-width:760px){.hub-page-main{padding:96px 18px 60px}.hub-cta-grid{grid-template-columns:1fr 1fr}.hub-grid.three{grid-template-columns:repeat(3,1fr)}.hub-closing{grid-template-columns:1.2fr .8fr}.hub-mobile-bar{display:none}}
@media (min-width:980px){.hub-hero{padding:26px 24px}.hub-section{padding:24px 22px}}
