.favorites-page{max-width:1200px;margin:0 auto;padding:2rem;min-height:60vh}.favorites-page h1{font-size:2rem;color:var(--coffee-dark);margin-bottom:.5rem}.favorites-subtitle{color:var(--text-secondary);font-size:1rem;margin-bottom:2rem}.favorites-sync-panel{margin-bottom:1.5rem;padding:.9rem 1rem;border:1px solid var(--border);border-radius:10px;background:#fff}.favorites-sync-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.favorites-sync-status{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.02em}.favorites-sync-status--idle,.favorites-sync-status--connecting,.favorites-sync-status--syncing{color:#7a4f12;background:#f8edd8}.favorites-sync-status--synced{color:#19672b;background:#dff4e5}.favorites-sync-status--error{color:#8f1f1f;background:#f9dede}.favorites-sync-time{color:var(--text-secondary);font-size:.8rem}.favorites-sync-copy{margin:.6rem 0 0;color:var(--text-secondary);font-size:.9rem}.favorites-sync-form{margin-top:.7rem;display:flex;gap:.5rem;flex-wrap:wrap}.favorites-sync-form input{flex:1 1 260px;min-width:0;padding:.5rem .65rem;border:1px solid var(--border);border-radius:7px;font-size:.9rem;background:#fff;color:var(--text-primary)}.favorites-sync-form input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #c47e1e1f}.favorites-sync-form button{padding:.5rem .85rem;border:1px solid var(--accent);border-radius:7px;background:var(--accent);color:#fff;font-size:.86rem;font-weight:600;cursor:pointer}.favorites-sync-form button:disabled{opacity:.65;cursor:wait}.favorites-sync-error{margin:.6rem 0 0;color:var(--error);font-size:.85rem}.favorites-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:2rem}.favorites-tab{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.favorites-tab:hover{color:var(--coffee-dark);background:#c17f240d}.favorites-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.favorites-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--border);color:var(--text-secondary);font-size:.75rem;font-weight:700}.favorites-tab.active .favorites-tab-count{background:var(--accent);color:#fff}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.favorites-card{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;transition:all .2s ease;box-shadow:var(--shadow)}.favorites-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.favorites-card-content{display:flex;gap:1rem;padding:1rem}.favorites-card-image{width:80px;height:100px;flex-shrink:0;border-radius:8px;overflow:hidden;background:var(--cream);display:flex;align-items:center;justify-content:center}.favorites-card-image img{width:100%;height:100%;object-fit:cover}.favorites-card-info{flex:1;min-width:0}.favorites-card-name{font-size:1rem;font-weight:600;color:var(--coffee-dark);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorites-card-brand{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.favorites-card-details{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.favorites-card-tag{display:inline-flex;align-items:center;padding:.2rem .5rem;background:var(--cream);border-radius:4px;font-size:.75rem;color:var(--text-secondary)}.favorites-card-bottom{display:flex;align-items:center;justify-content:space-between}.favorites-card-rating{display:flex;align-items:center;gap:.25rem;font-size:.85rem;font-weight:600;color:var(--accent)}.favorites-card-price{font-size:.9rem;font-weight:600;color:var(--coffee-dark)}.favorites-card-footer{display:flex;align-items:center;justify-content:flex-end;padding:.5rem 1rem;border-top:1px solid var(--border);background:#f5f0e84d}.favorites-remove-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.favorites-remove-btn:hover{background:var(--error);border-color:var(--error);color:#fff}.favorites-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.favorites-empty-icon{color:var(--border);margin-bottom:1.5rem;opacity:.6}.favorites-empty h3{font-size:1.25rem;color:var(--coffee-dark);margin-bottom:.5rem}.favorites-empty p{color:var(--text-secondary);font-size:.95rem;max-width:400px;line-height:1.5}.favorites-loading{display:flex;align-items:center;justify-content:center;padding:4rem}.favorites-loading .spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.favorites-page{padding:1.25rem}.favorites-page h1{font-size:1.5rem}.favorites-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.favorites-tab{padding:.75rem 1rem;font-size:.85rem}.favorites-grid{grid-template-columns:1fr}.favorites-sync-panel{padding:.8rem}.favorites-sync-form button{width:100%}}@media (max-width: 480px){.favorites-page{padding:1rem}.favorites-tab{padding:.625rem .75rem;font-size:.8rem;gap:.375rem}.favorites-tab-count{min-width:20px;height:20px;font-size:.7rem}.favorites-card-content{padding:.875rem}.favorites-card-image{width:64px;height:80px}}
