/* ===== EXPANDABLE TECHNICAL SECTION ===== */
.tech-details {
    margin: 2.5rem 0;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    overflow: hidden;
}
.tech-details summary {
    padding: 1rem 1.5rem;
    font-size: 1.1rem;
    font-weight: 700;
    cursor: pointer;
    background: linear-gradient(135deg, #f8f9fa, #eef1f5);
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    user-select: none;
    transition: background 0.2s;
}
.tech-details summary:hover { background: #e8ecf1; }
.tech-details summary::-webkit-details-marker { display: none; }
.tech-details summary::after { content: '▸'; margin-left: auto; transition: transform 0.2s; font-size: 1.2rem; }
.tech-details[open] summary::after { transform: rotate(90deg); }
.tech-details-content {
    padding: 1.5rem;
    font-size: 0.95rem;
    line-height: 1.7;
}
.tech-details-content h3 { margin-top: 0; font-size: 1.15rem; }
.tech-details-content h4 { margin-top: 1.5rem; margin-bottom: 0.5rem; font-size: 1rem; }
.tech-details-content ul { margin: 0.5rem 0 1rem 1.5rem; }
.tech-details-content p { margin: 0.5rem 0; }
.tech-table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: 0.9rem; }
.tech-table th, .tech-table td { padding: 0.6rem 1rem; text-align: left; border-bottom: 1px solid #e0e0e0; }
.tech-table th { background: #f5f5f5; font-weight: 600; }

/* ===== REVIEW PAGE STYLES ===== */

.review-header {
    padding: 90px 0 40px;
    background: linear-gradient(135deg, #0b1929 0%, #132f4c 100%);
    color: var(--white);
}

.back-link {
    display: inline-block; font-size: 0.85rem; font-weight: 600;
    color: rgba(255,255,255,0.6); margin-bottom: 20px; text-decoration: none;
}
.back-link:hover { color: var(--white); }

.review-meta-top {
    display: flex; gap: 16px; align-items: center; margin-bottom: 12px;
}
.review-category {
    background: var(--green); color: white; font-size: 0.75rem;
    font-weight: 700; padding: 4px 12px; border-radius: 4px;
    text-transform: uppercase; letter-spacing: 0.3px;
}
.review-date { font-size: 0.85rem; color: rgba(255,255,255,0.6); }

.review-header h1 { font-size: 2.2rem; font-weight: 800; margin-bottom: 12px; max-width: 700px; color: var(--white); }
.review-subtitle { font-size: 1.1rem; color: rgba(255,255,255,0.7); margin-bottom: 32px; }

/* Score Card */
.score-card {
    display: flex; gap: 0; background: var(--white);
    border: 1px solid var(--gray-300); border-radius: var(--radius);
    overflow: hidden; margin-bottom: 24px;
    box-shadow: var(--shadow);
}
.score-card-section { flex: 1; padding: 24px; text-align: center; }
.score-card-divider { width: 1px; background: var(--gray-300); }
.score-card-label {
    font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.5px;
    color: var(--gray-500); font-weight: 700; margin-bottom: 8px;
}
.score-card-stars { font-size: 1.5rem; color: var(--gold); margin-bottom: 4px; }
.score-card-stars.community-pending { opacity: 0.3; }
.score-card-number { font-size: 1.3rem; font-weight: 800; color: var(--gray-900); }
.score-card-price .price-num { color: var(--green); }
.score-card-verdict { font-size: 0.75rem; color: var(--gray-500); margin-top: 4px; }

@media (max-width: 640px) {
    .score-card { flex-direction: column; }
    .score-card-divider { width: 100%; height: 1px; }
    .score-card-section { padding: 16px; }
    .review-header h1 { font-size: 1.6rem; }
}

/* Share Bar */
.share-bar { display: flex; align-items: center; gap: 12px; }
.share-label { font-size: 0.8rem; color: rgba(255,255,255,0.5); font-weight: 500; }
.share-btn {
    width: 36px; height: 36px; border: 1px solid rgba(255,255,255,0.2);
    border-radius: 8px; background: rgba(255,255,255,0.05); cursor: pointer;
    font-size: 0.9rem; display: flex; align-items: center; justify-content: center;
    transition: var(--transition); color: rgba(255,255,255,0.7);
}
.share-btn:hover { border-color: var(--green); color: var(--green); }

/* Review Body */
.review-body { padding: 48px 0 80px; }
.review-content { max-width: 680px; }

.review-content p { margin-bottom: 16px; font-size: 1rem; color: var(--gray-700); line-height: 1.75; }
.review-content h2 { font-size: 1.5rem; margin-top: 40px; margin-bottom: 16px; color: var(--gray-900); }
.review-content ul { margin: 0 0 16px 24px; color: var(--gray-700); }
.review-content li { margin-bottom: 8px; line-height: 1.6; }

.review-intro { border-left: 3px solid var(--green); padding-left: 20px; margin-bottom: 32px; }
.review-intro p { color: var(--gray-500); font-style: italic; }

/* Callouts */
.callout {
    padding: 20px 24px; border-radius: var(--radius-sm);
    margin: 24px 0; font-size: 1.05rem; line-height: 1.6;
}
.callout-green { background: var(--green-light); color: var(--green-dark); border-left: 4px solid var(--green); }
.callout-highlight { background: var(--gold-light); color: #92400e; border-left: 4px solid var(--gold); }

/* Trip Stats */
.trip-stats {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 12px; background: var(--gray-50); border-radius: var(--radius-sm);
    padding: 20px; margin: 16px 0 20px;
}
.trip-stat { font-size: 0.9rem; color: var(--gray-700); }

@media (max-width: 480px) {
    .trip-stats { grid-template-columns: 1fr; }
}

/* Verdict Box */
.verdict-box {
    display: flex; gap: 24px; align-items: flex-start;
    background: var(--green-light); border: 2px solid var(--green);
    border-radius: var(--radius); padding: 32px; margin: 32px 0;
}
.verdict-score { font-size: 2rem; color: var(--gold); flex-shrink: 0; }
.verdict-text p { margin-bottom: 8px; }
.verdict-text p:last-child { margin-bottom: 0; }

@media (max-width: 480px) {
    .verdict-box { flex-direction: column; gap: 12px; padding: 24px; }
}

/* Review CTA */
.review-cta {
    background: var(--gray-50); border: 2px solid var(--gray-300);
    border-radius: var(--radius); padding: 32px; text-align: center;
    margin: 48px 0;
}
.review-cta h3 { margin-bottom: 8px; }
.review-cta p { color: var(--gray-700); margin-bottom: 20px; }

/* User Rating Section */
.user-rating-section {
    background: var(--white); border: 1px solid var(--gray-300);
    border-radius: var(--radius); padding: 32px;
    margin: 48px 0 32px; max-width: 680px;
}
.user-rating-section h3 { margin-bottom: 8px; }
.user-rating-section > p { color: var(--gray-500); margin-bottom: 20px; font-size: 0.9rem; }

.star-rating { display: flex; gap: 8px; margin-bottom: 16px; }
.star-rating .star {
    font-size: 2rem; background: none; border: none;
    color: var(--gray-300); cursor: pointer; transition: var(--transition);
    padding: 0;
}
.star-rating .star:hover,
.star-rating .star.active { color: var(--gold); }

.review-form-field {
    width: 100%; border: 1px solid var(--gray-300); border-radius: var(--radius-sm);
    padding: 12px 16px; font-family: inherit; font-size: 0.9rem;
    margin-bottom: 12px;
}
.review-form-field:focus { outline: none; border-color: var(--green); }

.user-comment {
    width: 100%; border: 1px solid var(--gray-300); border-radius: var(--radius-sm);
    padding: 12px 16px; font-family: inherit; font-size: 0.9rem;
    resize: vertical; margin-bottom: 16px;
}
.user-comment:focus { outline: none; border-color: var(--green); }

.form-row {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
}
.form-row .review-form-field {
    margin-bottom: 0;
}

@media (max-width: 640px) {
    .form-row {
        flex-direction: column;
        gap: 0;
    }
    .form-row .review-form-field {
        margin-bottom: 12px;
    }
}

.hp-field { position: absolute; left: -9999px; }

.rating-note { font-size: 0.75rem; color: var(--gray-500); margin-top: 12px; }

/* User Reviews */
.user-reviews { max-width: 680px; margin-bottom: 48px; }
.user-reviews h3 { margin-bottom: 16px; }
.no-reviews { color: var(--gray-500); font-style: italic; }

.user-review-card {
    border: 1px solid var(--gray-300); border-radius: var(--radius-sm);
    padding: 20px; margin-bottom: 12px;
}
.user-review-stars { color: var(--gold); margin-bottom: 8px; }
.user-review-comment { color: var(--gray-700); font-size: 0.9rem; }
.user-review-date { font-size: 0.75rem; color: var(--gray-500); margin-top: 8px; }
