/**
 * Apaxon Restaurant Reviews — Public Stylesheet
 */

.apx-rev-summary,
.apx-rev-list,
.apx-rev-form-wrap,
.apx-rev-form,
.apx-rev-stars,
.apx-rev-inline {
    --apx-r-accent:        #8b3a2e;
    --apx-r-accent-soft:   #fdf2ef;
    --apx-r-star:          #f59e0b;
    --apx-r-star-soft:     #fef3c7;
    --apx-r-text:          #1c1917;
    --apx-r-text-soft:     #57534e;
    --apx-r-muted:         #78716c;
    --apx-r-border:        #e7e5e4;
    --apx-r-border-strong: #d6d3d1;
    --apx-r-bg:            #ffffff;
    --apx-r-bg-soft:       #fafaf9;
    --apx-r-success:       #166534;
    --apx-r-success-bg:    #dcfce7;
    --apx-r-error:         #991b1b;
    --apx-r-error-bg:      #fee2e2;
    --apx-r-radius:        12px;
    --apx-r-radius-sm:     6px;
    --apx-r-font:          -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --apx-r-font-display:  Georgia, "Times New Roman", serif;
    font-family: var(--apx-r-font);
    color: var(--apx-r-text);
    line-height: 1.5;
    box-sizing: border-box;
}

.apx-rev-summary *,
.apx-rev-list *,
.apx-rev-form-wrap *,
.apx-rev-form * { box-sizing: border-box; }

/* =========================================================
   STARS (display)
   ========================================================= */
.apx-rev-stars {
    display: inline-flex;
    gap: 2px;
    font-size: 18px;
    line-height: 1;
}

.apx-rev-star.is-full   { color: var(--apx-r-star); }
.apx-rev-star.is-empty  { color: #d1d5db; }
.apx-rev-star.is-half {
    color: #d1d5db;
    background: linear-gradient(90deg, var(--apx-r-star) 50%, #d1d5db 50%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* =========================================================
   SUMMARY HEADER (avg score)
   ========================================================= */
.apx-rev-summary {
    max-width: 760px;
    margin: 0 auto;
}

.apx-rev-summary-header {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 24px 28px;
    background: var(--apx-r-bg-soft);
    border: 1px solid var(--apx-r-border);
    border-radius: var(--apx-r-radius);
    margin-bottom: 24px;
}

@media (max-width: 500px) {
    .apx-rev-summary-header {
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
}

.apx-rev-summary-score {
    display: flex;
    align-items: baseline;
    gap: 4px;
    font-family: var(--apx-r-font-display);
    color: var(--apx-r-accent);
    flex-shrink: 0;
}

.apx-rev-summary-number {
    font-size: 48px;
    font-weight: 700;
    line-height: 1;
}

.apx-rev-summary-of {
    font-size: 22px;
    color: var(--apx-r-muted);
}

.apx-rev-summary-meta { flex: 1; }

.apx-rev-summary-meta .apx-rev-stars { font-size: 22px; }

.apx-rev-summary-count {
    margin: 6px 0 0;
    color: var(--apx-r-text-soft);
    font-size: 14px;
}

.apx-rev-summary-empty {
    margin: 0;
    color: var(--apx-r-muted);
    font-style: italic;
    text-align: center;
    padding: 20px 0;
}

/* =========================================================
   REVIEW LIST
   ========================================================= */
.apx-rev-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 32px;
}

.apx-rev-item {
    background: var(--apx-r-bg);
    border: 1px solid var(--apx-r-border);
    border-radius: var(--apx-r-radius);
    padding: 20px 24px;
    transition: border-color 0.15s ease;
}

.apx-rev-item:hover {
    border-color: var(--apx-r-border-strong);
}

.apx-rev-item-header {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.apx-rev-item-author {
    font-family: var(--apx-r-font-display);
    font-weight: 700;
    font-size: 15px;
    color: var(--apx-r-text);
}

.apx-rev-item-date {
    color: var(--apx-r-muted);
    font-size: 13px;
    margin-left: auto;
}

.apx-rev-item-comment {
    margin: 0;
    color: var(--apx-r-text);
    font-size: 15px;
    line-height: 1.6;
}

.apx-rev-item-footer {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--apx-r-border);
    font-size: 12px;
    color: var(--apx-r-muted);
}

.apx-rev-item-recommend {
    color: var(--apx-r-success);
    font-weight: 600;
}

.apx-rev-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--apx-r-muted);
    background: var(--apx-r-bg-soft);
    border-radius: var(--apx-r-radius);
    border: 1px dashed var(--apx-r-border-strong);
    font-style: italic;
}

/* =========================================================
   INLINE STARS
   ========================================================= */
.apx-rev-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--apx-r-text-soft);
}

.apx-rev-inline .apx-rev-stars { font-size: 14px; }

.apx-rev-inline-text {
    font-weight: 600;
}

/* =========================================================
   SUBMISSION FORM
   ========================================================= */
.apx-rev-form-wrap {
    background: var(--apx-r-bg);
    border: 1px solid var(--apx-r-border);
    border-radius: var(--apx-r-radius);
    padding: 28px 32px;
    box-shadow: 0 1px 2px rgba(28, 25, 23, 0.04);
}

@media (max-width: 600px) {
    .apx-rev-form-wrap { padding: 20px; }
}

.apx-rev-form-title {
    font-family: var(--apx-r-font-display);
    font-size: 22px;
    margin: 0 0 4px;
    color: var(--apx-r-text);
}

.apx-rev-form-sub {
    margin: 0 0 20px;
    color: var(--apx-r-text-soft);
    font-size: 14px;
}

.apx-rev-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

@media (max-width: 600px) {
    .apx-rev-row { grid-template-columns: 1fr; }
}

.apx-rev-field {
    margin-bottom: 14px;
    border: 0;
    padding: 0;
}

.apx-rev-field:last-of-type { margin-bottom: 0; }

.apx-rev-field label,
.apx-rev-field legend {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    font-size: 13px;
    color: var(--apx-r-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.apx-rev-field input[type="text"],
.apx-rev-field input[type="email"],
.apx-rev-field input[type="date"],
.apx-rev-field textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--apx-r-border-strong);
    border-radius: var(--apx-r-radius-sm);
    font-size: 14px;
    font-family: inherit;
    background: var(--apx-r-bg);
    color: var(--apx-r-text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.apx-rev-field input:focus,
.apx-rev-field textarea:focus {
    outline: 0;
    border-color: var(--apx-r-accent);
    box-shadow: 0 0 0 3px var(--apx-r-accent-soft);
}

.apx-rev-field textarea {
    resize: vertical;
    min-height: 100px;
}

.apx-rev-hint {
    display: block;
    margin-top: 4px;
    font-size: 11px;
    color: var(--apx-r-muted);
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
}

/* Star input */
.apx-rev-stars-input {
    display: inline-flex;
    gap: 4px;
}

.apx-rev-star-btn {
    background: transparent;
    border: 0;
    padding: 4px;
    cursor: pointer;
    color: #d1d5db;
    transition: color 0.15s ease, transform 0.1s ease;
}

.apx-rev-star-btn:hover { transform: scale(1.1); }

.apx-rev-star-btn.is-active,
.apx-rev-star-btn.is-hover {
    color: var(--apx-r-star);
}

.apx-rev-star-icon {
    font-size: 36px;
    line-height: 1;
    display: block;
}

/* Recommend radios */
.apx-rev-recommend {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.apx-rev-recommend legend {
    width: 100%;
}

.apx-rev-radio {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border: 1px solid var(--apx-r-border-strong);
    border-radius: var(--apx-r-radius-sm);
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.15s ease;
    text-transform: none;
    letter-spacing: 0;
}

.apx-rev-radio:hover {
    border-color: var(--apx-r-accent);
    background: var(--apx-r-bg-soft);
}

.apx-rev-radio:has(input:checked) {
    border-color: var(--apx-r-accent);
    background: var(--apx-r-accent-soft);
    color: var(--apx-r-accent);
}

.apx-rev-radio input { accent-color: var(--apx-r-accent); }

/* Submit + feedback */
.apx-rev-submit {
    width: 100%;
    padding: 13px;
    margin-top: 6px;
    font-size: 14px;
    font-weight: 700;
    font-family: inherit;
    color: #fff;
    background: var(--apx-r-accent);
    border: 0;
    border-radius: var(--apx-r-radius-sm);
    cursor: pointer;
    transition: background 0.15s ease;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.apx-rev-submit:hover { background: #6e2d23; }
.apx-rev-submit:disabled { opacity: 0.7; cursor: wait; }

.apx-rev-feedback {
    margin: 14px 0;
    padding: 11px 13px;
    border-radius: var(--apx-r-radius-sm);
    display: none;
    font-size: 14px;
    line-height: 1.5;
}

.apx-rev-feedback.is-error {
    display: block;
    background: var(--apx-r-error-bg);
    border: 1px solid #fca5a5;
    color: var(--apx-r-error);
}

.apx-rev-feedback.is-success {
    display: block;
    background: var(--apx-r-success-bg);
    border: 1px solid #86efac;
    color: var(--apx-r-success);
}
