/**
 * Laptop Post Styles
 *
 * Styles for laptop/notebook product reviews.
 * Extends product-review-base.css with laptop-specific components.
 * Theme: Dark (#2d2d3a) with Purple accents (#673AB7) - matches Desktop
 *
 * @package VividUltimate
 * @since 3.5.168
 */

/* ==========================================================================
   Laptop Theme Variables (matches Desktop)
   ========================================================================== */

.vae-laptop-post {
    --vae-accent-color: #673AB7;
    --vae-accent-hover: #5e35b1;
    --vae-accent-light: #ede7f6;
    --vae-dark-bg: #2d2d3a;
    --vae-dark-text: #ffffff;
}

/* ==========================================================================
   Key Takeaways - Dark Theme (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-key-takeaways {
    background: var(--vae-dark-bg);
    padding: 25px;
    border-radius: 12px;
    margin: 25px 0;
    color: #fff;
}

.vae-laptop-post .vae-key-takeaways h3 {
    color: #fff !important;
    margin: 0 0 15px 0 !important;
    font-size: 1.3em;
    font-weight: bold;
}

.vae-laptop-post .vae-key-takeaways ul {
    margin: 0;
    padding-left: 20px;
}

.vae-laptop-post .vae-key-takeaways li {
    color: #fff;
    margin-bottom: 8px;
    line-height: 1.6;
}

/* Ratings grid inside key takeaways */
.vae-laptop-post .vae-key-takeaways .vae-ratings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 12px;
    margin-top: 20px;
}

.vae-laptop-post .vae-key-takeaways .vae-rating-item {
    background: var(--vae-accent-color);
    padding: 12px;
    border-radius: 6px;
    text-align: center;
}

.vae-laptop-post .vae-key-takeaways .vae-rating-label {
    font-size: 0.85em;
    opacity: 0.9;
    display: block;
    margin-bottom: 5px;
    color: #fff;
}

.vae-laptop-post .vae-key-takeaways .vae-rating-value {
    font-size: 1.4em;
    font-weight: bold;
    color: #fff;
}

/* ==========================================================================
   Quick Verdict - Accent Theme (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-quick-verdict {
    border-left: 4px solid var(--vae-accent-color);
    background: var(--vae-accent-light);
    padding: 20px;
    margin: 25px 0;
    border-radius: 0 8px 8px 0;
}

.vae-laptop-post .vae-quick-verdict .vae-verdict-title,
.vae-laptop-post .vae-quick-verdict strong {
    color: var(--vae-accent-color);
    font-size: 1.1em;
    display: block;
    margin-bottom: 8px;
}

.vae-laptop-post .vae-quick-verdict .vae-verdict-text,
.vae-laptop-post .vae-quick-verdict p {
    color: #333;
    margin: 0;
    line-height: 1.6;
}

/* ==========================================================================
   Laptop Specs Box - Dark Theme
   ========================================================================== */

.vae-laptop-specs-box {
    background: var(--vae-dark-bg, #2d2d3a);
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
    color: #fff;
}

.vae-laptop-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-laptop-icon {
    font-size: 32px;
}

.vae-laptop-title,
.vae-laptop-specs-box h3,
.vae-laptop-specs-box h4 {
    margin: 0 !important;
    color: #fff !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-laptop-specs-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
}

.vae-laptop-spec-item {
    background: rgba(255, 255, 255, 0.08);
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    transition: transform 0.2s ease, border-top 0.2s ease;
    border-top: 3px solid transparent;
}

.vae-laptop-spec-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color, #673AB7);
}

.vae-laptop-spec-value {
    display: block;
    font-size: 1.3em;
    font-weight: 700;
    color: #fff;
    margin-bottom: 5px;
}

.vae-laptop-spec-label {
    display: block;
    font-size: 0.85em;
    color: rgba(255, 255, 255, 0.7);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media (max-width: 768px) {
    .vae-laptop-specs-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .vae-laptop-specs-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Display Analysis - LIGHT Theme (visual break from dark boxes)
   ========================================================================== */

.vae-display-analysis {
    background: #f8f9fa;
    border: 1px solid #e0e0e0;
    color: #333;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-display-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-display-icon {
    font-size: 28px;
}

.vae-display-title,
.vae-display-analysis h3,
.vae-display-analysis h4 {
    margin: 0 0 20px 0 !important;
    color: #333 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-display-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.vae-display-item {
    text-align: center;
    padding: 20px 15px;
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-display-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-display-value {
    display: block;
    font-size: 1.5em;
    font-weight: 700;
    color: var(--vae-accent-color);
}

.vae-display-label {
    display: block;
    font-size: 12px;
    color: #666;
    margin-top: 8px;
    text-transform: uppercase;
}

.vae-display-rating {
    margin-top: 20px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.vae-display-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

.vae-display-badge.vae-good {
    background: #e6f7ed;
    color: #00875a;
    border: 1px solid #a8e6c3;
}

.vae-display-badge.vae-average {
    background: #fef3e6;
    color: #d97706;
    border: 1px solid #fcd9a8;
}

.vae-display-badge.vae-poor {
    background: #fde8e8;
    color: #dc2626;
    border: 1px solid #f5c6c6;
}

/* ==========================================================================
   Battery Meter - Dark Theme
   ========================================================================== */

.vae-battery-meter {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-battery-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-battery-icon {
    font-size: 28px;
}

.vae-battery-title,
.vae-battery-meter h3,
.vae-battery-meter h4 {
    margin: 0 0 20px 0 !important;
    color: #fff !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-battery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.vae-battery-item {
    padding: 20px;
    background: rgba(255,255,255,0.08);
    border-radius: 8px;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-battery-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

/* Battery item emojis - 30px standard */
.vae-battery-icon {
    display: block;
    font-size: 30px;
    margin-bottom: 8px;
}

.vae-battery-hours {
    display: block;
    font-size: 2.5em;
    font-weight: 700;
    color: #4caf50;
}

.vae-battery-hours[data-level="good"] {
    color: #00d509;
}

.vae-battery-hours[data-level="average"] {
    color: #ff9800;
}

.vae-battery-hours[data-level="poor"] {
    color: #f44336;
}

.vae-battery-label {
    display: block;
    font-size: 13px;
    color: #fff;
    margin-top: 8px;
    text-transform: uppercase;
    font-weight: 400;
}

.vae-battery-capacity {
    margin-top: 20px;
    padding: 15px;
    background: rgba(255,255,255,0.05);
    border-radius: 8px;
    text-align: center;
    color: #fff;
}

/* ==========================================================================
   Thermal/Performance Chart - Dark Theme
   ========================================================================== */

.vae-thermal-chart {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-thermal-chart h3,
.vae-thermal-chart h4 {
    margin: 0 0 20px 0 !important;
    color: #fff !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-performance-bars {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.vae-perf-bar-item {
    display: grid;
    grid-template-columns: 110px 110px 1fr;
    align-items: end;
    gap: 15px;
}

@media (max-width: 600px) {
    .vae-perf-bar-item {
        grid-template-columns: 1fr;
        gap: 8px;
    }
}

.vae-perf-label {
    font-weight: 600;
    color: rgb(255 255 255);
    font-size: 16px;
}

.vae-perf-track {
    height: 24px;
    background: rgba(255,255,255,0.1);
    border-radius: 12px;
    overflow: hidden;
}

.vae-perf-fill {
    height: 100%;
    border-radius: 12px;
    background: linear-gradient(90deg, var(--vae-accent-color), #9575cd);
}

.vae-perf-value {
    font-weight: 700;
    color: #fff;
    font-size: 13px;
    background: var(--vae-accent-color);
    padding: 8px 16px;
    border-radius: 20px;
    text-align: center;
}

.vae-throttle-warning {
    margin-top: 20px;
    padding: 15px;
    background: rgb(255 255 255 / 15%);
    border-left: 4px solid #3aeb0e;
    border-radius: 0 8px 8px 0;
    color: #fff;
}

/* ==========================================================================
   Portability Stats - LIGHT Theme (visual break from dark boxes)
   ========================================================================== */

.vae-portability-stats {
    background: #f8f9fa;
    border: 1px solid #e0e0e0;
    color: #333;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-portability-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-portability-icon {
    font-size: 28px;
}

.vae-portability-title,
.vae-portability-stats h3,
.vae-portability-stats h4 {
    margin: 0 0 20px 0 !important;
    color: #333 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-portability-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    text-align: center;
    margin-bottom: 20px;
}

@media (max-width: 600px) {
    .vae-portability-grid {
        grid-template-columns: 1fr;
    }
}

.vae-portability-item {
    padding: 20px;
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-portability-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-portability-value {
    display: block;
    font-size: 1.8em;
    font-weight: 700;
    color: var(--vae-accent-color);
}

.vae-portability-label {
    display: block;
    font-size: 12px;
    color: #666;
    margin-top: 8px;
    text-transform: uppercase;
}

.vae-portability-verdict {
    padding: 15px 20px;
    border-radius: 8px;
    text-align: center;
    font-weight: 500;
}

.vae-portability-verdict.vae-ultraportable {
    background: #e6f7ed;
    color: #00875a;
    border: 1px solid #a8e6c3;
}

.vae-portability-verdict.vae-portable {
    background: var(--vae-accent-light);
    color: var(--vae-accent-color);
    border: 1px solid #d1c4e9;
}

.vae-portability-verdict.vae-heavy {
    background: #fef3e6;
    color: #d97706;
    border: 1px solid #fcd9a8;
}

/* ==========================================================================
   Build Quality Box - Dark Theme
   ========================================================================== */

.vae-build-quality-box {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-build-title,
.vae-build-quality-box h3,
.vae-build-quality-box h4 {
    margin: 0 0 20px 0 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
    color: #fff !important;
}

/* Materials Grid - Prompt HTML Structure */
.vae-build-materials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-build-materials {
        grid-template-columns: 1fr;
    }
}

.vae-material-item {
    background: rgba(255,255,255,0.08);
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-material-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

/* Material item emojis - 30px standard */
.vae-material-icon {
    display: block;
    font-size: 30px;
    margin-bottom: 8px;
}

.vae-material-label {
    display: block;
    font-size: 18px;
    color: #3aeb0e;
    text-transform: uppercase;
    margin-bottom: 5px;
    font-weight: 500;
}

.vae-material-value {
    display: block;
    font-size: 1.1em;
    font-weight: 600;
    color: #fff;
}

/* Build Tests Section */
.vae-build-tests {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-build-tests {
        grid-template-columns: 1fr;
    }
}

.vae-build-test {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    background: rgba(255,255,255,0.08);
    border-radius: 8px;
    border-left: 3px solid rgba(255,255,255,0.2);
    border-top: 1px solid transparent;
    transition: transform 0.2s ease, border-top-color 0.2s ease;
}

.vae-build-test:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-build-test[data-pass="yes"] {
    border-left-color: #673AB7;
}

.vae-build-test[data-pass="partial"] {
    border-left-color: #ff9800;
}

.vae-build-test[data-pass="no"] {
    border-left-color: #f44336;
}

.vae-test-name {
    font-size: 1em;
    color: #3aeb0e;
    font-weight: 400;
}

.vae-test-result {
    font-weight: 600;
    color: #fff;
}

.vae-build-test[data-pass="yes"] .vae-test-result {
    color: #fff;
}

.vae-build-test[data-pass="partial"] .vae-test-result {
    color: #ff9800;
}

.vae-build-test[data-pass="no"] .vae-test-result {
    color: #f44336;
}

/* Dimensions Row */
.vae-dimensions {
    display: flex;
    gap: 20px;
    justify-content: center;
    padding: 15px;
    background: rgba(255,255,255,0.05);
    border-radius: 8px;
    margin-bottom: 20px;
}

.vae-dim-item {
    font-size: 0.95em;
    color: rgba(255,255,255,0.8);
}

/* Build Verdict */
.vae-build-verdict {
    padding: 15px 20px;
    border-radius: 8px;
    text-align: center;
    font-weight: 400;
}

.vae-build-verdict[data-rating="excellent"] {
    background: #fff;
    color: #2d2d3a;
}

.vae-build-verdict[data-rating="good"] {
    background: rgba(139, 195, 74, 0.2);
    color: #8bc34a;
}

.vae-build-verdict[data-rating="average"] {
    background: rgba(255, 152, 0, 0.2);
    color: #ff9800;
}

.vae-build-verdict[data-rating="poor"] {
    background: rgba(244, 67, 54, 0.2);
    color: #f44336;
}

/* Legacy build grid (alternative structure) */
.vae-build-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-build-grid {
        grid-template-columns: 1fr;
    }
}

.vae-build-item {
    background: rgba(255,255,255,0.08);
    padding: 20px;
    border-radius: 8px;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-build-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-build-aspect {
    font-size: 0.85em;
    color: rgba(255,255,255,0.7);
    margin-bottom: 10px;
    text-transform: uppercase;
}

.vae-build-rating {
    font-size: 1.8em;
    font-weight: 700;
    margin-bottom: 5px;
}

.vae-build-rating[data-level="excellent"] { color: #00d509; }
.vae-build-rating[data-level="good"] { color: #8bc34a; }
.vae-build-rating[data-level="average"] { color: #ff9800; }
.vae-build-rating[data-level="poor"] { color: #f44336; }

.vae-build-desc {
    font-size: 0.85em;
    color: rgba(255,255,255,0.7);
}

/* ==========================================================================
   Webcam Box - Dark Theme
   ========================================================================== */

.vae-webcam-box {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-webcam-title,
.vae-webcam-box h3,
.vae-webcam-box h4 {
    margin: 0 0 20px 0 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
    color: #fff !important;
}

.vae-webcam-specs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-webcam-specs {
        grid-template-columns: 1fr;
    }
}

.vae-webcam-spec {
    text-align: center;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-webcam-spec:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-webcam-spec .vae-webcam-icon {
    display: block;
    font-size: 30px;
    margin-bottom: 8px;
}

.vae-webcam-spec .vae-webcam-label {
    display: block;
    font-size: 20px;
    color: rgb(255 255 255);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 5px;
    font-weight: 800;
}

.vae-webcam-spec .vae-webcam-value {
    display: block;
    font-size: 1.1em;
    font-weight: 400;
    color: #fff;
}

.vae-webcam-quality {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-webcam-quality {
        grid-template-columns: 1fr;
    }
}

.vae-quality-item {
    background: rgba(255, 255, 255, 0.08);
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-quality-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-quality-item .vae-quality-label {
    display: block;
    font-size: 18px;
    color: rgb(255 255 255);
    margin-bottom: 8px;
    font-weight: 500;
}

.vae-quality-item .vae-quality-rating {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
}

.vae-quality-rating[data-rating="excellent"] {
    background: rgba(0, 213, 9, 0.2);
    color: #00d509;
}

.vae-quality-rating[data-rating="good"] {
    background: rgba(139, 195, 74, 0.2);
    color: #8bc34a;
}

.vae-quality-rating[data-rating="average"] {
    background: rgba(255, 152, 0, 0.2);
    color: #ff9800;
}

.vae-quality-rating[data-rating="poor"] {
    background: rgba(244, 67, 54, 0.2);
    color: #f44336;
}

.vae-webcam-extras {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.vae-webcam-badge {
    padding: 8px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

.vae-webcam-badge[data-has="yes"],
.vae-webcam-badge.vae-has-feature {
    background: rgba(0, 213, 9, 0.2);
    color: #00d509;
    border: 1px solid rgba(0, 213, 9, 0.3);
}

.vae-webcam-badge[data-has="no"],
.vae-webcam-badge.vae-no-feature {
    background: rgba(255,255,255,0.05);
    color: rgba(255,255,255,0.5);
    border: 1px solid rgba(255,255,255,0.1);
    text-decoration: line-through;
}

.vae-webcam-verdict {
    padding: 15px 20px;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.6;
    color: #fff;
    background: rgb(255 255 255 / 15%);
    border-left: 4px solid #9C27B0;
}

/* ==========================================================================
   Audio/Speaker Box - Dark Theme
   ========================================================================== */

.vae-audio-box {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-audio-title,
.vae-audio-box h3,
.vae-audio-box h4 {
    margin: 0 0 20px 0 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
    color: #fff !important;
}

.vae-audio-specs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    background: rgba(255,255,255,0.08);
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .vae-audio-specs {
        grid-template-columns: 1fr;
    }
}

.vae-audio-spec {
    text-align: center;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-audio-spec:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-audio-spec .vae-audio-icon {
    display: block;
    font-size: 30px;
    margin-bottom: 8px;
}

.vae-audio-spec .vae-audio-label {
    font-weight: 800;
    display: block;
    font-size: 20px;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 5px;
}

.vae-audio-spec .vae-audio-value {
    display: block;
    font-size: 1.1em;
    font-weight: 400;
    color: #fff;
}

.vae-audio-ratings {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

@media (max-width: 600px) {
    .vae-audio-ratings {
        grid-template-columns: repeat(2, 1fr);
    }
}

.vae-audio-rating {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 15px;
    background: rgba(255,255,255,0.05);
    border-radius: 10px;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-audio-rating:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-audio-rating .vae-audio-category {
    font-size: 15px;
    color: #fff;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Audio rating emojis - 30px standard */
.vae-audio-rating .vae-audio-emoji {
    display: block;
    font-size: 30px;
    margin-bottom: 8px;
}

.vae-audio-rating .vae-audio-bar {
    height: 10px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 3px;
    overflow: hidden;
}

.vae-audio-rating .vae-audio-fill {
    height: 100%;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--vae-accent-color), #b39ddb);
}

.vae-audio-extras {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.vae-audio-badge {
    padding: 8px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

.vae-audio-badge[data-has="yes"] {
    background: rgba(0, 213, 9, 0.2);
    color: #00d509;
    border: 1px solid rgba(0, 213, 9, 0.3);
}

.vae-audio-badge[data-has="no"] {
    background: rgba(255,255,255,0.05);
    color: rgba(255,255,255,0.5);
    border: 1px solid rgba(255,255,255,0.1);
    text-decoration: line-through;
}

.vae-audio-verdict {
    padding: 15px 20px;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.6;
    color: #fff;
    background: rgb(255 255 255 / 15%);
    border-left: 4px solid #673AB7;
}

/* ==========================================================================
   Input Assessment (Keyboard/Trackpad) - Dark Theme
   ========================================================================== */

.vae-input-assessment {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 25px 0;
}

@media (max-width: 768px) {
    .vae-input-assessment {
        grid-template-columns: 1fr;
    }
}

.vae-input-card {
    background: #000000;
    border-radius: 12px;
    padding: 25px;
    color: #fff;
}

.vae-input-card h4 {
    margin: 0 0 15px 0 !important;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff !important;
    font-size: 1.1em !important;
    font-weight: 700 !important;
}

.vae-input-rating {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
}

.vae-input-score {
    font-size: 2em;
    font-weight: 700;
    color: #00d509;
}

.vae-input-score-label {
    font-size: 14px;
    color: rgba(255,255,255,0.7);
}

.vae-input-details {
    list-style: none;
    margin: 0;
    padding: 0;
}

.vae-input-details li {
    padding: 10px 0 10px 28px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    font-size: 14px;
    position: relative;
    line-height: 1.5;
    color: rgba(255,255,255,0.9);
}

.vae-input-details li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 10px;
    color: var(--vae-accent-color);
    font-weight: 700;
    font-size: 14px;
}

.vae-input-details li:last-child {
    border-bottom: none;
}

/* ==========================================================================
   Convertible/2-in-1 Box - Dark Theme
   ========================================================================== */

.vae-convertible-box {
    background: var(--vae-dark-bg);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
}

.vae-convertible-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-convertible-icon {
    font-size: 28px;
}

.vae-convertible-title,
.vae-convertible-box h3,
.vae-convertible-box h4 {
    margin: 0 0 20px 0 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
    color: #fff !important;
}

.vae-convertible-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.vae-convertible-item {
    text-align: center;
    padding: 20px 15px;
    background: rgba(255,255,255,0.08);
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.1);
    transition: transform 0.3s ease;
}

.vae-convertible-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-convertible-value {
    display: block;
    font-size: 1.3em;
    font-weight: 700;
    color: #fff;
    margin-bottom: 8px;
}

.vae-convertible-label {
    display: block;
    font-size: 11px;
    color: rgba(255,255,255,0.7);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.vae-modes-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.vae-mode-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: rgba(103, 58, 183, 0.2);
    border: 1px solid rgba(103, 58, 183, 0.4);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    color: #b39ddb;
}

.vae-mode-badge::before { font-size: 16px; }
.vae-mode-badge.vae-laptop-mode::before { content: "💻"; }
.vae-mode-badge.vae-tablet-mode::before { content: "📱"; }
.vae-mode-badge.vae-tent-mode::before { content: "⛺"; }
.vae-mode-badge.vae-stand-mode::before { content: "🖥️"; }

/* ==========================================================================
   Stylus/Pen Support Box - Dark Theme
   ========================================================================== */

.vae-stylus-box {
    background: linear-gradient(135deg, #1a1a2e 0%, var(--vae-dark-bg) 100%);
    color: #fff;
    border-radius: 12px;
    padding: 25px;
    margin: 25px 0;
    border: 1px solid rgba(103, 58, 183, 0.3);
}

.vae-stylus-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.vae-stylus-icon {
    font-size: 28px;
}

.vae-stylus-title,
.vae-stylus-box h3,
.vae-stylus-box h4 {
    margin: 0 0 20px 0 !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
    color: #fff !important;
}

.vae-stylus-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.vae-stylus-item {
    text-align: center;
    padding: 20px 15px;
    background: rgba(255,255,255,0.06);
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.1);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-stylus-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-stylus-value {
    display: block;
    font-size: 1.4em;
    font-weight: 700;
    color: #b39ddb;
    margin-bottom: 8px;
}

.vae-stylus-label {
    display: block;
    font-size: 11px;
    color: rgba(255,255,255,0.7);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.vae-stylus-features {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.vae-stylus-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
}

.vae-stylus-badge.vae-included {
    background: rgba(0, 213, 9, 0.2);
    color: #00d509;
}

.vae-stylus-badge.vae-optional {
    background: rgba(255, 152, 0, 0.2);
    color: #ff9800;
}

.vae-stylus-badge.vae-not-supported {
    background: rgba(244, 67, 54, 0.2);
    color: #f44336;
}

.vae-stylus-note {
    margin-top: 15px;
    padding: 15px;
    background: rgba(103, 58, 183, 0.15);
    border-radius: 8px;
    border-left: 4px solid var(--vae-accent-color);
    font-size: 14px;
    line-height: 1.6;
    color: #fff;
}

/* ==========================================================================
   Port Layout - Dark Theme
   ========================================================================== */

.vae-port-layout {
    background: var(--vae-dark-bg);
    color: #fff;
    padding: 25px;
    border-radius: 12px;
    margin: 25px 0;
}

.vae-port-layout h3,
.vae-port-layout h4 {
    margin: 0 0 20px 0 !important;
    color: #fff !important;
    font-size: 1.3em !important;
    font-weight: 700 !important;
}

.vae-ports-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.vae-port-item {
    background: rgba(255,255,255,0.08);
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: #fff;
    border: 1px solid transparent;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.vae-port-item:hover {
    transform: translateY(-4px);
    border-top: 3px solid var(--vae-accent-color);
}

.vae-port-count {
    background: var(--vae-accent-color);
    color: #fff;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 12px;
}

.vae-wireless {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.vae-wireless-badge {
    padding: 8px 14px;
    background: rgba(103, 58, 183, 0.2);
    border: 1px solid rgba(103, 58, 183, 0.4);
    border-radius: 20px;
    font-size: 13px;
    color: #b39ddb;
}

/* ==========================================================================
   Final Verdict - Dark Theme with Race Flag (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-final-verdict {
    background: var(--vae-dark-bg);
    color: #fff;
    padding: 30px;
    border-radius: 12px;
    margin: 30px 0;
}

.vae-laptop-post .vae-final-verdict h2,
.vae-laptop-post .vae-final-verdict h3,
.vae-laptop-post .vae-final-verdict .vae-verdict-heading {
    color: #fff !important;
    margin: 0 0 15px 0;
    font-size: 1.4em;
}

.vae-laptop-post .vae-final-verdict h2::before,
.vae-laptop-post .vae-final-verdict h3::before {
    content: "🏁 ";
}

.vae-laptop-post .vae-final-verdict .vae-verdict-content,
.vae-laptop-post .vae-final-verdict p {
    color: rgba(255,255,255,0.9);
    line-height: 1.7;
    margin: 0 0 15px 0;
}

.vae-laptop-post .vae-final-rating {
    display: inline-block;
    background: var(--vae-accent-color);
    color: #fff;
    padding: 12px 24px;
    border-radius: 8px;
    font-size: 1.2em;
    font-weight: 700;
    margin-top: 15px;
}

/* ==========================================================================
   Pros & Cons - Dark Theme (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-pros-cons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 25px 0;
}

@media (max-width: 768px) {
    .vae-laptop-post .vae-pros-cons {
        grid-template-columns: 1fr;
    }
}

.vae-laptop-post .vae-pros,
.vae-laptop-post .vae-cons {
    padding: 20px;
    border-radius: 8px;
}

.vae-laptop-post .vae-pros {
    background: rgba(0, 213, 9, 0.1);
    border: 1px solid rgba(0, 213, 9, 0.3);
}

.vae-laptop-post .vae-cons {
    background: rgba(244, 67, 54, 0.1);
    border: 1px solid rgba(244, 67, 54, 0.3);
}

.vae-laptop-post .vae-pros h4 {
    color: #00d509;
    margin: 0 0 15px 0;
}

.vae-laptop-post .vae-cons h4 {
    color: #f44336;
    margin: 0 0 15px 0;
}

.vae-laptop-post .vae-pros li,
.vae-laptop-post .vae-cons li {
    margin-bottom: 8px;
    line-height: 1.5;
}

/* ==========================================================================
   Comparison Table - Dark Theme (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-comparison-table thead {
    background: var(--vae-dark-bg);
}

.vae-laptop-post .vae-comparison-table thead th {
    color: #fff;
}

/* ==========================================================================
   Sticky Bar - Dark Theme (matches Desktop)
   ========================================================================== */

.vae-laptop-post .vae-sticky-product-bar {
    background: #2d2d3a;
}

/* ==========================================================================
   CONTENT MAX-WIDTH - Readable line lengths
   ========================================================================== */

.vae-laptop-post .entry-content,
.vae-laptop-post .post-content,
.vae-laptop-post article .content-area {
    max-width: 820px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
}

.vae-laptop-post .entry-content .vae-table-wrapper {
    width: 100%;
    overflow-x: auto;
}

.vae-laptop-post.vae-sticky-active {
    padding-top: 56px;
}

.vae-laptop-post [id] {
    scroll-margin-top: 70px;
}

/* ==========================================================================
   TOC Count Badge
   ========================================================================== */

.vae-toc-count {
    font-size: 13px;
    color: #3aeb0e;
    font-weight: 600;
    padding: 2px 10px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 12px;
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 768px) {
    .vae-display-grid,
    .vae-battery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .vae-portability-grid,
    .vae-build-materials {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .vae-display-grid,
    .vae-battery-grid {
        grid-template-columns: 1fr;
    }
}
