/* FindEdition Platform 17.5 — Mobile Device Page Design System */

.md-device-page {
    --md-bg: #f1f5f9;
    --md-surface: #ffffff;
    --md-surface-2: #f8fafc;
    --md-text: var(--mobiles-text, #0f172a);
    --md-muted: var(--mobiles-muted, #64748b);
    --md-border: var(--mobiles-border, #e2e8f0);
    --md-primary: var(--mobiles-primary, #2563eb);
    --md-primary-dark: #1d4ed8;
    --md-accent: #7c3aed;
    --md-success: #10b981;
    --md-danger: #ef4444;
    --md-radius: 16px;
    --md-radius-sm: 10px;
    --md-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
    --md-shadow-lg: 0 12px 40px rgba(15, 23, 42, 0.1);
    --md-shadow-card: 0 2px 8px rgba(15, 23, 42, 0.05);
    --md-shadow-card-hover: 0 6px 20px rgba(15, 23, 42, 0.09);
    --md-card-pad: 0.875rem;
    --md-card-pad-sm: 0.75rem;
    --md-card-gap: 0.375rem;
    --md-card-gap-sm: 0.25rem;
    --fe-site-header-height: 3.5rem;
    --md-section-nav-height: 3rem;
    --md-scroll-offset: calc(var(--fe-site-header-height) + var(--md-section-nav-height));
    --md-font: 'Inter', system-ui, sans-serif;
    background: var(--md-bg);
    color: var(--md-text);
    font-family: var(--md-font);
    padding-bottom: 80px;
}

.md-device-page.md-dark {
    --md-bg: #0f172a;
    --md-surface: #1e293b;
    --md-surface-2: #334155;
    --md-text: #f1f5f9;
    --md-muted: #94a3b8;
    --md-border: #334155;
}

.md-container { max-width: 1280px; margin: 0 auto; padding: 0 1rem; }

/* Breadcrumb */
.md-breadcrumb-bar {
    background: var(--md-surface);
    border-bottom: 1px solid var(--md-border);
}
.md-breadcrumb-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1.25rem;
    flex-wrap: wrap;
    padding: 0.45rem 0;
}
.md-breadcrumb { padding: 0; flex: 1 1 auto; min-width: 0; }
.md-breadcrumb ol { display: flex; flex-wrap: wrap; gap: 0.5rem; list-style: none; padding: 0; margin: 0; font-size: 0.8125rem; color: var(--md-muted); align-items: center; }
.md-breadcrumb a { color: var(--md-primary); text-decoration: none; }
.md-breadcrumb a:hover { text-decoration: underline; }
.md-breadcrumb-bar .mf-nav--toolbar {
    flex: 0 0 auto;
    padding: 0;
    margin: 0;
    border-bottom: none;
    gap: 0.2rem;
    justify-content: flex-end;
}
.md-breadcrumb-bar .mf-nav--toolbar .mf-nav__link {
    min-height: 30px;
    padding: 0.2rem 0.55rem;
    font-size: 0.75rem;
    border-radius: 6px;
}
@media (max-width: 768px) {
    .md-breadcrumb-bar-inner {
        flex-direction: column;
        align-items: stretch;
        gap: 0.35rem;
        padding: 0.5rem 0;
    }
    .md-breadcrumb-bar .mf-nav--toolbar {
        justify-content: flex-start;
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    .md-breadcrumb-bar .mf-nav--toolbar::-webkit-scrollbar { display: none; }
}

/* Hero */
.md-hero-section { background: linear-gradient(180deg, var(--md-surface) 0%, var(--md-bg) 100%); padding: 1.5rem 0 2rem; }
.md-hero-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 1024px) { .md-hero-grid { grid-template-columns: 1fr 1fr; } }

/* Gallery */
.md-gallery-main { background: var(--md-surface-2); border-radius: var(--md-radius); padding: 2rem; position: relative; border: 1px solid var(--md-border); }
.md-gallery-zoom { border: none; background: none; width: 100%; cursor: zoom-in; position: relative; padding: 0; }
.md-gallery-hero-img { width: 100%; height: auto; max-height: 420px; object-fit: contain; transition: transform 0.3s ease; }
.md-gallery-zoom:hover .md-gallery-hero-img { transform: scale(1.02); }
.md-gallery-zoom-hint { position: absolute; bottom: 1rem; right: 1rem; background: rgba(0,0,0,0.6); color: #fff; padding: 0.5rem 0.75rem; border-radius: 8px; font-size: 0.75rem; }
.md-gallery-thumbs { display: flex; gap: 0.5rem; margin-top: 1rem; overflow-x: auto; padding-bottom: 0.25rem; }
.md-gallery-thumb { flex: 0 0 72px; height: 72px; border: 2px solid transparent; border-radius: var(--md-radius-sm); overflow: hidden; cursor: pointer; background: var(--md-surface); padding: 4px; transition: border-color 0.2s; }
.md-gallery-thumb.active, .md-gallery-thumb:hover { border-color: var(--md-primary); }
.md-gallery-thumb img { width: 100%; height: 100%; object-fit: contain; }
.md-gallery-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 300px; color: var(--md-muted); font-size: 3rem; gap: 1rem; }

/* Hero info */
.md-hero-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 0.75rem; }
.md-badge { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.25rem 0.75rem; border-radius: 999px; font-size: 0.75rem; font-weight: 600; text-decoration: none; }
.md-badge-brand { background: #dbeafe; color: #1e40af; }
.md-badge-editors { background: linear-gradient(135deg, #fbbf24, #f59e0b); color: #78350f; }
.md-badge-year { background: var(--md-surface-2); color: var(--md-muted); border: 1px solid var(--md-border); }
.md-device-title { font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 800; line-height: 1.15; margin: 0 0 0.25rem; letter-spacing: -0.02em; }
.md-device-subtitle { font-size: 1.125rem; color: var(--md-muted); margin: 0 0 1.25rem; }
.md-rating-row { display: flex; flex-wrap: wrap; gap: 1.5rem; margin-bottom: 1rem; }
.md-rating-block { text-align: center; }
.md-rating-value { display: block; font-size: 1.75rem; font-weight: 800; color: var(--md-primary); }
.md-rating-label { font-size: 0.75rem; color: var(--md-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.md-rating-final .md-rating-value { color: var(--md-accent); }
.md-stars { color: #fbbf24; font-size: 0.875rem; }
.md-hero-meta { display: flex; flex-wrap: wrap; gap: 1rem; font-size: 0.875rem; color: var(--md-muted); margin-bottom: 1.25rem; }
.md-variant-group { margin-bottom: 1rem; }
.md-color-swatches, .md-storage-options { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.md-color-swatch, .md-storage-btn { border: 2px solid var(--md-border); background: var(--md-surface); border-radius: var(--md-radius-sm); padding: 0.5rem 0.75rem; font-size: 0.8125rem; cursor: pointer; display: inline-flex; align-items: center; gap: 0.5rem; transition: all 0.2s; color: var(--md-text); }
.md-color-swatch span { width: 16px; height: 16px; border-radius: 50%; border: 1px solid rgba(0,0,0,0.1); }
.md-color-swatch.active, .md-storage-btn.active { border-color: var(--md-primary); background: #eff6ff; }

/* Purchase box */
.md-purchase-box { background: var(--md-surface); border: 1px solid var(--md-border); border-radius: var(--md-radius); padding: 1.5rem; box-shadow: var(--md-shadow); }
.md-price-discount { display: inline-block; background: var(--md-danger); color: #fff; padding: 0.15rem 0.5rem; border-radius: 6px; font-size: 0.75rem; font-weight: 700; margin-bottom: 0.5rem; }
.md-price-current { display: flex; align-items: baseline; gap: 0.5rem; }
.md-price-from { font-size: 0.875rem; color: var(--md-muted); }
.md-price-amount { font-size: 2rem; font-weight: 800; color: var(--md-primary); }
.md-price-msrp { font-size: 0.875rem; color: var(--md-muted); text-decoration: line-through; }
.md-price-range { font-size: 0.875rem; color: var(--md-muted); margin: 0.25rem 0 0; }
.md-price-empty { text-align: center; padding: 1rem; color: var(--md-muted); }
.md-availability { display: flex; align-items: center; gap: 0.5rem; color: var(--md-success); font-size: 0.875rem; font-weight: 600; margin: 1rem 0; }
.md-purchase-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.md-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.75rem 1.25rem; border-radius: var(--md-radius-sm); font-weight: 600; font-size: 0.9375rem; cursor: pointer; border: none; text-decoration: none; transition: all 0.2s; }
.md-btn-primary { background: linear-gradient(135deg, var(--md-primary), var(--md-accent)); color: #fff; flex: 1; }
.md-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(37,99,235,0.4); }
.md-btn-ghost { background: var(--md-surface-2); color: var(--md-text); border: 1px solid var(--md-border); }
.md-btn-ghost:hover { border-color: var(--md-primary); color: var(--md-primary); }
.md-btn-ghost.liked { color: var(--md-danger); border-color: var(--md-danger); }
.md-btn-sm { padding: 0.5rem 1rem; font-size: 0.8125rem; }
.md-sellers { margin-top: 1.25rem; border-top: 1px solid var(--md-border); padding-top: 1rem; }
.md-sellers h4 { font-size: 0.875rem; margin: 0 0 0.75rem; }
.md-seller-row { display: flex; justify-content: space-between; padding: 0.75rem; border-radius: var(--md-radius-sm); text-decoration: none; color: var(--md-text); border: 1px solid var(--md-border); margin-bottom: 0.5rem; transition: border-color 0.2s; }
.md-seller-row:hover { border-color: var(--md-primary); }

/* Section nav — sticks below global FindEdition site header */
.md-section-nav {
    position: sticky;
    top: var(--fe-site-header-height, 3.5rem);
    z-index: 40;
    background: var(--md-surface);
    border-bottom: 1px solid var(--md-border);
    box-shadow: var(--md-shadow);
}
.md-section-nav-inner { display: flex; gap: 0.5rem; padding: 0.75rem 0; align-items: center; }
.md-section-nav-links { display: flex; gap: 0.25rem; overflow-x: auto; flex: 1; min-width: 0; scrollbar-width: none; align-items: center; }
.md-section-nav-links::-webkit-scrollbar { display: none; }
.md-section-nav-actions {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    flex-shrink: 0;
    margin-left: auto;
    padding-left: 0.5rem;
    border-left: 1px solid var(--md-border);
}
.md-section-nav a { white-space: nowrap; padding: 0.5rem 1rem; border-radius: 999px; font-size: 0.875rem; font-weight: 500; color: var(--md-muted); text-decoration: none; transition: all 0.2s; min-height: 44px; display: inline-flex; align-items: center; }
.md-section-nav a:hover, .md-section-nav a.active, .md-section-nav a[aria-current="location"] { background: #eff6ff; color: var(--md-primary); }
.md-section-nav a:focus-visible { outline: 2px solid var(--md-primary); outline-offset: 2px; }
/* Voice Reader — section nav chip (matches FindEdition nav pills + toolbar tools) */
.md-voice-nav {
    position: relative;
    flex-shrink: 0;
}
.md-voice-nav-chip {
    display: inline-flex;
    align-items: stretch;
    min-height: 44px;
    border: 1px solid var(--md-border);
    border-radius: 999px;
    background: var(--md-surface-2);
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.md-voice-nav-chip:hover {
    border-color: #bfdbfe;
}
.md-voice-nav-chip.is-playing {
    border-color: #93c5fd;
    background: #eff6ff;
    box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.08);
}
.md-voice-nav-play {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 0.75rem 0.5rem 0.875rem;
    border: none;
    background: transparent;
    color: var(--md-muted);
    font-family: inherit;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: color 0.2s, background 0.2s;
    white-space: nowrap;
}
.md-voice-nav-play:hover,
.md-voice-nav-chip.is-playing .md-voice-nav-play {
    color: var(--md-primary);
}
.md-voice-nav-icon {
    width: 1.375rem;
    height: 1.375rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--md-primary), var(--md-accent));
    color: #fff;
    font-size: 0.625rem;
    flex-shrink: 0;
    transition: transform 0.2s;
}
.md-voice-nav-chip.is-playing .md-voice-nav-icon {
    animation: md-voice-pulse 1.4s ease-in-out infinite;
}
@keyframes md-voice-pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.06); opacity: 0.92; }
}
.md-voice-nav-text { display: none; }
@media (min-width: 640px) { .md-voice-nav-text { display: inline; } }
.md-voice-nav-sep {
    width: 1px;
    align-self: stretch;
    background: var(--md-border);
    flex-shrink: 0;
}
.md-voice-nav-gear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--md-muted);
    font-size: 0.625rem;
    cursor: pointer;
    transition: color 0.2s, background 0.2s;
}
.md-voice-nav-gear:hover,
.md-voice-nav-gear[aria-expanded="true"] {
    color: var(--md-primary);
    background: rgba(37, 99, 235, 0.06);
}
.md-voice-nav-gear[aria-expanded="true"] i {
    transform: rotate(180deg);
}
.md-voice-nav-gear i {
    transition: transform 0.2s;
}
.md-voice-nav-dropdown {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    z-index: 55;
    width: min(16rem, calc(100vw - 2rem));
    padding: 0.625rem;
    background: var(--md-surface);
    border: 1px solid var(--md-border);
    border-radius: var(--md-radius-sm);
    box-shadow: var(--md-shadow-lg);
}
.md-voice-nav-dropdown[hidden] { display: none !important; }
.md-voice-nav-dropdown-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0 0.125rem 0.5rem;
    margin-bottom: 0.5rem;
    border-bottom: 1px solid var(--md-border);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--md-text);
}
.md-voice-nav-dropdown-head span {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}
.md-voice-nav-dropdown-head span i {
    color: var(--md-primary);
    font-size: 0.75rem;
}
.md-voice-nav-dropdown-head small {
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--md-muted);
}
.md-voice-nav-dropdown-row {
    display: grid;
    grid-template-columns: 4.25rem 1fr;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}
.md-voice-nav-dropdown-row label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--md-muted);
}
.md-voice-nav-select {
    width: 100%;
    padding: 0.4rem 0.5rem;
    font-size: 0.8125rem;
    font-family: inherit;
    border: 1px solid var(--md-border);
    border-radius: 8px;
    background: var(--md-surface-2);
    color: var(--md-text);
    outline: none;
}
.md-voice-nav-select:focus {
    border-color: var(--md-primary);
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12);
}
.md-voice-nav-dropdown-actions {
    display: flex;
    justify-content: flex-end;
    padding-top: 0.25rem;
}
.md-voice-nav-stop {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.75rem;
    border: 1px solid var(--md-border);
    border-radius: 8px;
    background: var(--md-surface-2);
    color: var(--md-muted);
    font-family: inherit;
    font-size: 0.75rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}
.md-voice-nav-stop:hover {
    border-color: #fca5a5;
    color: #dc2626;
    background: #fef2f2;
}
.md-voice-nav-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
}
.md-voice-nav-progress,
.md-voice-nav-progress-fill {
    display: none;
}
.md-dark-toggle {
    background: var(--md-surface-2);
    border: 1px solid var(--md-border);
    border-radius: 999px;
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    color: var(--md-text);
    flex-shrink: 0;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s, color 0.2s;
}
.md-dark-toggle:hover {
    border-color: #bfdbfe;
    color: var(--md-primary);
}
@media (max-width: 639px) {
    .md-section-nav-actions {
        padding-left: 0.375rem;
        gap: 0.25rem;
    }
    .md-voice-nav-play {
        padding: 0.5rem 0.625rem;
    }
    .md-voice-nav-gear {
        width: 2rem;
    }
}
.md-device-page.md-dark .md-voice-nav-chip:hover {
    border-color: #3b82f6;
}
.md-device-page.md-dark .md-voice-nav-chip.is-playing {
    background: rgba(37, 99, 235, 0.14);
    border-color: #3b82f6;
    box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.2);
}
.md-device-page.md-dark .md-voice-nav-dropdown {
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}
/* Frozen layout — scroll offset for sticky section nav */
.md-scores-section, .md-specs-section, .md-review-section, .md-purchase-section,
.md-intelligence-section, .md-pricing-section, .md-alternatives-section,
.md-community-hub, .md-recently-viewed, .md-related-section { scroll-margin-top: var(--md-scroll-offset, 6.5rem); }

/* Main layout */
.md-main-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; padding: 2rem 0; }
@media (min-width: 1024px) { .md-main-grid { grid-template-columns: 1fr 340px; } }
.md-card { background: var(--md-surface); border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); padding: var(--md-card-pad); margin-bottom: 1rem; box-shadow: var(--md-shadow-card); }
.md-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.75rem; padding-bottom: 0.625rem; border-bottom: 2px solid var(--md-primary); }
.md-card-header h2 { font-size: 1.0625rem; font-weight: 700; margin: 0; display: flex; align-items: center; gap: 0.4rem; }

/* Scores */
.md-scores-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.md-score-card { background: var(--md-surface-2); border-radius: var(--md-radius-sm); padding: 1rem; }
.md-score-card-head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; font-size: 0.875rem; }
.md-score-card-head strong { margin-left: auto; font-size: 1.125rem; color: var(--md-primary); }
.md-score-bar { height: 6px; background: var(--md-border); border-radius: 999px; overflow: hidden; }
.md-score-fill { height: 100%; background: linear-gradient(90deg, var(--md-primary), var(--md-accent)); border-radius: 999px; transition: width 0.6s ease; }
.md-score-final-badge { background: linear-gradient(135deg, var(--md-primary), var(--md-accent)); color: #fff; padding: 0.35rem 0.75rem; border-radius: 999px; font-weight: 700; }

/* Specs */
.md-spec-search { width: 100%; max-width: 280px; padding: 0.5rem 1rem; border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); background: var(--md-surface-2); color: var(--md-text); }
.md-spec-anchors { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1rem; }
.md-spec-anchors a { font-size: 0.8125rem; padding: 0.35rem 0.75rem; background: var(--md-surface-2); border-radius: 999px; text-decoration: none; color: var(--md-muted); border: 1px solid var(--md-border); }
.md-spec-anchors a:hover { color: var(--md-primary); border-color: var(--md-primary); }
.md-spec-card { border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); margin-bottom: 0.75rem; overflow: hidden; }
.md-spec-card summary { padding: 1rem 1.25rem; cursor: pointer; font-weight: 600; display: flex; align-items: center; gap: 0.75rem; list-style: none; background: var(--md-surface-2); }
.md-spec-card summary::-webkit-details-marker { display: none; }
.md-spec-count { margin-left: auto; font-size: 0.75rem; color: var(--md-muted); background: var(--md-surface); padding: 0.15rem 0.5rem; border-radius: 999px; }
.md-spec-fields { padding: 0.5rem 1.25rem 1rem; }
.md-spec-field { display: grid; grid-template-columns: 1fr 1.5fr; gap: 1rem; padding: 0.75rem 0; border-bottom: 1px solid var(--md-border); font-size: 0.9375rem; }
.md-spec-field:last-child { border-bottom: none; }
.md-spec-label { color: var(--md-muted); font-weight: 500; }
.md-spec-value { font-weight: 600; }

/* Review */
.md-review-overview p { font-size: 1.0625rem; line-height: 1.7; color: var(--md-muted); }
.md-pros-cons-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; margin: 1.5rem 0; }
@media (min-width: 768px) { .md-pros-cons-grid { grid-template-columns: 1fr 1fr; } }
.md-pros-card, .md-cons-card { border-radius: var(--md-radius-sm); padding: 1.25rem; }
.md-pros-card { background: linear-gradient(135deg, #ecfdf5, #d1fae5); border: 1px solid #6ee7b7; }
.md-cons-card { background: linear-gradient(135deg, #fef2f2, #fee2e2); border: 1px solid #fca5a5; }
.md-pros-card h3, .md-cons-card h3 { margin: 0 0 1rem; font-size: 1rem; }
.md-pros-card ul, .md-cons-card ul { list-style: none; padding: 0; margin: 0; }
.md-pros-card li, .md-cons-card li { padding: 0.35rem 0; font-size: 0.9375rem; }
.md-verdict-card { background: linear-gradient(135deg, #eff6ff, #ede9fe); border-radius: var(--md-radius-sm); padding: 1.5rem; margin-top: 1.5rem; border: 1px solid #bfdbfe; }
.md-verdict-meta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1rem; font-size: 0.875rem; color: var(--md-muted); }

/* Pricing section */
.md-pricing-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--md-card-gap); margin-bottom: 0.75rem; }
@media (min-width: 640px) { .md-pricing-cards { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .md-pricing-cards { grid-template-columns: repeat(auto-fill, minmax(6.5rem, 1fr)); } }
.md-pricing-card { background: var(--md-surface); border-radius: var(--md-radius-sm); padding: var(--md-card-pad-sm) 0.625rem; text-align: center; border: 1px solid var(--md-border); box-shadow: var(--md-shadow-card); transition: box-shadow 0.2s ease, transform 0.2s ease; }
.md-pricing-card:hover { box-shadow: var(--md-shadow-card-hover); transform: translateY(-1px); }
.md-pricing-label { display: block; font-size: 0.6875rem; color: var(--md-muted); font-weight: 600; margin-bottom: 0.15rem; }
.md-pricing-value { font-size: 1rem; font-weight: 800; color: var(--md-primary); line-height: 1.2; }
.md-pricing-discount .md-pricing-value { color: var(--md-danger); }
.md-regional-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 0.75rem; }
.md-regional-item { display: flex; justify-content: space-between; padding: 0.75rem; background: var(--md-surface-2); border-radius: var(--md-radius-sm); font-size: 0.875rem; }
.md-price-chart canvas { width: 100%; height: 200px; }
.md-price-chart-empty { text-align: center; padding: 2rem; color: var(--md-muted); }

/* Related */
.md-phone-carousel { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; }
.md-phone-card { display: flex; flex-direction: column; background: var(--md-surface-2); border-radius: var(--md-radius-sm); padding: 1rem; text-decoration: none; color: var(--md-text); border: 1px solid var(--md-border); transition: all 0.2s; }
.md-phone-card:hover { border-color: var(--md-primary); transform: translateY(-2px); box-shadow: var(--md-shadow); }
.md-phone-card img { width: 100%; height: 120px; object-fit: contain; margin-bottom: 0.75rem; }
.md-phone-card-placeholder { height: 120px; display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--md-muted); }
.md-phone-card-info strong { display: block; font-size: 0.875rem; margin-bottom: 0.25rem; }
.md-phone-card-price { font-size: 0.8125rem; color: var(--md-primary); font-weight: 600; }
.md-phone-card-rating { font-size: 0.75rem; color: #fbbf24; }

/* Comments */
.md-comment-sort { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1.25rem; font-size: 0.875rem; flex-wrap: wrap; }
.md-comment-sort a { padding: 0.35rem 0.75rem; border-radius: 999px; text-decoration: none; color: var(--md-muted); border: 1px solid var(--md-border); }
.md-comment-sort a.active { background: var(--md-primary); color: #fff; border-color: var(--md-primary); }
.md-comment-form textarea { width: 100%; padding: 1rem; border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); background: var(--md-surface-2); color: var(--md-text); resize: vertical; min-height: 100px; font-family: inherit; }
.md-comment-form-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem; font-size: 0.875rem; }
.md-comment-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.md-comment-avatar-sm { width: 32px; height: 32px; }
.md-comment-avatar-fallback { display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--md-primary), var(--md-accent)); color: #fff; font-weight: 700; }
.md-comments-list { display: flex; flex-direction: column; gap: 1rem; }
.md-comment { background: var(--md-surface-2); border-radius: var(--md-radius-sm); padding: 1.25rem; border: 1px solid var(--md-border); }
.md-comment-pinned { border-color: var(--md-primary); box-shadow: 0 0 0 1px var(--md-primary); }
.md-comment-main { display: flex; gap: 1rem; }
.md-comment-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; font-size: 0.8125rem; }
.md-comment-meta time { color: var(--md-muted); }
.md-badge-mini { font-size: 0.6875rem; padding: 0.15rem 0.5rem; border-radius: 999px; font-weight: 600; }
.md-badge-author { background: #dbeafe; color: #1e40af; }
.md-badge-verified { background: #d1fae5; color: #065f46; }
.md-badge-pinned { background: #fef3c7; color: #92400e; }
.md-comment-text { margin: 0 0 0.75rem; line-height: 1.6; white-space: pre-wrap; }
.md-comment-actions { display: flex; gap: 1rem; }
.md-comment-like, .md-comment-reply, .md-comment-delete { background: none; border: none; color: var(--md-muted); cursor: pointer; font-size: 0.8125rem; padding: 0; }
.md-comment-delete { color: var(--md-danger); }
.md-comment-delete:hover { text-decoration: underline; }
.md-comments-pagination nav { display: flex; justify-content: center; }
.md-img-broken { opacity: 0.35; }
.md-comment-like:hover, .md-comment-reply:hover { color: var(--md-primary); }
.md-comment-like.liked { color: var(--md-primary); }
.md-comment-replies { margin-top: 1rem; padding-left: 1rem; border-left: 2px solid var(--md-border); }
.md-reply-form { margin-top: 0.75rem; }
.md-reply-form.hidden { display: none; }
.md-empty-state { text-align: center; padding: 3rem 1rem; color: var(--md-muted); }
.md-empty-state i { font-size: 3rem; margin-bottom: 1rem; opacity: 0.5; }
.md-alert { padding: 0.75rem 1rem; border-radius: var(--md-radius-sm); margin-bottom: 1rem; }
.md-alert-success { background: #d1fae5; color: #065f46; }
.md-alert-error { background: #fee2e2; color: #991b1b; }

/* Sidebar */
.md-sidebar-sticky { position: sticky; top: 4rem; }
.md-sidebar-widget { background: var(--md-surface); border: 1px solid var(--md-border); border-radius: var(--md-radius); padding: 1.25rem; margin-bottom: 1rem; box-shadow: var(--md-shadow); }
.md-sidebar-widget h3 { font-size: 0.9375rem; font-weight: 700; margin: 0 0 1rem; display: flex; align-items: center; gap: 0.5rem; }
.md-sidebar-specs { list-style: none; padding: 0; margin: 0; }
.md-sidebar-specs li { display: flex; justify-content: space-between; padding: 0.5rem 0; border-bottom: 1px solid var(--md-border); font-size: 0.8125rem; }
.md-sidebar-link { display: block; margin-top: 0.75rem; font-size: 0.8125rem; color: var(--md-primary); text-decoration: none; }
.md-sidebar-phones { display: flex; flex-direction: column; gap: 0.75rem; }
.md-sidebar-phone { display: flex; gap: 0.75rem; align-items: center; text-decoration: none; color: var(--md-text); font-size: 0.8125rem; padding: 0.5rem; border-radius: var(--md-radius-sm); transition: background 0.2s; }
.md-sidebar-phone:hover { background: var(--md-surface-2); }
.md-sidebar-phone img { border-radius: 8px; object-fit: contain; background: var(--md-surface-2); }
.md-brand-chips { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.md-brand-chips a { font-size: 0.75rem; padding: 0.35rem 0.65rem; background: var(--md-surface-2); border-radius: 999px; text-decoration: none; color: var(--md-muted); border: 1px solid var(--md-border); }
.md-brand-chips a:hover { color: var(--md-primary); border-color: var(--md-primary); }
.md-newsletter-form { display: flex; flex-direction: column; gap: 0.5rem; }
.md-newsletter-form input { padding: 0.5rem 0.75rem; border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); background: var(--md-surface-2); color: var(--md-text); }
@media (max-width: 1023px) { .md-sidebar-purchase { display: none; } }

/* Sticky purchase bar */
.md-sticky-purchase { position: fixed; bottom: 0; left: 0; right: 0; z-index: 50; background: var(--md-surface); border-top: 1px solid var(--md-border); box-shadow: 0 -4px 20px rgba(0,0,0,0.1); padding: 0.75rem 1rem; }
.md-sticky-purchase[hidden] { display: none; }
.md-sticky-purchase-inner { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 2fr) auto; align-items: center; gap: 0.75rem 1rem; }
.md-sticky-purchase-info strong { display: block; font-size: 0.9375rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.md-sticky-purchase-info span { color: var(--md-primary); font-weight: 700; font-size: 0.875rem; }
.md-sticky-purchase-ratings { min-width: 0; }
.md-sticky-purchase-actions { display: flex; gap: 0.5rem; flex-shrink: 0; }
@media (max-width: 1023px) {
    .md-sticky-purchase-ratings { display: none; }
    .md-sticky-purchase-inner { grid-template-columns: 1fr auto; }
}

/* Lightbox */
.md-lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,0.92); display: flex; align-items: center; justify-content: center; }
.md-lightbox[hidden] { display: none; }
.md-lightbox-stage { max-width: 90vw; max-height: 85vh; }
.md-lightbox-stage img { max-width: 100%; max-height: 85vh; object-fit: contain; }
.md-lightbox-close, .md-lightbox-prev, .md-lightbox-next { position: absolute; background: rgba(255,255,255,0.15); border: none; color: #fff; width: 48px; height: 48px; border-radius: 50%; cursor: pointer; font-size: 1.25rem; transition: background 0.2s; }
.md-lightbox-close:hover, .md-lightbox-prev:hover, .md-lightbox-next:hover { background: rgba(255,255,255,0.3); }
.md-lightbox-close { top: 1rem; right: 1rem; }
.md-lightbox-prev { left: 1rem; top: 50%; transform: translateY(-50%); }
.md-lightbox-next { right: 1rem; top: 50%; transform: translateY(-50%); }
.md-lightbox-counter { position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); color: #fff; font-size: 0.875rem; }

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
    .md-score-fill, .md-gallery-hero-img, .md-phone-card, .md-btn-primary { transition: none; }
}
@media (prefers-contrast: more) {
    .md-device-page { --md-border: #000; }
    .md-btn-primary { background: #000; }
}
@media print {
    .md-section-nav, .md-sticky-purchase, .md-sidebar, .md-lightbox, .md-comment-form { display: none !important; }
}

/* Platform 17.8 — Integration completion */
.mobile-price-wrap { display: inline-flex; flex-wrap: wrap; align-items: center; gap: 0.35rem; }
.mobile-price-badge { font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; padding: 0.15rem 0.45rem; border-radius: 4px; background: #f1f5f9; color: #64748b; border: 1px solid #e2e8f0; }
.mobile-price-na { color: #94a3b8; font-style: italic; }

.md-rating-hero { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--md-card-gap); margin: 0.5rem 0 0.25rem; }
@media (min-width: 640px) { .md-rating-hero { grid-template-columns: repeat(4, 1fr); } }
.md-rating-card { text-align: left; position: relative; border-top: 3px solid var(--rating-color, var(--md-primary)); display: flex; flex-direction: column; justify-content: flex-start; gap: var(--md-card-gap-sm); min-height: 6rem; }
@media (min-width: 640px) and (max-width: 1023px) { .md-rating-card { min-height: 6.5rem; } }
@media (min-width: 1024px) { .md-rating-card { min-height: 7.25rem; } }
.md-rating-card-head { display: flex; align-items: center; gap: 0.35rem; min-height: 1.125rem; }
.md-rating-card-icon { color: var(--rating-color); font-size: 1.125rem; line-height: 1; flex-shrink: 0; }
.md-rating-card-icon i { font-size: 1.125rem; }
.md-rating-card-label { font-size: 0.6875rem; font-weight: 600; color: var(--md-muted); line-height: 1.2; flex: 1; min-width: 0; }
.md-rating-card-value { font-size: 2.375rem; font-weight: 800; line-height: 1; color: var(--md-text); letter-spacing: -0.02em; }
@media (max-width: 639px) { .md-rating-card-value { font-size: 2rem; } }
.md-rating-card-meta { font-size: 0.625rem; color: var(--md-muted); line-height: 1.25; }
.md-rating-card-confidence { font-size: 0.625rem; color: var(--md-muted); line-height: 1.2; margin-top: auto; }
.md-rating-trend { font-size: 0.5625rem; font-weight: 700; padding: 0.1rem 0.35rem; border-radius: 999px; line-height: 1; flex-shrink: 0; }

/* Hero quick spec bar — replaces rating cards in hero */
.md-hero-spec-bar {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    margin: 0.5rem 0 0.35rem;
    border-radius: var(--md-radius-sm);
    overflow: hidden;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.08) 0%, rgba(124, 58, 237, 0.1) 100%);
    border: 1px solid var(--md-border);
    box-shadow: var(--md-shadow-card);
}
@media (min-width: 640px) { .md-hero-spec-bar { grid-template-columns: repeat(4, 1fr); } }
.md-hero-spec-cell {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.65rem 0.75rem;
    min-width: 0;
    border-right: 1px solid rgba(226, 232, 240, 0.85);
    background: rgba(255, 255, 255, 0.72);
}
.md-hero-spec-cell:last-child { border-right: none; }
@media (max-width: 639px) {
    .md-hero-spec-cell:nth-child(2n) { border-right: none; }
    .md-hero-spec-cell:nth-child(-n+2) { border-bottom: 1px solid rgba(226, 232, 240, 0.85); }
}
.md-hero-spec-icon { color: var(--md-primary); font-size: 0.875rem; line-height: 1; }
.md-hero-spec-title { font-size: 0.5625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--md-muted); }
.md-hero-spec-primary { font-size: 0.9375rem; font-weight: 800; line-height: 1.15; color: var(--md-text); letter-spacing: -0.01em; }
.md-hero-spec-secondary { font-size: 0.625rem; color: var(--md-muted); line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Sticky bar compact ratings */
.md-rating-hero--sticky {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.35rem;
    margin: 0;
}
.md-rating-hero--sticky .md-rating-card {
    min-height: 0;
    padding: 0.35rem 0.45rem;
    gap: 0.1rem;
    border-top-width: 2px;
    text-align: center;
    align-items: center;
}
.md-rating-hero--sticky .md-rating-card-head--compact {
    justify-content: center;
    min-height: 0;
    gap: 0.2rem;
}
.md-rating-hero--sticky .md-rating-card-icon { font-size: 0.6875rem; }
.md-rating-hero--sticky .md-rating-card-icon i { font-size: 0.6875rem; }
.md-rating-hero--sticky .md-rating-card-label {
    font-size: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: unset;
}
.md-rating-hero--sticky .md-rating-card-value { font-size: 1.125rem; font-weight: 800; }

.md-rating-trend.md-trend-up { background: rgba(22, 163, 74, 0.12); color: var(--md-success); }
.md-rating-trend.md-trend-down { background: rgba(220, 38, 38, 0.1); color: var(--md-danger); }

.md-scores-compact .md-scores-grid-compact { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
@media (min-width: 640px) { .md-scores-compact .md-scores-grid-compact { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .md-scores-compact .md-scores-grid-compact { grid-template-columns: repeat(4, 1fr); } }
.md-score-compact { background: var(--md-surface-2); border: 1px solid var(--md-border); border-radius: 8px; padding: 0.5rem 0.65rem; }
.md-score-compact-head { display: flex; align-items: center; gap: 0.35rem; font-size: 0.75rem; margin-bottom: 0.35rem; }
.md-score-compact-head i { color: var(--score-color); width: 14px; text-align: center; }
.md-score-compact-title { flex: 1; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.md-score-compact-value { font-weight: 800; font-size: 0.8125rem; }
.md-score-bar-sm { height: 4px; }
.md-score-compact-tier { font-size: 0.5625rem; color: var(--md-muted); text-transform: uppercase; font-weight: 600; }

.md-price-tier-badge { display: inline-block; font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; padding: 0.2rem 0.5rem; border-radius: 4px; background: var(--md-surface-2); color: var(--md-muted); margin-bottom: 0.35rem; }
.md-unavailable { color: var(--md-danger) !important; }
.md-unavailable i { color: var(--md-danger); }

.md-sidebar-author .md-author-row { display: flex; gap: 0.75rem; align-items: center; }
.md-author-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.md-author-fallback { display: flex; align-items: center; justify-content: center; background: var(--md-primary); color: #fff; font-weight: 700; }
.md-author-role { display: block; font-size: 0.75rem; color: var(--md-muted); }
.md-ad-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 120px; background: var(--md-surface-2); border: 1px dashed var(--md-border); border-radius: var(--md-radius-sm); color: var(--md-muted); font-size: 0.8125rem; gap: 0.5rem; }
.md-sidebar-phone-price { font-size: 0.75rem; color: var(--md-primary); font-weight: 600; }

.md-community-summary { display: flex; align-items: center; gap: 1rem; padding: 1rem; background: var(--md-surface-2); border-radius: var(--md-radius-sm); margin-bottom: 1rem; }
.md-community-score-big { font-size: 2.5rem; font-weight: 800; color: var(--md-primary); line-height: 1; }
.md-review-form { margin-bottom: 1.5rem; padding: 1rem; background: var(--md-surface-2); border-radius: var(--md-radius-sm); border: 1px solid var(--md-border); }
.md-rating-input { margin-bottom: 0.75rem; }
.md-star-rating-input { display: flex; flex-wrap: wrap; gap: 0.25rem; }
.md-star-label input { position: absolute; opacity: 0; }
.md-star-label span { display: inline-block; padding: 0.25rem 0.5rem; border: 1px solid var(--md-border); border-radius: 4px; font-size: 0.75rem; cursor: pointer; }
.md-star-label input:checked + span { background: var(--md-primary); color: #fff; border-color: var(--md-primary); }
.md-review-extras { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin: 0.75rem 0; }
@media (max-width: 640px) { .md-review-extras { grid-template-columns: 1fr; } }
.md-review-extras label, .md-review-options label { font-size: 0.8125rem; font-weight: 600; display: block; margin-bottom: 0.25rem; }
.md-review-options { display: flex; flex-wrap: wrap; gap: 1rem; margin: 0.5rem 0; }
.md-checkbox { display: flex; align-items: center; gap: 0.35rem; font-size: 0.8125rem; cursor: pointer; }
.md-review-images-grid { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.5rem; }
.md-review-thumb { width: 72px; height: 72px; object-fit: cover; border-radius: 6px; border: 1px solid var(--md-border); }
.md-review-rating-badge { font-size: 0.75rem; color: #f59e0b; font-weight: 700; }
.md-badge-recommend { background: #d1fae5; color: #065f46; }
.md-badge-no-recommend { background: #fee2e2; color: #991b1b; }
.md-rated-notice { background: #dbeafe; color: #1e40af; padding: 0.75rem; border-radius: 8px; margin-bottom: 1rem; }
.md-comments-subheading { font-size: 1rem; font-weight: 700; margin: 1.5rem 0 1rem; padding-top: 1rem; border-top: 1px solid var(--md-border); }

.md-badge-stock { background: #d1fae5; color: #065f46; }
.md-intelligence-section .md-highlights { display: flex; flex-wrap: wrap; gap: var(--md-card-gap); margin-bottom: 0.75rem; }
.md-highlight-chip { font-size: 0.75rem; padding: 0.25rem 0.6rem; background: var(--md-surface-2); border-radius: 999px; border: 1px solid var(--md-border); }
.md-intel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--md-card-gap); margin-bottom: 0.75rem; }
@media (max-width: 640px) { .md-intel-grid { grid-template-columns: 1fr; } }
.md-intel-card { border-radius: var(--md-radius-sm); border: 1px solid var(--md-border); background: var(--md-surface); box-shadow: var(--md-shadow-card); transition: box-shadow 0.2s ease; }
.md-intel-card:hover { box-shadow: var(--md-shadow-card-hover); }
.md-intel-card h3 { font-size: 0.8125rem; font-weight: 700; margin: 0 0 0.35rem; display: flex; align-items: center; gap: 0.35rem; }
.md-intel-card h3 i { font-size: 0.875rem; color: var(--md-primary); width: 1rem; text-align: center; flex-shrink: 0; }
.md-intel-card p { font-size: 0.8125rem; line-height: 1.45; margin: 0; color: var(--md-text); }
.md-intelligence-section .md-takeaways,
.md-intelligence-section .md-buying-rec,
.md-intelligence-section .md-competitors,
.md-intelligence-section .md-path-grid { margin-bottom: 0.75rem; }
.md-intelligence-section h3 { font-size: 0.875rem; font-weight: 700; margin: 0 0 0.4rem; }
.md-intelligence-section .md-takeaways ul,
.md-intelligence-section .md-path-grid ul { margin: 0; padding-left: 1.1rem; font-size: 0.8125rem; line-height: 1.45; }
.md-intelligence-section .md-path-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--md-card-gap); }
@media (max-width: 640px) { .md-intelligence-section .md-path-grid { grid-template-columns: 1fr; } }
.md-intel-buy { border-left: 4px solid #16a34a; }
.md-intel-avoid { border-left: 4px solid #dc2626; }
.md-spec-important { background: rgba(37, 99, 235, 0.04); }
.md-spec-badge { font-size: 0.625rem; padding: 0.1rem 0.4rem; border-radius: 4px; margin-left: 0.35rem; font-weight: 600; }
.md-badge-important { background: #dbeafe; color: #1e40af; }
.md-store-grid, .md-affiliate-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 0.75rem; margin-top: 0.75rem; }
.md-store-card, .md-affiliate-card { display: flex; flex-direction: column; padding: 0.75rem; border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); text-decoration: none; color: var(--md-text); font-size: 0.875rem; }
.md-variant-group button.unavailable { opacity: 0.45; text-decoration: line-through; }
.md-variant-group button small { display: block; font-size: 0.6875rem; color: var(--md-muted); }
.md-trend-up { color: #16a34a; }
.md-trend-down { color: #dc2626; }

/* Platform 17.9 — Product Experience */
.md-hero-header { display: flex; flex-direction: column; gap: 0.65rem; }
.md-hero-quick-specs { display: flex; flex-wrap: wrap; gap: 0.35rem 0.75rem; list-style: none; padding: 0; margin: 0.25rem 0; font-size: 0.75rem; color: var(--md-muted); }
.md-hero-quick-specs li { display: flex; align-items: center; gap: 0.25rem; }
.md-hero-quick-specs i { color: var(--md-success); font-size: 0.625rem; }
.md-hero-variant-split {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 1rem;
}
.md-hero-variant-split .md-hero-variant-row {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
}
.md-hero-variant-row { display: inline-flex; align-items: center; gap: 0.35rem; flex-wrap: wrap; max-width: 100%; }
.md-variant-label {
    flex: 0 0 auto;
    min-width: 0;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--md-muted);
    line-height: 1.2;
    white-space: nowrap;
}
.md-hero-variant-chips {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    flex: 0 0 auto;
    min-width: 0;
}
.md-hero-variant-row[data-variant-group="storage"] .md-variant-label {
    min-width: 3.5rem;
}
.md-variant-chip, .md-color-chip { font-size: 0.75rem; padding: 0.3rem 0.65rem; border: 1px solid var(--md-border); border-radius: 999px; background: var(--md-surface); cursor: pointer; transition: border-color 0.15s; }
.md-variant-chip.active, .md-color-chip.active { border-color: var(--md-primary); background: rgba(37,99,235,0.08); color: var(--md-primary); font-weight: 600; }
@media (max-width: 520px) {
    .md-hero-variant-split {
        flex-direction: column;
        align-items: stretch;
        gap: 0.35rem;
    }
    .md-hero-variant-split .md-hero-variant-row {
        width: 100%;
    }
}
.md-color-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 0.25rem; vertical-align: middle; }
.md-hero-cta { align-self: flex-start; }
.md-hero-purchase { margin-top: 0.25rem; }
.md-hero-actions { margin-top: 0.25rem; }

.md-purchase-premium { background: var(--md-surface); border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); padding: 0.65rem 0.75rem; box-shadow: var(--md-shadow-card); }
.md-purchase-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.35rem; }
.md-purchase-top-left { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.md-purchase-discount { background: #dc2626; color: #fff; font-size: 0.625rem; font-weight: 700; padding: 0.1rem 0.4rem; border-radius: 4px; line-height: 1.3; }
.md-purchase-avail { font-size: 0.625rem; font-weight: 600; display: flex; align-items: center; gap: 0.25rem; color: var(--md-muted); }
.md-purchase-avail.in i { color: #16a34a; font-size: 0.45rem; }
.md-purchase-avail.out { color: #dc2626; }
.md-wishlist-btn { background: #fff; border: 1px solid var(--md-border); border-radius: 50%; width: 28px; height: 28px; min-height: 28px !important; cursor: pointer; color: var(--md-muted); display: flex; align-items: center; justify-content: center; font-size: 0.75rem; }
.md-wishlist-btn.active, .md-wishlist-btn:hover { color: #dc2626; border-color: #fca5a5; background: #fef2f2; }
.md-purchase-mid { margin-bottom: 0.4rem; }
.md-purchase-price-row { display: flex; align-items: baseline; gap: 0.5rem; }
.mpi-buybox-price-line { display: flex; align-items: baseline; flex-wrap: wrap; gap: 0.35rem 0.5rem; line-height: 1.15; }
.md-purchase-current { font-size: 1.375rem; font-weight: 800; color: var(--md-text); line-height: 1.1; }
.md-purchase-old { font-size: 0.8125rem; color: var(--md-muted); text-decoration: line-through; }
.md-purchase-savings { font-size: 0.6875rem; color: #16a34a; font-weight: 600; }
.mpi-buybox-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.35rem 0.65rem; margin: 0.2rem 0 0; font-size: 0.6875rem; color: var(--md-muted); line-height: 1.3; }
.mpi-buybox-meta strong { color: var(--md-text); font-weight: 600; }
.mpi-buybox-store-inline strong { color: var(--md-text); }
.md-purchase-tier { font-size: 0.625rem; text-transform: uppercase; font-weight: 700; color: var(--md-muted); }
.md-purchase-bottom { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.3rem; border-top: 1px solid var(--md-border); padding-top: 0.45rem; margin-top: 0.15rem; }
.md-purchase-action {
    font-size: 0.6875rem; padding: 0.3rem 0.35rem; min-height: 0 !important; height: auto;
    border: 1px solid var(--md-border); border-radius: 8px; background: #f8fafc; color: #334155;
    text-decoration: none; cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
    gap: 0.25rem; font-weight: 600; line-height: 1.2; white-space: nowrap;
}
.md-purchase-action i { font-size: 0.65rem; opacity: 0.85; }
.md-purchase-action:hover { border-color: #2563eb; color: #2563eb; background: #fff; }
.md-purchase-action-primary { background: #2563eb !important; color: #fff !important; border-color: #2563eb !important; }
.md-purchase-action-primary:hover { background: #1d4ed8 !important; border-color: #1d4ed8 !important; color: #fff !important; }
.md-purchase-reviews {
    display: flex; align-items: center; justify-content: center; gap: 0.35rem;
    width: 100%; margin-top: 0.35rem; padding: 0.35rem 0.65rem; min-height: 0 !important;
    border-radius: 8px; text-decoration: none; font-weight: 600; font-size: 0.75rem; line-height: 1.2;
    border: 1px solid #c7d2fe; background: #eef2ff; color: #4338ca; box-sizing: border-box;
}
.md-purchase-reviews i { font-size: 0.7rem; }
.md-purchase-reviews:hover { background: #e0e7ff; border-color: #818cf8; color: #3730a3; transform: none; box-shadow: none; }

.md-scores-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.75rem; margin-bottom: 0.75rem; }
.md-scores-header h2 { font-size: 1.0625rem; }
.md-score-summary { font-size: 0.8125rem; margin: 0.2rem 0 0; line-height: 1.4; color: var(--md-muted); }
.md-overall-score { position: relative; width: 60px; height: 60px; flex-shrink: 0; }
.md-overall-ring { width: 60px; height: 60px; }
.md-overall-value { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 1.0625rem; font-weight: 800; }
.md-scores-grid-premium { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--md-card-gap); align-items: stretch; }
@media (min-width: 640px) { .md-scores-grid-premium { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .md-scores-grid-premium { grid-template-columns: repeat(4, 1fr); } }
.md-score-ring-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.35rem; height: 100%; min-height: 6.5rem; }
@media (min-width: 640px) { .md-score-ring-card { min-height: 7rem; } }
@media (min-width: 1024px) { .md-score-ring-card { min-height: 7.5rem; } }
.md-score-ring-card:hover { box-shadow: var(--md-shadow-card-hover); transform: translateY(-1px); }
.md-score-ring-card:focus-within { outline: 2px solid var(--md-primary); outline-offset: 2px; }
.md-score-ring-wrap { position: relative; width: 40px; height: 40px; flex-shrink: 0; }
.md-score-ring { width: 40px; height: 40px; }
.md-score-ring-value { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 0.6875rem; font-weight: 800; }
.md-score-ring-meta { min-width: 0; width: 100%; }
.md-score-ring-head { display: flex; align-items: center; justify-content: center; gap: 0.25rem; flex-wrap: wrap; margin-bottom: 0.1rem; }
.md-score-ring-meta i { color: var(--tier-color); font-size: 0.6875rem; }
.md-score-ring-title { font-size: 0.6875rem; font-weight: 700; line-height: 1.2; }
.md-score-ring-badge { font-size: 0.5625rem; font-weight: 700; color: var(--tier-color); background: color-mix(in srgb, var(--tier-color) 12%, transparent); padding: 0.05rem 0.35rem; border-radius: 999px; }
.md-score-ring-summary { font-size: 0.625rem; color: var(--md-muted); margin: 0; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.md-community-hub { opacity: 1; }
.md-community-hub:not(.md-lazy-loaded) .md-reviews-list { min-height: 80px; }
.md-community-summary-panel { display: grid; grid-template-columns: auto 1fr auto; gap: 1rem; align-items: center; padding: 1rem; background: var(--md-surface-2); border-radius: var(--md-radius-sm); margin-bottom: 1rem; }
@media (max-width: 640px) { .md-community-summary-panel { grid-template-columns: 1fr; } }
.md-cs-big { font-size: 2rem; font-weight: 800; color: var(--md-primary); display: block; line-height: 1; }
.md-cs-label { font-size: 0.6875rem; color: var(--md-muted); text-transform: uppercase; }
.md-cs-stats { display: flex; flex-wrap: wrap; gap: 0.75rem; font-size: 0.8125rem; }
.md-cs-bar-row { display: flex; align-items: center; gap: 0.35rem; font-size: 0.6875rem; margin-bottom: 0.2rem; }
.md-cs-bar { flex: 1; height: 6px; background: var(--md-border); border-radius: 3px; overflow: hidden; min-width: 60px; }
.md-cs-bar div { height: 100%; background: var(--md-primary); border-radius: 3px; }
.md-community-tabs { display: flex; gap: 0.25rem; border-bottom: 2px solid var(--md-border); margin-bottom: 1rem; overflow-x: auto; }
.md-community-tabs button { background: none; border: none; padding: 0.65rem 1rem; font-size: 0.8125rem; font-weight: 600; color: var(--md-muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; white-space: nowrap; }
.md-community-tabs button.active { color: var(--md-primary); border-bottom-color: var(--md-primary); }
.md-community-tabs button em { font-style: normal; background: var(--md-surface-2); padding: 0.1rem 0.35rem; border-radius: 999px; font-size: 0.625rem; margin-left: 0.25rem; }
.md-tab-panel[hidden] { display: none !important; }
.md-tab-subhead { font-size: 0.875rem; font-weight: 700; margin: 1rem 0 0.5rem; }
.md-review-card { border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); padding: 1rem; margin-bottom: 0.75rem; background: var(--md-surface); }
.md-review-card-head { display: flex; gap: 0.75rem; margin-bottom: 0.65rem; }
.md-review-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.md-review-avatar-fb { display: flex; align-items: center; justify-content: center; background: var(--md-primary); color: #fff; font-weight: 700; }
.md-review-badges { display: flex; flex-wrap: wrap; gap: 0.25rem; margin: 0.2rem 0; }
.md-rbadge { font-size: 0.625rem; padding: 0.1rem 0.4rem; border-radius: 4px; background: var(--md-surface-2); }
.md-rbadge.verified { background: #d1fae5; color: #065f46; }
.md-review-card-sub { font-size: 0.75rem; color: var(--md-muted); display: flex; flex-wrap: wrap; gap: 0.5rem; }
.md-review-stars { color: #f59e0b; font-weight: 700; }
.md-review-pros, .md-review-cons { font-size: 0.8125rem; margin-bottom: 0.35rem; }
.md-review-body { font-size: 0.875rem; line-height: 1.55; margin: 0.5rem 0; }
.md-review-card-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-top: 0.75rem; padding: 0.65rem 0.75rem; border-radius: 10px; background: #f1f5f9; border: 1px solid #e2e8f0; }
.md-review-helpful, .md-review-reply, .md-review-report { color: inherit; cursor: pointer; }

/* Community action chips — reviews & discussion (light FindEdition palette; beats Tailwind button reset) */
.md-device-page button.md-community-action,
.md-device-page .md-inline-form button.md-community-action {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.75rem;
    margin: 0;
    border-radius: 999px;
    border: 1px solid #e2e8f0;
    background-color: #f8fafc !important;
    background-image: none !important;
    color: #334155;
    font-size: 0.75rem;
    font-weight: 600;
    font-family: inherit;
    line-height: 1.2;
    cursor: pointer;
    text-decoration: none;
    appearance: none;
    -webkit-appearance: none;
    box-shadow: none;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.md-device-page button.md-community-action i,
.md-device-page .md-inline-form button.md-community-action i {
    font-size: 0.7rem;
    opacity: 0.9;
    color: inherit;
}
.md-device-page button.md-community-action:disabled {
    opacity: 0.65;
    cursor: default;
}
.md-device-page button.md-community-action--helpful,
.md-device-page .md-inline-form button.md-community-action--helpful {
    background-color: #f0fdf4 !important;
    border-color: #bbf7d0;
    color: #15803d;
}
.md-device-page button.md-community-action--helpful:hover {
    background-color: #dcfce7 !important;
    border-color: #4ade80;
    color: #166534;
}
.md-device-page button.md-community-action--helpful.is-voted,
.md-device-page button.md-community-action--helpful.is-voted:hover,
.md-device-page button.md-comment-like.is-voted,
.md-device-page button.md-comment-like.is-voted:hover {
    background-color: #dcfce7 !important;
    border-color: #4ade80;
    color: #166534;
}
.md-device-page button.md-community-action--reply {
    background-color: #eef2ff !important;
    border-color: #c7d2fe !important;
    color: #4338ca !important;
}
.md-device-page button.md-community-action--reply:hover {
    background-color: #eef2ff !important;
    border-color: #a5b4fc;
    color: #4338ca;
}
.md-device-page button.md-community-action--report {
    background-color: #fff7ed !important;
    border-color: #fed7aa;
    color: #c2410c;
}
.md-device-page button.md-community-action--report:hover {
    background-color: #ffedd5 !important;
    border-color: #fb923c;
    color: #9a3412;
}
.md-device-page button.md-community-action--edit {
    background-color: #eef2ff !important;
    border-color: #c7d2fe;
    color: #4338ca;
}
.md-device-page button.md-community-action--edit:hover {
    background-color: #e0e7ff !important;
    border-color: #818cf8;
    color: #3730a3;
}
.md-device-page button.md-community-action--delete,
.md-device-page .md-inline-form button.md-community-action--delete,
.md-device-page button[type="submit"].md-community-action--delete {
    background-color: #fef2f2 !important;
    border-color: #fca5a5 !important;
    color: #b91c1c !important;
}
.md-device-page button.md-community-action--delete:hover {
    background-color: #fee2e2 !important;
    border-color: #f87171 !important;
    color: #991b1b !important;
}
.md-device-page button.md-community-action--moderate,
.md-device-page .md-inline-form button.md-community-action--moderate,
.md-device-page button[type="submit"].md-community-action--moderate {
    background-color: #fffbeb !important;
    border-color: #fcd34d !important;
    color: #b45309 !important;
}
.md-device-page button.md-community-action--moderate:hover {
    background-color: #fef3c7 !important;
    border-color: #fbbf24 !important;
    color: #92400e !important;
}
.md-inline-form .md-community-action { margin: 0; }
.md-review-form-premium { background: var(--md-surface-2); border: 1px solid var(--md-border); border-radius: var(--md-radius-sm); padding: 1rem; margin-bottom: 1rem; }
.md-star-rating-stars { display: flex; flex-wrap: wrap; gap: 0.2rem; margin-bottom: 0.75rem; }
.md-star-pick { cursor: pointer; }
.md-star-pick input { position: absolute; opacity: 0; }
.md-star-pick i { color: #d1d5db; font-size: 0.875rem; }
.md-star-pick input:checked ~ i, .md-star-pick:hover i { color: #f59e0b; }
.md-form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 0.65rem; margin-bottom: 0.65rem; }
.md-input { width: 100%; padding: 0.5rem; border: 1px solid var(--md-border); border-radius: 6px; background: var(--md-surface); color: var(--md-text); font-size: 0.8125rem; }
.md-discussion-item { padding: 0.75rem 0; border-bottom: 1px solid var(--md-border); font-size: 0.875rem; }
.md-photos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 0.5rem; }
.md-photo-item img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 8px; }
.md-photo-item figcaption { font-size: 0.625rem; color: var(--md-muted); margin-top: 0.25rem; }
.md-empty-compact { text-align: center; color: var(--md-muted); padding: 1.5rem; font-size: 0.875rem; }

.md-hero-info { display: flex; flex-direction: column; gap: 0.75rem; }
.md-hero-section { padding: 1rem 0 1.25rem; }
.md-main-grid { gap: 1.25rem; }
.md-card { margin-bottom: 1rem; }

/* Platform 20.3.2 — Global site header must remain visible above device page chrome */
body:has(.md-device-page) > header {
    position: sticky;
    top: 0;
    z-index: 60;
    display: block;
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

/* Platform 20.3.1 — Unified enterprise card system */
.md-enterprise-card {
    background: var(--md-surface);
    border: 1px solid var(--md-border);
    border-radius: var(--md-radius-sm);
    padding: var(--md-card-pad-sm) var(--md-card-pad);
    box-shadow: var(--md-shadow-card);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.md-enterprise-card:hover { box-shadow: var(--md-shadow-card-hover); transform: translateY(-1px); }
.md-enterprise-card:focus-within { outline: 2px solid var(--md-primary); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
    .md-enterprise-card, .md-score-ring-card, .md-pricing-card { transition: none; }
    .md-enterprise-card:hover, .md-score-ring-card:hover, .md-pricing-card:hover { transform: none; }
}

/* Platform 20.1 — Responsive stabilization (device page) */
.md-device-page { overflow-x: clip; max-width: 100%; }
.md-container { padding-inline: clamp(0.75rem, 3vw, 1.25rem); box-sizing: border-box; }
.md-main-content, .md-sidebar { min-width: 0; }
.md-device-page img:not([width]) { max-width: 100%; height: auto; }
.md-phone-carousel { scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.md-purchase-action, .md-btn, .md-wishlist-btn, .md-dark-toggle { min-height: 44px; }
.mpi-buybox .md-purchase-action,
.mpi-buybox .md-purchase-reviews { min-height: 0 !important; }
.mpi-buybox .md-wishlist-btn { min-height: 28px !important; }
.md-community-tabs button, .md-star-pick { min-height: 44px; padding-inline: 0.5rem; }
.md-prose, .md-review-body { overflow-wrap: anywhere; word-break: break-word; }
.md-comp-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.md-purchase-action:focus-visible, .md-btn:focus-visible, .md-purchase-reviews:focus-visible, .md-community-tabs button:focus-visible { outline: 2px solid var(--md-primary); outline-offset: 2px; }

.md-purchase-section { margin-bottom: 0.5rem; }
.md-alt-grid-secondary { margin-top: 1rem; }
.md-review-sort-form { margin-bottom: 0.75rem; }
.md-review-sort-form select { padding: 0.35rem 0.5rem; border: 1px solid var(--md-border); border-radius: 6px; font-size: 0.8125rem; background: var(--md-surface); color: var(--md-text); min-height: 44px; }
.md-discussion-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-top: 0.5rem; padding: 0.65rem 0.75rem; border-radius: 10px; background: #f1f5f9; border: 1px solid #e2e8f0; }
.md-discussion-replies { margin-left: 1rem; padding-left: 0.75rem; border-left: 2px solid var(--md-border); margin-top: 0.5rem; }
.md-discussion-reply { font-size: 0.8125rem; margin-bottom: 0.5rem; }
.md-reply-form { margin-top: 0.5rem; }
.md-reply-form textarea { width: 100%; padding: 0.5rem; border: 1px solid var(--md-border); border-radius: 6px; font-size: 0.8125rem; }
.md-review-edit-form { margin-top: 0.75rem; padding: 0.75rem; background: var(--md-surface-2); border-radius: 8px; border: 1px solid var(--md-border); }
.md-review-edit-form label { display: block; font-size: 0.8125rem; margin-bottom: 0.5rem; }
.md-inline-form { display: inline; }
.md-rbadge.staff { background: #dbeafe; color: #1e40af; }
.md-rbadge.expert { background: #fef3c7; color: #92400e; }
.md-rbadge.recommend { background: #dcfce7; color: #166534; }
/* Scoped utility — do NOT use global .hidden (breaks Tailwind hidden lg:flex on site header) */
.md-device-page .hidden { display: none !important; }

/* Loading skeleton */
@keyframes md-shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
.md-skeleton { background: linear-gradient(90deg, var(--md-surface-2) 25%, var(--md-border) 50%, var(--md-surface-2) 75%); background-size: 200% 100%; animation: md-shimmer 1.5s infinite; border-radius: var(--md-radius-sm); }

/* Platform 20.3.5 — Sidebar enrichment widgets */
.md-sb-popular,
.md-sb-related,
.md-sb-news {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.md-sb-head { display: flex; align-items: center; gap: 0.35rem; margin: 0 0 0.75rem; padding-left: 0.6rem; border-left: 3px solid var(--md-primary); flex-shrink: 0; }
.md-sb-head h3 { margin: 0; font-size: 0.6875rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; color: var(--md-muted); line-height: 1.25; }
.md-sb-head-info { margin-left: auto; color: var(--md-muted); font-size: 0.75rem; text-decoration: none; }
.md-sb-head-info:hover { color: var(--md-primary); }
.md-sb-more-link {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    width: 100%;
    margin-top: 0.65rem;
    padding-top: 0.6rem;
    border-top: 1px solid var(--md-border);
    font-size: 0.625rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--md-text);
    text-decoration: none;
    flex-shrink: 0;
    box-sizing: border-box;
    line-height: 1.3;
}
.md-sb-more-link:hover { color: var(--md-primary); }
.md-sb-more-link i { flex-shrink: 0; width: 1rem; height: 1rem; border-radius: 50%; background: var(--md-text); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 0.5rem; }
.md-sb-more-link:hover i { background: var(--md-primary); }

.md-sb-finder { padding: 0; overflow: hidden; }
.md-sb-finder-head { display: flex; align-items: center; justify-content: center; gap: 0.4rem; padding: 0.55rem 0.75rem; background: linear-gradient(135deg, var(--md-primary), var(--md-accent)); color: #fff; font-size: 0.6875rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; }
.md-sb-brand-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); background: var(--md-surface); }
.md-sb-brand-grid a { display: flex; align-items: center; justify-content: center; min-height: 2rem; padding: 0.35rem 0.25rem; border-right: 1px solid var(--md-border); border-bottom: 1px solid var(--md-border); font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.02em; color: var(--md-muted); text-decoration: none; text-align: center; line-height: 1.1; word-break: break-word; }
.md-sb-brand-grid a:hover { color: var(--md-primary); background: rgba(37, 99, 235, 0.06); }
.md-sb-brand-grid a:nth-child(4n) { border-right: none; }
.md-sb-finder-foot { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; padding: 0.45rem 0.65rem; background: var(--md-surface-2); border-top: 1px solid var(--md-border); }
.md-sb-finder-foot a { font-size: 0.5625rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.03em; color: var(--md-text); text-decoration: none; display: inline-flex; align-items: center; gap: 0.25rem; }
.md-sb-finder-foot a:hover { color: var(--md-primary); }

.md-sb-news-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.65rem; flex: 1 1 auto; min-height: 0; min-width: 0; }
.md-sb-news-item { display: flex; gap: 0.65rem; text-decoration: none; color: inherit; align-items: flex-start; }
.md-sb-news-item:hover strong { color: var(--md-primary); }
.md-sb-news-thumb { flex-shrink: 0; width: 56px; height: 56px; border-radius: 8px; overflow: hidden; background: var(--md-surface-2); border: 1px solid var(--md-border); }
.md-sb-news-thumb img { width: 100%; height: 100%; object-fit: cover; }
.md-sb-news-thumb-fb { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--md-muted); font-size: 1.125rem; }
.md-sb-news-body { min-width: 0; display: flex; flex-direction: column; gap: 0.25rem; }
.md-sb-news-body strong { font-size: 0.75rem; line-height: 1.35; color: var(--md-text); font-weight: 700; }
.md-sb-news-date { font-size: 0.625rem; color: var(--md-muted); display: inline-flex; align-items: center; gap: 0.25rem; }

.md-sb-phone-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.5rem; width: 100%; min-width: 0; }
.md-sb-phone-cell { display: flex; flex-direction: column; align-items: center; gap: 0.35rem; text-decoration: none; color: var(--md-text); padding: 0.35rem 0.2rem; border-radius: 8px; transition: background 0.15s; }
.md-sb-phone-cell:hover { background: var(--md-surface-2); }
.md-sb-phone-img { width: 100%; aspect-ratio: 1; display: flex; align-items: center; justify-content: center; background: var(--md-surface-2); border: 1px solid var(--md-border); border-radius: 8px; overflow: hidden; }
.md-sb-phone-img img { max-width: 88%; max-height: 88%; object-fit: contain; }
.md-sb-phone-img-fb { color: var(--md-muted); font-size: 1.25rem; }
.md-sb-phone-label { text-align: center; min-width: 0; width: 100%; }
.md-sb-phone-brand { display: block; font-size: 0.5625rem; color: var(--md-muted); text-transform: uppercase; letter-spacing: 0.03em; }
.md-sb-phone-model { display: block; font-size: 0.625rem; font-weight: 800; line-height: 1.25; word-break: break-word; }
.md-sb-related-cat { margin: -0.35rem 0 0.65rem; font-size: 0.6875rem; color: var(--md-muted); flex-shrink: 0; }

@media (max-width: 639px) {
    .md-sb-brand-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .md-sb-brand-grid a:nth-child(4n) { border-right: 1px solid var(--md-border); }
    .md-sb-brand-grid a:nth-child(3n) { border-right: none; }
}
