.user-profile-page{background-color:var(--background,#f8f9fa);min-height:calc(100vh - 60px);padding:2rem 0}.user-profile-page .container{max-width:800px;margin:0 auto;padding:0 1rem}.user-profile-page .loading-container{text-align:center;flex-direction:column;align-items:center;padding:4rem 2rem;display:flex}.user-profile-page .loading-spinner{border:3px solid var(--border-light,#e5e7eb);border-top:3px solid var(--brand-copper,#a73a04);border-radius:50%;width:2.5rem;height:2.5rem;margin-bottom:1rem;animation:.8s linear infinite up-spin}@keyframes up-spin{to{transform:rotate(360deg)}}.up-header{background:#fff;border-radius:12px;margin-bottom:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000000f}.up-header-top{align-items:flex-start;gap:1.25rem;display:flex}.up-avatar{background:linear-gradient(135deg,#f4a261,#f4d03f);border:3px solid #ffffffe6;border-radius:50%;flex-shrink:0;width:80px;height:80px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.up-avatar img{object-fit:cover;width:100%;height:100%}.up-avatar-placeholder{color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;font-weight:700;display:flex}.up-info{flex:1;min-width:0}.up-name-row{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.up-info h1{color:var(--text-primary,#2c2c2c);margin:0;font-size:1.5rem;font-weight:700;line-height:1.3}.up-location{color:var(--text-secondary,#788390);align-items:center;gap:.25rem;margin-bottom:.5rem;font-size:.8125rem;display:flex}.up-bio{color:var(--text-primary,#2c2c2c);margin:0 0 .75rem;font-size:.9rem;line-height:1.5}.up-stats{color:var(--text-secondary,#788390);gap:1.25rem;margin-bottom:.75rem;font-size:.875rem;display:flex}.up-stats strong{color:var(--text-primary,#2c2c2c);font-weight:700}.up-badges{flex-wrap:wrap;gap:.5rem;display:flex}.up-badge{color:var(--text-primary,#374151);background:#f8f8f8;border-radius:100px;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.8125rem;font-weight:500;display:flex}.up-badge svg{width:14px;height:14px}.up-badge svg.newcomer{fill:#6b7280}.up-badge svg.reviewer{fill:#eab308}.up-badge svg.enthusiast{fill:#2563eb}.up-badge svg.connoisseur{fill:#9333ea}.follow-btn{cursor:pointer;border:2px solid var(--brand-copper,#a73a04);white-space:nowrap;border-radius:8px;padding:.5rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.follow-btn:disabled{opacity:.5;cursor:not-allowed}.follow-btn:not(.is-following){background:var(--brand-copper,#a73a04);color:#fff}.follow-btn:not(.is-following):hover{background:var(--primary-hover,#8b2f03);border-color:var(--primary-hover,#8b2f03)}.follow-btn.is-following{color:var(--brand-copper,#a73a04);background:#fff}.follow-btn.is-following:hover{color:#dc2626;background:#fef2f2;border-color:#dc2626}.up-tabs{background:#fff;border-radius:8px;margin-bottom:1rem;display:flex;overflow:hidden;box-shadow:0 1px 4px #0000000d}.up-tab{color:var(--text-secondary,#788390);cursor:pointer;text-align:center;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.up-tab:hover{color:var(--text-primary,#2c2c2c);background:#fafafa}.up-tab.active{color:var(--brand-copper,#a73a04);border-bottom-color:var(--brand-copper,#a73a04)}.up-review{background:#fff;border-radius:10px;margin-bottom:.75rem;padding:1rem 1.25rem;box-shadow:0 1px 4px #0000000a}.up-review-header{justify-content:space-between;align-items:center;margin-bottom:.375rem;display:flex}.up-review-chocolate{color:var(--text-primary,#2c2c2c);margin:0;font-size:1rem;font-weight:700;text-decoration:none}.up-review-chocolate:hover{color:var(--brand-copper,#a73a04)}.up-review-stars{color:var(--star-color,#f59e0b);letter-spacing:-1px;font-size:.875rem}.up-review-stars .empty{color:var(--star-empty,#e5e7eb)}.up-review-maker{color:var(--maker-color,#b8693d);margin:0 0 .375rem;font-size:.8125rem}.up-review-text{color:var(--text-primary,#374151);margin:0 0 .5rem;font-size:.875rem;line-height:1.5}.up-review-date{color:var(--text-secondary,#788390);margin:0;font-size:.75rem}.up-favorites-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;display:grid}.up-fav-card{background:#fff;border-radius:10px;text-decoration:none;transition:all .2s;overflow:hidden;box-shadow:0 1px 4px #0000000a}.up-fav-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.up-fav-img{background:var(--background-accent,#f8f6f3);justify-content:center;align-items:center;width:100%;height:120px;display:flex}.up-fav-img img{object-fit:cover;width:100%;height:100%}.up-fav-img .placeholder{font-size:2rem}.up-fav-info{padding:.625rem}.up-fav-name{color:var(--text-primary,#2c2c2c);margin:0 0 .125rem;font-size:.8125rem;font-weight:700;line-height:1.3}.up-fav-maker{color:var(--maker-color,#b8693d);margin:0;font-size:.75rem}.up-empty{text-align:center;color:var(--text-secondary,#788390);padding:2rem 1rem}.up-empty h4{color:var(--text-primary,#2c2c2c);margin:0 0 .25rem;font-size:1rem}.up-empty p{margin:0;font-size:.875rem}.up-private{text-align:center;background:#fff;border-radius:12px;margin-top:1rem;padding:2.5rem 1.5rem;box-shadow:0 2px 8px #0000000f}.up-private svg{width:48px;height:48px;color:var(--text-secondary,#788390);margin-bottom:.75rem}.up-private h3{color:var(--text-primary,#2c2c2c);margin:0 0 .375rem;font-size:1.125rem}.up-private p{color:var(--text-secondary,#788390);margin:0;font-size:.875rem}.up-error{text-align:center;background:#fff;border-radius:12px;padding:3rem 1.5rem;box-shadow:0 2px 8px #0000000f}.up-error h2{color:var(--text-primary,#2c2c2c);margin:0 0 .5rem}.up-error p{color:var(--text-secondary,#788390);margin:0 0 1.25rem}@media (max-width:600px){.up-header-top{text-align:center;flex-direction:column;align-items:center}.up-name-row,.up-location,.up-stats,.up-badges{justify-content:center}.up-info h1{font-size:1.25rem}.follow-btn{width:100%;margin-top:.5rem}.up-favorites-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
