﻿/* WHMPRESS Reviews — Frontend Stylesheet
   Colors: #067ABF primary | #24C1E8 accent | #052355 dark navy */

.whmp-reviews-root {
--whmp-primary:      #067ABF;
--whmp-accent:       #24C1E8;
--whmp-dark:         #052355;
--whmp-white:        #ffffff;
--whmp-primary-rgb:  6, 122, 191;
--whmp-accent-rgb:   36, 193, 232;
--whmp-dark-rgb:     5, 35, 85;
--whmp-bg:           #f4f8fd;
--whmp-border:       #d0dff0;
--whmp-text:         #1a2a45;
--whmp-muted:        #5b7090;
--whmp-star-fill:    #f5a623;
--whmp-star-empty:   #dde4f0;
--whmp-radius:       10px;
--whmp-shadow:       0px 0px 30px 5px rgba(0, 130.85103260869562, 173.4, 0.12);
--whmp-focus:        0 0 0 3px rgba(6, 122, 191, 0.25);
--whmp-tr:           all 0.2s ease;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
color: var(--whmp-text);
line-height: 1.6;
max-width: 100%;
margin: 0 auto;
padding: 0;
box-sizing: border-box;
}
.whmp-reviews-root *, .whmp-reviews-root *::before, .whmp-reviews-root *::after {
box-sizing: inherit;
}
/* Ensure [hidden] is respected even when themes override display */
.whmp-reviews-root [hidden] { display: none !important; }
/* Defeat theme reset.css rules that colour all [type=button]/button elements */
.whmp-reviews-root button,
.whmp-reviews-root [type="button"],
.whmp-reviews-root [type="submit"] {
background-color: transparent;
color: inherit;
border: none;
}
.whmp-reviews-root button:hover,
.whmp-reviews-root [type="button"]:hover,
.whmp-reviews-root [type="submit"]:hover,
.whmp-reviews-root button:focus,
.whmp-reviews-root [type="button"]:focus,
.whmp-reviews-root [type="submit"]:focus {
background-color: transparent;
color: inherit;
text-decoration: none;
}

/* White outer container */
.whmp-reviews-box {
background: var(--whmp-white);
border-radius: 10px;
box-shadow: var(--whmp-shadow);
padding: 30px 34px;
}

/* Auth area separator */
.whmp-reviews-auth {
margin-bottom: 28px;
padding-bottom: 28px;
border-bottom: 1px solid var(--whmp-border);
}

/* Trigger button */
.whmp-reviews-root .whmp-reviews-trigger {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 11px 22px;
background: linear-gradient(135deg, var(--whmp-primary), #0562a0);
color: var(--whmp-white);
border: none;
border-radius: 8px;
font-size: .9375rem;
font-weight: 600;
font-family: inherit;
cursor: pointer;
transition: var(--whmp-tr);
}
.whmp-reviews-root .whmp-reviews-trigger:hover {
background: linear-gradient(135deg, #0562a0, #044a7a);
background-color: #0562a0;
color: var(--whmp-white);
transform: translateY(-1px);
box-shadow: 0 4px 14px rgba(var(--whmp-primary-rgb), .35);
}

/* Login panel */
.whmp-reviews-login-panel {
background: var(--whmp-bg);
border: 1px solid var(--whmp-border);
border-radius: var(--whmp-radius);
padding: 22px 26px;
animation: whmp-popup .22s ease;
}
.whmp-reviews-login-panel h3 {
margin: 0 0 4px;
font-size: 1.05rem;
color: var(--whmp-dark);
}
.whmp-reviews-login-panel > p {
margin: 0 0 16px;
font-size: .875rem;
color: var(--whmp-muted);
}

/* Write panel */
.whmp-reviews-write-panel {
background: var(--whmp-bg);
border: 1px solid var(--whmp-border);
border-radius: var(--whmp-radius);
padding: 20px 24px;
animation: whmp-popup .22s ease;
}

/* User strip */
.whmp-reviews-user-strip {
display: flex;
align-items: center;
gap: 10px;
padding: 9px 13px;
background: linear-gradient(90deg, rgba(var(--whmp-accent-rgb), .09), rgba(var(--whmp-primary-rgb), .05));
border: 1px solid rgba(var(--whmp-accent-rgb), .28);
border-radius: 7px;
margin-bottom: 16px;
font-size: .875rem;
color: var(--whmp-dark);
}
.whmp-reviews-avatar-sm {
width: 32px;
height: 32px;
border-radius: 50%;
background: linear-gradient(135deg, var(--whmp-primary), var(--whmp-accent));
color: var(--whmp-white);
display: flex;
align-items: center;
justify-content: center;
font-size: .875rem;
font-weight: 700;
flex-shrink: 0;
}
.whmp-reviews-switch-btn {
margin-left: auto;
background: transparent;
border: 1.5px solid var(--whmp-primary);
color: var(--whmp-primary);
border-radius: 6px;
padding: 4px 10px;
font-size: .8rem;
font-family: inherit;
cursor: pointer;
transition: var(--whmp-tr);
}
.whmp-reviews-switch-btn:hover {
background: rgba(var(--whmp-primary-rgb), .07);
background-color: rgba(var(--whmp-primary-rgb), .07);
color: var(--whmp-primary);
}

/* Already-reviewed notice */
.whmp-reviews-done {
display: flex;
align-items: center;
gap: 8px;
padding: 12px 16px;
background: #eff8ff;
border: 1px solid rgba(var(--whmp-primary-rgb), .22);
border-radius: 8px;
color: var(--whmp-primary);
font-size: .875rem;
font-weight: 500;
animation: whmp-popup .22s ease;
}

/* Form row (login) */
.whmp-reviews-form-row {
display: grid;
grid-template-columns: 1fr 1fr auto;
gap: 12px;
align-items: end;
}
.whmp-reviews-field {
display: flex;
flex-direction: column;
gap: 5px;
}
.whmp-reviews-field > label {
font-size: .8rem;
font-weight: 600;
color: var(--whmp-dark);
}
.whmp-reviews-field-action label {
visibility: hidden;
}

/* Inputs */
.whmp-reviews-input,
.whmp-reviews-textarea,
.whmp-reviews-sort-sel {
padding: 9px 12px;
font-size: .9375rem;
color: var(--whmp-text);
background: var(--whmp-white);
border: 1.5px solid var(--whmp-border);
border-radius: 7px;
outline: none;
transition: var(--whmp-tr);
font-family: inherit;
width: 100%;
}
.whmp-reviews-input:hover { border-color: var(--whmp-primary); }
.whmp-reviews-input:focus,
.whmp-reviews-textarea:focus,
.whmp-reviews-sort-sel:focus {
border-color: var(--whmp-primary);
box-shadow: var(--whmp-focus);
}
.whmp-reviews-textarea {
resize: vertical;
min-height: 88px;
}

/* Password eye */
.whmp-reviews-pw-wrap { position: relative; }
.whmp-reviews-pw-wrap .whmp-reviews-input { padding-right: 42px; }
.whmp-reviews-pw-eye {
position: absolute;
right: 8px;
top: 50%;
transform: translateY(-50%);
background: none;
border: none;
cursor: pointer;
color: var(--whmp-muted);
padding: 4px;
border-radius: 4px;
display: flex;
align-items: center;
line-height: 0;
}
.whmp-reviews-pw-eye svg { width: 18px; height: 18px; fill: currentColor; }
.whmp-reviews-pw-eye:hover { color: var(--whmp-primary); background-color: transparent; }

/* Buttons */
.whmp-reviews-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
padding: 9px 20px;
font-size: .9375rem;
font-weight: 600;
font-family: inherit;
border-radius: 7px;
border: none;
cursor: pointer;
transition: var(--whmp-tr);
white-space: nowrap;
background: linear-gradient(135deg, var(--whmp-primary), #0562a0);
color: var(--whmp-white);
}
.whmp-reviews-btn:hover:not(:disabled) {
background: linear-gradient(135deg, #0562a0, #044a7a);
background-color: #0562a0;
color: var(--whmp-white);
transform: translateY(-1px);
box-shadow: 0 4px 14px rgba(var(--whmp-primary-rgb), .35);
}
.whmp-reviews-btn:disabled {
opacity: .5;
cursor: not-allowed;
transform: none;
}
.whmp-reviews-spinner {
display: inline-block;
width: 15px;
height: 15px;
border: 2px solid rgba(255, 255, 255, .35);
border-top-color: var(--whmp-white);
border-radius: 50%;
animation: whmp-spin .7s linear infinite;
}

/* Error message */
.whmp-reviews-error {
margin-top: 10px;
padding: 10px 14px;
background: #fff2f2;
border: 1px solid #f5c6c6;
border-radius: 7px;
color: #c0392b;
font-size: .875rem;
animation: whmp-popup .2s ease;
}

/* Form bottom — stars + submit on same row */
.whmp-reviews-form-bottom {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 12px;
margin-top: 14px;
}

/* Interactive star picker */
.whmp-reviews-stars-pick {
display: flex;
align-items: center;
gap: 2px;
}
.whmp-reviews-star-btn {
background: none;
border: none;
font-size: 1.8rem;
color: var(--whmp-star-empty);
cursor: pointer;
padding: 2px;
line-height: 1;
transition: color .15s, transform .15s;
font-family: inherit;
}
.whmp-reviews-star-btn:hover,
.whmp-reviews-star-btn.hover,
.whmp-reviews-star-btn.sel {
color: var(--whmp-primary);
background-color: transparent;
transform: scale(1.18);
}
.whmp-reviews-star-label {
font-size: .8125rem;
font-weight: 600;
color: var(--whmp-dark);
margin-left: 8px;
min-width: 58px;
}

/* Reviews section */
.whmp-reviews-section { padding-top: 2px; }

.whmp-reviews-heading {
font-size: 1.35rem;
font-weight: 700;
color: var(--whmp-dark);
margin: 0 0 20px;
}

/* Rating summary */
.whmp-reviews-summary {
display: flex;
gap: 28px;
align-items: center;
flex-wrap: wrap;
background: var(--whmp-bg);
border: 1px solid var(--whmp-border);
border-radius: var(--whmp-radius);
padding: 20px 24px;
margin-bottom: 18px;
}
.whmp-reviews-score {
display: flex;
flex-direction: column;
align-items: center;
gap: 5px;
min-width: 80px;
}
.whmp-reviews-avg {
font-size: 2.8rem;
font-weight: 800;
color: var(--whmp-dark);
line-height: 1;
}
.whmp-reviews-total {
font-size: .8rem;
color: var(--whmp-muted);
}
.whmp-reviews-bars {
flex: 1;
min-width: 160px;
display: flex;
flex-direction: column;
gap: 5px;
}
.whmp-reviews-root .whmp-reviews-bar-btn {
display: flex;
align-items: center;
gap: 7px;
width: 100%;
background: none;
background-color: transparent;
border: none;
padding: 3px 5px;
cursor: pointer;
border-radius: 6px;
transition: var(--whmp-tr);
color: var(--whmp-text);
font-family: inherit;
}
.whmp-reviews-bar-btn:hover { background: rgba(var(--whmp-primary-rgb), .06); background-color: rgba(var(--whmp-primary-rgb), .06); color: var(--whmp-text); }
.whmp-reviews-bar-lbl {
font-size: .8rem;
font-weight: 600;
color: var(--whmp-text);
min-width: 22px;
}
.whmp-reviews-bar-track {
flex: 1;
height: 7px;
background: var(--whmp-star-empty);
border-radius: 99px;
overflow: hidden;
}
.whmp-reviews-bar-fill {
height: 100%;
background: linear-gradient(90deg, var(--whmp-primary), var(--whmp-accent));
border-radius: 99px;
transition: width .5s cubic-bezier(.4, 0, .2, 1);
}
.whmp-reviews-bar-ct {
font-size: .8rem;
color: var(--whmp-muted);
min-width: 18px;
text-align: right;
}
.whmp-reviews-bar-btn.bar-active .whmp-reviews-bar-fill {
background: linear-gradient(90deg, var(--whmp-dark), var(--whmp-primary));
}

/* Controls */
.whmp-reviews-controls {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 10px;
padding: 11px 14px;
background: var(--whmp-bg);
border: 1px solid var(--whmp-border);
border-radius: 9px;
margin-bottom: 18px;
}
.whmp-reviews-filters {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 5px;
}
.whmp-reviews-ctrl-lbl {
font-size: .8rem;
font-weight: 600;
color: var(--whmp-muted);
}
.whmp-reviews-root .whmp-reviews-filter-btn {
padding: 5px 12px;
font-size: .8rem;
font-weight: 600;
font-family: inherit;
color: var(--whmp-muted);
background: var(--whmp-white);
background-color: var(--whmp-white);
border: 1.5px solid var(--whmp-border);
border-radius: 99px;
cursor: pointer;
transition: var(--whmp-tr);
}
.whmp-reviews-root .whmp-reviews-filter-btn:hover { border-color: var(--whmp-primary); color: var(--whmp-primary); background-color: var(--whmp-white); }
.whmp-reviews-root .whmp-reviews-filter-btn.active {
background: var(--whmp-primary);
background-color: var(--whmp-primary);
border-color: var(--whmp-primary);
color: var(--whmp-white);
}
.whmp-reviews-sort {
display: flex;
align-items: center;
gap: 6px;
}
.whmp-reviews-sort-sel {
appearance: none;
-webkit-appearance: none;
padding: 6px 28px 6px 10px;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%235b7090'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 6px center;
background-size: 18px;
font-size: .875rem;
width: auto;
border: 1.5px solid var(--whmp-border);
border-radius: 7px;
cursor: pointer;
}

/* Review cards */
.whmp-reviews-cards {
display: flex;
flex-direction: column;
gap: 12px;
}
.whmp-reviews-card {
background: var(--whmp-white);
border: 1px solid var(--whmp-border);
border-radius: var(--whmp-radius);
padding: 18px 22px;
box-shadow: 0 1px 5px rgba(5, 35, 85, .05);
transition: var(--whmp-tr);
animation: whmp-popup .3s ease;
}
.whmp-reviews-card:hover {
box-shadow: 0 4px 16px rgba(5, 35, 85, .1);
border-color: rgba(var(--whmp-primary-rgb), .28);
transform: translateY(-1px);
}
.whmp-reviews-card-head {
display: flex;
align-items: flex-start;
gap: 12px;
margin-bottom: 12px;
flex-wrap: wrap;
}
.whmp-reviews-avatar {
width: 42px;
height: 42px;
border-radius: 50%;
background: linear-gradient(135deg, var(--whmp-primary), var(--whmp-accent));
color: var(--whmp-white);
font-size: 1.05rem;
font-weight: 700;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
box-shadow: 0 2px 7px rgba(var(--whmp-primary-rgb), .28);
}
.whmp-reviews-card-meta {
display: flex;
flex-direction: column;
gap: 2px;
flex: 1;
}
.whmp-reviews-card-meta strong {
font-size: .9375rem;
color: var(--whmp-dark);
}
.whmp-reviews-card-meta time {
font-size: .78rem;
color: var(--whmp-muted);
}
.whmp-reviews-card-rating {
display: flex;
align-items: center;
gap: 5px;
margin-left: auto;
font-size: .875rem;
font-weight: 700;
color: var(--whmp-dark);
}
.whmp-reviews-card-text {
font-size: .9375rem;
color: var(--whmp-text);
margin: 0;
line-height: 1.65;
}

/* Edit button — pencil icon on user's own card */
.whmp-reviews-edit-btn {
flex-shrink: 0;
background: transparent;
border: none;
cursor: pointer;
padding: 5px;
color: var(--whmp-muted);
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
transition: var(--whmp-tr);
opacity: 0;
}
.whmp-reviews-card:hover .whmp-reviews-edit-btn,
.whmp-reviews-card-edit ~ .whmp-reviews-edit-btn {
opacity: 1;
}
.whmp-reviews-edit-btn:hover {
color: var(--whmp-primary);
background: rgba(var(--whmp-primary-rgb), .1);
background-color: rgba(var(--whmp-primary-rgb), .1);
opacity: 1;
}

/* Inline edit form */
.whmp-reviews-card-edit {
margin-top: 12px;
padding-top: 14px;
border-top: 1px solid var(--whmp-border);
animation: whmp-popup .2s ease;
}
.whmp-reviews-edit-stars {
display: flex;
align-items: center;
gap: 4px;
margin-bottom: 10px;
}
.whmp-reviews-edit-text {
width: 100%;
padding: 10px 12px;
border: 1px solid var(--whmp-border);
border-radius: var(--whmp-radius);
font-family: inherit;
font-size: .9375rem;
color: var(--whmp-text);
background: var(--whmp-bg);
resize: vertical;
transition: border-color .2s, box-shadow .2s;
box-sizing: border-box;
}
.whmp-reviews-edit-text:focus {
outline: none;
border-color: var(--whmp-primary);
box-shadow: var(--whmp-focus);
background: var(--whmp-white);
}
.whmp-reviews-edit-actions {
display: flex;
align-items: center;
gap: 10px;
margin-top: 10px;
}
.whmp-reviews-edit-save-btn {
padding: 8px 20px;
font-size: .875rem;
}
.whmp-reviews-edit-cancel-btn {
background: transparent;
border: none;
cursor: pointer;
font-size: .875rem;
color: var(--whmp-muted);
padding: 8px 10px;
border-radius: 6px;
transition: var(--whmp-tr);
}
.whmp-reviews-edit-cancel-btn:hover {
color: var(--whmp-text);
background: var(--whmp-bg);
background-color: var(--whmp-bg);
}

/* Static star row */
.whmp-reviews-stars-static { display: inline-flex; gap: 1px; }
.whmp-reviews-star-icon { width: 16px; height: 16px; fill: var(--whmp-star-empty); }
.whmp-reviews-star-full { fill: var(--whmp-star-fill); }
.whmp-reviews-star-half { fill: url(#whmp-half-grad); }

/* Empty / no-results */
.whmp-reviews-empty,
.whmp-reviews-nores {
text-align: center;
padding: 32px 16px;
color: var(--whmp-muted);
font-style: italic;
}
.whmp-reviews-empty p, .whmp-reviews-nores p { margin: 0; }

/* Avg stars container */
.whmp-reviews-avg-stars { display: flex; }

/* Responsive */
@media (max-width: 640px) {
.whmp-reviews-box { padding: 18px 16px; }
.whmp-reviews-form-row { grid-template-columns: 1fr; }
.whmp-reviews-summary { flex-direction: column; gap: 16px; }
.whmp-reviews-score { flex-direction: row; gap: 12px; }
.whmp-reviews-controls { flex-direction: column; align-items: flex-start; }
.whmp-reviews-card-rating { margin-left: 0; margin-top: 4px; }
.whmp-reviews-form-bottom { flex-direction: column; align-items: flex-start; }
}

/* Animations */
@keyframes whmp-popup {
from { opacity: 0; transform: translateY(8px); }
to   { opacity: 1; transform: translateY(0); }
}
@keyframes whmp-spin {
to { transform: rotate(360deg); }
}
@keyframes whmp-shake {
0%, 100% { transform: translateX(0); }
20%       { transform: translateX(-5px); }
40%       { transform: translateX(5px); }
60%       { transform: translateX(-3px); }
80%       { transform: translateX(3px); }
}
.whmp-reviews-shake {
animation: whmp-shake .5s ease both;
}
