body:has(.av-hero) #main-content { padding: 0 !important; max-width: none !important; margin: 0 !important; }
.av-hero {
position: relative; width: 100%; height: 340px; overflow: hidden;
background: linear-gradient(135deg, var(--brand-color), var(--hero-gradient-end));
display: flex; align-items: flex-end; line-height: 0;
}
.hero-orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity: 0.6; animation: hero-float 10s infinite ease-in-out alternate; z-index: 0; }
.hero-orb-1 { width: 400px; height: 400px; background: var(--hero-orb-1); top: -100px; left: -100px; animation-delay: 0s; }
.hero-orb-2 { width: 500px; height: 500px; background: var(--hero-orb-2); bottom: -150px; right: -100px; animation-delay: -3s; }
.hero-orb-3 { width: 300px; height: 300px; background: var(--hero-orb-3); top: 50%; left: 50%; transform: translate(-50%,-50%); animation-delay: -6s; }
@keyframes hero-float { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(30px,50px) scale(1.1); } }
.hero-waves { position: absolute; bottom: -1px; left: 0; width: 100%; height: 60px; z-index: 5; }
.hero-parallax > use { animation: hero-wave-move 25s cubic-bezier(.55,.5,.45,.5) infinite; }
.hero-parallax > use:nth-child(1) { animation-delay: -2s; animation-duration: 7s; }
.hero-parallax > use:nth-child(2) { animation-delay: -3s; animation-duration: 10s; }
.hero-parallax > use:nth-child(3) { animation-delay: -4s; animation-duration: 13s; }
.hero-parallax > use:nth-child(4) { animation-delay: -5s; animation-duration: 20s; }
@keyframes hero-wave-move { 0% { transform: translate3d(-90px,0,0); } 100% { transform: translate3d(85px,0,0); } }
.av-hero-content {
position: relative; z-index: 10; width: 100%;
padding: 32px 40px 56px;
display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center;
}
.av-hero-logo {
width: 90px; height: 90px; object-fit: contain; border-radius: 18px;
background: rgba(255,255,255,0.15); padding: 10px;
backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
border: 1px solid rgba(255,255,255,0.25); margin-bottom: 4px;
}
.av-hero-title { font-size: 22px; font-weight: 600; color: var(--text-on-brand); letter-spacing: -0.02em; line-height: 1.3; margin: 0; }
.av-hero-sub   { font-size: 14px; color: rgba(255,255,255,0.8); margin: 0; line-height: 1.5; }
.av-hero-btn {
display: inline-flex; align-items: center; gap: 7px; height: 42px; padding: 0 24px;
background: var(--text-on-brand); color: var(--brand-color); border-radius: 8px;
font-family: var(--font-base); font-size: 14px; font-weight: 700; text-decoration: none;
margin-top: 4px; transition: opacity 0.15s;
}
.av-hero-btn:hover { opacity: 0.88; }
.av-inner {
padding: 32px 24px; max-width: 1440px; margin: 0 auto; width: 100%;
display: grid; grid-template-columns: 300px 1fr; gap: 16px; align-items: start;
}
.av-left { display: flex; flex-direction: column; gap: 12px; position: sticky; top: calc(72px + 16px); }
.av-card { background: var(--bg-main); border: 1px solid var(--border-color); border-radius: 12px; padding: 16px; }
.av-card-title { font-size: 17px; font-weight: 700; color: var(--text-main); margin: 0 0 14px 0; }
.av-global-score { display: flex; align-items: baseline; gap: 4px; margin-bottom: 8px; }
.av-score-big { font-size: 48px; font-weight: 800; color: var(--text-main); line-height: 1; }
.av-score-max { font-size: 18px; color: var(--text-muted); font-weight: 600; }
.av-score-count { font-size: 12px; color: var(--text-light); margin-top: 6px; }
.av-cat-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border-color); }
.av-cat-row:last-child { border-bottom: none; padding-bottom: 0; }
.av-cat-label { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--text-muted); }
.av-cat-label i { font-size: 14px; color: var(--text-light); }
.av-cat-score { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.av-cat-num { font-size: 12px; font-weight: 700; color: var(--text-main); width: 26px; text-align: right; }
.av-btn-primary {
display: flex; align-items: center; justify-content: center; gap: 7px;
height: 42px; width: 100%; background: var(--brand-color);
color: var(--text-on-brand); border-radius: 8px; font-family: var(--font-base);
font-size: 14px; font-weight: 700; text-decoration: none; transition: opacity 0.15s;
}
.av-btn-primary:hover { opacity: 0.88; }
.av-main { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.av-results-meta { font-size: 13px; color: var(--text-muted); font-weight: 500; }
.av-list { display: flex; flex-direction: column; gap: 10px; }
.av-card-item {
background: var(--bg-main); border: 1px solid var(--border-color);
border-radius: 12px; padding: 18px 20px; display: flex; flex-direction: column; gap: 14px;
transition: border-color 0.15s;
}
.av-card-item:hover { border-color: var(--brand-color); }
.av-card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.av-author-info { display: flex; align-items: center; gap: 10px; }
.av-author-name { font-size: 14px; font-weight: 700; color: var(--text-main); }
.av-author-date { font-size: 12px; color: var(--text-light); }
.av-avis-score { display: flex; align-items: center; gap: 6px; }
.av-score-emoji { font-size: 24px; line-height: 1; }
.av-score-val { font-size: 13px; font-weight: 700; color: var(--text-main); }
.av-cats-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.av-cat-chip {
display: inline-flex; align-items: center; gap: 5px;
background: var(--bg-surface); border: 1px solid var(--border-color);
border-radius: 20px; padding: 4px 10px; font-size: 12px; color: var(--text-muted);
}
.av-cat-chip i { font-size: 13px; }
.av-chip-label { font-weight: 600; color: var(--text-main); }
.av-chip-emoji { font-size: 16px; line-height: 1; }
.av-chip-score { font-size: 11px; font-weight: 700; color: var(--brand-color); }
.av-comment-wrap {
padding-top: 12px; border-top: 1px solid var(--border-color);
display: flex; flex-direction: column; gap: 4px;
}
.av-comment {
font-size: 13.5px; color: var(--text-muted); line-height: 1.7; margin: 0;
display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.av-comment.is-expanded { display: block; overflow: visible; }
.av-expand-btn {
display: inline-flex; align-items: center; gap: 4px;
background: none; border: none; padding: 0; cursor: pointer;
font-family: var(--font-base); font-size: 12px; font-weight: 600;
color: var(--brand-color); align-self: flex-start; transition: opacity 0.15s;
}
.av-expand-btn:hover { opacity: 0.75; }
.av-expand-icon { font-size: 12px; line-height: 1; transition: transform 0.2s; }
.av-empty {
display: flex; flex-direction: column; align-items: center; justify-content: center;
gap: 12px; padding: 48px 24px; background: var(--bg-main);
border: 1px solid var(--border-color); border-radius: 12px; color: var(--text-muted);
}
.av-empty i { font-size: 36px; opacity: 0.35; }
.av-empty p { font-size: 14px; margin: 0; }
.av-pagination { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
.av-page-btn {
display: inline-flex; align-items: center; justify-content: center;
width: 36px; height: 36px; border-radius: 8px; border: 1px solid var(--border-color);
background: var(--bg-main); font-size: 13px; font-weight: 600; color: var(--text-muted);
text-decoration: none; transition: color 0.15s, border-color 0.15s;
}
.av-page-btn:hover { color: var(--brand-color); border-color: var(--brand-color); }
.av-page-btn.active { background: var(--brand-color); color: var(--text-on-brand); border-color: var(--brand-color); }
.av-rating-row {
display: flex; align-items: center; justify-content: space-between;
gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-color); flex-wrap: wrap;
}
.av-rating-row:last-child { border-bottom: none; padding-bottom: 0; }
.av-rating-label {
display: flex; align-items: center; gap: 8px;
font-size: 14px; font-weight: 600; color: var(--text-main);
min-width: 160px; flex-shrink: 0;
}
.av-rating-label i { font-size: 16px; color: var(--text-muted); }
.av-emoji-group { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.av-emoji-label { display: flex; flex-direction: column; align-items: center; gap: 3px; cursor: pointer; }
.av-emoji-btn {
font-size: 26px; line-height: 1; opacity: 0.35;
transition: opacity 0.15s, transform 0.15s;
display: block;
}
.av-emoji-btn:hover { opacity: 1; transform: scale(1.2); }
.av-emoji-btn.selected { opacity: 1; transform: scale(1.25); }
.av-emoji-num { font-size: 10px; color: var(--text-light); font-weight: 600; }
@media (max-width: 860px) {
.av-inner { grid-template-columns: 1fr; }
.av-left  { position: static; }
}
@media (max-width: 768px) {
.av-hero { height: 340px; }
.hero-orb-1 { width: 200px; height: 200px; }
.hero-orb-2 { width: 250px; height: 250px; }
.hero-orb-3 { width: 150px; height: 150px; }
.hero-waves { height: 30px; }
.av-hero-content { padding: 16px 16px 36px; }
.av-inner { padding: 16px 12px; }
.av-rating-row { flex-direction: column; align-items: flex-start; }
.av-emoji-btn { font-size: 22px; }
}