.product-hub{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#eef2ff 40%,#f0f9ff 80%,#f8fafc);font-family:Fredoka,sans-serif;overflow-x:hidden}.hub-hero{text-align:center;padding:100px 24px 40px;max-width:720px;margin:0 auto;position:relative}.hub-hero:before{content:"";position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(26,115,232,.06) 0,transparent 70%);pointer-events:none;z-index:0}.hub-logo{font-size:3.2rem;font-weight:700;color:#1a73e8;margin-bottom:8px;text-shadow:2px 2px 4px rgba(26,115,232,.12);animation:hubFadeInDown .8s ease-out}.hub-logo,.hub-tagline{position:relative;z-index:1}.hub-tagline{font-size:1.35rem;font-weight:500;color:#444;margin-bottom:12px;animation:hubFadeInUp .7s ease-out .15s both}.hub-subtitle{font-size:1rem;color:#888;max-width:480px;margin:0 auto 8px;line-height:1.6;position:relative;z-index:1;animation:hubFadeInUp .7s ease-out .3s both}.hub-auth-links{display:flex;justify-content:center;gap:16px;margin-top:24px;animation:hubFadeInUp .7s ease-out .4s both}.hub-auth-links,.hub-grid{position:relative;z-index:1}.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1080px;margin:0 auto;padding:20px 24px 60px}.hub-card{position:relative;background:#fff;border-radius:24px;padding:36px 28px 32px;border:2px solid #f0f0f0;transition:all .4s cubic-bezier(.25,.8,.25,1);text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:flex-start;overflow:hidden;cursor:pointer;animation:hubCardIn .6s ease-out both}.hub-card:first-child{animation-delay:.35s}.hub-card:nth-child(2){animation-delay:.45s}.hub-card:nth-child(3){animation-delay:.55s}.hub-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.12)}.hub-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:24px 24px 0 0;transition:height .4s ease}.hub-card:hover:before{height:6px}.hub-card[data-product=living]:before{background:linear-gradient(90deg,#f93,#f60)}.hub-card[data-product=living]:hover{border-color:rgba(255,153,51,.3);box-shadow:0 16px 48px rgba(255,153,51,.12)}.hub-card[data-product=compliance]:before{background:linear-gradient(90deg,#1a73e8,#0d5bba)}.hub-card[data-product=compliance]:hover{border-color:rgba(26,115,232,.3);box-shadow:0 16px 48px rgba(26,115,232,.12)}.hub-card[data-product=tender]:before{background:linear-gradient(90deg,#0d9488,#0f766e)}.hub-card[data-product=tender]:hover{border-color:rgba(13,148,136,.3);box-shadow:0 16px 48px rgba(13,148,136,.12)}.hub-card-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:20px;transition:transform .3s ease}.hub-card:hover .hub-card-icon{transform:scale(1.08)}.hub-card[data-product=living] .hub-card-icon{background:linear-gradient(135deg,rgba(255,153,51,.1),rgba(255,102,0,.08))}.hub-card[data-product=compliance] .hub-card-icon{background:linear-gradient(135deg,rgba(26,115,232,.1),rgba(13,91,186,.08))}.hub-card[data-product=tender] .hub-card-icon{background:linear-gradient(135deg,rgba(13,148,136,.1),rgba(15,118,110,.08))}.hub-card-status{display:inline-block;padding:3px 12px;border-radius:50px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}.hub-card-status.active{background:#ecfdf5;color:#059669;border:1px solid #bbf7d0}.hub-card-status.coming-soon{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.hub-card h2{font-size:1.35rem;font-weight:700;color:#333;margin-bottom:8px;line-height:1.3}.hub-card p{font-size:.92rem;color:#666;line-height:1.6;margin-bottom:20px;flex:1}.hub-card-features{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.hub-feature-chip{padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:500;background:#f8f9fa;color:#666;border:1px solid #f0f0f0;white-space:nowrap}.hub-card-cta{display:inline-flex;align-items:center;gap:6px;font-size:.95rem;font-weight:600;padding:10px 24px;border-radius:50px;transition:all .3s ease;text-decoration:none;border:none;cursor:pointer;font-family:Fredoka,sans-serif;min-height:44px}.hub-card[data-product=living] .hub-card-cta{background:rgba(255,153,51,.08);color:#c2410c}.hub-card[data-product=living]:hover .hub-card-cta{background:linear-gradient(135deg,#f93,#f60);color:#fff;box-shadow:0 4px 15px rgba(255,153,51,.3)}.hub-card[data-product=compliance] .hub-card-cta{background:rgba(26,115,232,.08);color:#1a73e8}.hub-card[data-product=compliance]:hover .hub-card-cta{background:linear-gradient(135deg,#1a73e8,#0d5bba);color:#fff;box-shadow:0 4px 15px rgba(26,115,232,.3)}.hub-card[data-product=tender] .hub-card-cta{background:rgba(13,148,136,.08);color:#0d9488}.hub-card[data-product=tender]:hover .hub-card-cta{background:linear-gradient(135deg,#0d9488,#0f766e);color:#fff;box-shadow:0 4px 15px rgba(13,148,136,.3)}.hub-bottom{text-align:center;padding:0 24px 60px;animation:hubFadeInUp .7s ease-out .7s both}.hub-bottom-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 24px;border-radius:50px;background:#fff;border:1px solid #f0f0f0;font-size:.85rem;color:#888;box-shadow:0 2px 8px rgba(0,0,0,.04)}.hub-bottom-badge strong{color:#1a73e8;font-weight:600}.hub-footer{border-top:1px solid #f0f0f0;padding:32px 24px;background:#fff;text-align:center;font-size:.82rem;color:#999}.hub-footer a{color:#1a73e8;text-decoration:none;font-weight:500;transition:color .2s}.hub-footer a:hover{color:#0d5bba}@keyframes hubFadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes hubFadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes hubCardIn{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:768px){.hub-hero{padding:88px 20px 28px}.hub-logo{font-size:2.6rem}.hub-tagline{font-size:1.15rem}.hub-grid{grid-template-columns:1fr;gap:16px;padding:12px 16px 40px}.hub-card{padding:28px 24px 24px}.hub-card h2{font-size:1.2rem}}@media (max-width:480px){.hub-hero{padding:80px 16px 24px}.hub-logo{font-size:2.2rem}.hub-tagline{font-size:1.05rem}.hub-subtitle{font-size:.9rem}.hub-auth-links{gap:10px}.hub-card{padding:24px 20px 20px}.hub-card-icon{width:48px;height:48px;font-size:1.4rem;margin-bottom:16px}}@media (hover:none) and (pointer:coarse){.hub-card:hover{transform:none;box-shadow:0 4px 20px rgba(0,0,0,.08)}.hub-card:hover .hub-card-icon{transform:none}.hub-card:hover:before{height:4px}.hub-card[data-product=compliance]:hover .hub-card-cta,.hub-card[data-product=living]:hover .hub-card-cta,.hub-card[data-product=tender]:hover .hub-card-cta{background:inherit;color:inherit;box-shadow:none}.hub-card:active{transform:scale(.98);transition:transform .1s ease}}