:root{--card-radius:16px;--card-transition:all .3s cubic-bezier(.4, 0, .2, 1)}.chocolate-card{background:var(--background-primary);border:1px solid var(--border-light);border-radius:var(--card-radius);box-shadow:var(--shadow-md);transition:var(--card-transition);cursor:pointer;width:100%;height:auto;min-height:380px;color:inherit;flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:visible}.chocolate-card:hover{box-shadow:var(--shadow-xl);border-color:var(--star-color);transform:translateY(-6px)}.chocolate-card.featured{border:2px solid var(--star-color);box-shadow:0 6px 20px #f59e0b26}.image-container{background:linear-gradient(135deg, #fefefe 0%, var(--background-accent,#f8fafc) 100%);border-bottom:1px solid var(--border-light);justify-content:center;align-items:center;width:100%;height:220px;padding:20px;display:flex;position:relative;overflow:hidden}.image-container img,.card-image{object-fit:contain;width:auto;max-width:85%;height:85%;transition:transform .5s}.chocolate-card:hover .image-container img{transform:scale(1.05)}.card-actions{z-index:10;flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;top:12px;right:12px}.card-actions>*{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;background:#fffffff2;border:1px solid #00000014;border-radius:50%;transition:all .2s;box-shadow:0 2px 8px #0000001a;justify-content:center!important;align-items:center!important;width:36px!important;height:36px!important;padding:0!important;display:flex!important}.card-actions>:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.card-actions svg{width:18px!important;height:18px!important;margin:0!important}.favorite-button svg{stroke:#9ca3af;fill:none;stroke-width:2px}.favorite-button:hover svg{stroke:#ef4444;fill:#ef44441a}.favorite-button.favorited svg{fill:#ef4444;stroke:#ef4444}.want-to-try-button svg{stroke:#9ca3af;fill:none;stroke-width:2px}.want-to-try-button:hover svg{stroke:var(--star-color);fill:#f59e0b1a}.want-to-try-button.active svg,.want-to-try-button.added svg{fill:var(--star-color);stroke:var(--star-color)}.card-content{background:var(--background-primary);flex-direction:column;flex:1;gap:0;min-height:fit-content;padding:16px 16px 20px;display:flex;overflow:visible}.chocolate-title-link{color:inherit;margin-bottom:2px;text-decoration:none;display:block}.card-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 6px;font-size:1.05rem;font-weight:700;line-height:1.2;transition:color .2s;display:-webkit-box;overflow:hidden}.chocolate-title-link:hover .card-title{color:var(--star-color)}.card-maker-link{color:inherit;margin-bottom:4px;text-decoration:none;transition:color .2s}.card-maker{text-transform:uppercase;letter-spacing:.5px;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.8rem;font-weight:600;line-height:1.1;overflow:hidden;color:var(--maker-color)!important}.card-maker-link:hover .card-maker{color:var(--primary-hover)!important}.card-rating{border-top:1px solid var(--border-light);align-items:center;gap:6px;min-height:32px;margin-top:auto;padding:8px 0 6px;display:flex;overflow:visible}.rating-value{color:var(--text-primary);min-width:32px;font-size:1rem;font-weight:800}.stars{align-items:center;gap:1px;height:20px;line-height:20px;display:inline-flex;overflow:visible}.stars .star{text-align:center;width:16px;height:20px;font-size:16px;line-height:20px;transition:transform .2s;display:inline-block}.stars .star.filled{color:var(--star-color);text-shadow:0 1px 3px #f59e0b4d}.stars .star.half{color:var(--star-color);opacity:.5}.stars .star.empty{color:var(--star-empty)}.chocolate-card:hover .stars .star.filled{transform:scale(1.05)}.rating-count{color:var(--text-secondary);white-space:nowrap;margin-left:4px;font-size:.75rem;font-weight:500}.chocolate-card a,.chocolate-card a *,.chocolate-card a:link,.chocolate-card a:visited,.chocolate-card a:hover,.chocolate-card a:active{color:inherit;text-decoration:none}.chocolate-card .card-title:after,.chocolate-card .card-title:before,.chocolate-card .card-maker:after,.chocolate-card .card-maker:before,.chocolate-card .chocolate-title-link:after,.chocolate-card .chocolate-title-link:before,.chocolate-card .card-maker-link:after,.chocolate-card .card-maker-link:before{content:none;display:none}.chocolate-grid,.chocolate-cards,.featured-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1400px;margin:20px auto 40px;padding:0 20px;display:grid}.chocolate-card.loading .image-container{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (min-width:1200px){.chocolate-grid,.chocolate-cards,.featured-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}}@media (max-width:768px){.chocolate-card{min-height:340px}.image-container{height:180px;padding:15px}.image-container img,.card-image{max-width:75%;height:75%}.card-content{padding:14px 14px 18px}.card-title{margin-bottom:4px;font-size:1rem}.card-maker{font-size:.75rem}.card-actions{top:10px;right:10px}.card-actions>*{width:32px!important;height:32px!important}.card-actions svg{width:16px!important;height:16px!important}.card-rating{padding-top:6px;padding-bottom:4px}}@media (max-width:480px){.chocolate-card{min-height:320px}.image-container{height:240px;padding:12px}.image-container img,.card-image{max-width:90%;height:90%}.card-content{gap:8px;padding:14px 14px 18px}.card-title{font-size:.95rem}.card-maker{font-size:.8rem}.chocolate-grid{grid-template-columns:1fr;gap:16px;padding:0 16px}}.chocolate-card:focus-visible,.card-maker-link:focus-visible,.chocolate-title-link:focus-visible{outline:2px solid var(--star-color);outline-offset:2px;border-radius:var(--card-radius)}.card-actions>:focus-visible{outline:2px solid var(--star-color);outline-offset:2px}@media (prefers-reduced-motion:reduce){.chocolate-card,.image-container img,.stars .star,.card-actions>*{transition:none}.chocolate-card:hover .stars .star.filled{transform:none}}
