.my-reviews-page { --review-accent:#facc15; --review-border:rgba(148,163,184,.24); --review-muted:var(--muted-text,#64748b); }
.my-reviews-page__head { display:grid; grid-template-columns:minmax(0,1fr) minmax(360px,520px); align-items:start; gap:18px; margin-bottom:18px; }
.my-reviews-page__intro { min-width:0; }
.my-reviews-page__lead { max-width:760px; margin-bottom:0; }
.my-reviews-stats { display:grid; grid-template-columns:repeat(4,minmax(72px,1fr)); gap:8px; justify-self:end; width:100%; max-width:520px; }
.my-reviews-stat { border:1px solid var(--review-border); border-radius:16px; padding:10px 9px; background:var(--card-bg,rgba(255,255,255,.78)); text-align:center; box-shadow:0 10px 26px rgba(15,23,42,.07); min-width:0; }
.my-reviews-stat strong { display:block; font-size:1.15rem; line-height:1; letter-spacing:-.02em; color:var(--heading-color,#0f172a); }
.my-reviews-stat span { display:block; margin-top:5px; color:var(--review-muted); font-size:.72rem; white-space:nowrap; }
.my-reviews-panel { padding:18px; }
.my-reviews-toolbar { display:grid; grid-template-columns:minmax(260px,1fr) 150px 190px 170px; gap:14px; align-items:end; margin-bottom:14px; }
.my-reviews-toolbar label, .review-modal-form label { display:grid; gap:7px; font-weight:700; font-size:.88rem; color:var(--heading-color,#111827); }
.my-reviews-search { min-width:0; }
.my-reviews-results-head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin:4px 0 16px; color:var(--review-muted); font-size:.9rem; }
.my-reviews-results-head [data-result-count] { display:inline-grid; place-items:center; min-width:30px; height:24px; padding:0 8px; border-radius:999px; background:rgba(250,204,21,.18); color:#92400e; font-weight:900; }
.my-reviews-loading { font-weight:800; }
.my-reviews-grid { display:grid; gap:12px; min-height:160px; transition:opacity .16s ease; }
.my-reviews-root.is-loading .my-reviews-grid { opacity:.55; }
.my-review-card { display:grid; grid-template-columns:132px minmax(0,1fr); gap:16px; padding:16px; border-radius:22px; border:1px solid var(--review-border); background:var(--card-bg,rgba(255,255,255,.78)); box-shadow:0 16px 42px rgba(15,23,42,.08); transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease; }
.my-review-card:hover { transform:translateY(-1px); box-shadow:0 18px 48px rgba(15,23,42,.12); }
.my-review-card.is-removing { opacity:.35; transform:scale(.985); }
.my-review-card__image { display:grid; place-items:center; height:132px; border-radius:18px; background:#fff; border:1px solid rgba(148,163,184,.18); overflow:hidden; }
.my-review-card__image img { max-width:88%; max-height:104px; object-fit:contain; transition:transform .18s ease; }
.my-review-card__image--shop img { max-width:92%; max-height:86px; filter:none; }
.my-review-card__image span { font-size:42px; }
.my-review-card:hover .my-review-card__image img { transform:scale(1.03); }
.my-review-card__body { min-width:0; display:grid; align-content:start; }
.my-review-card__header { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:12px; align-items:start; }
.my-review-card__type { color:var(--review-muted); font-weight:800; font-size:.78rem; margin-bottom:5px; }
.my-review-card__type span { color:var(--heading-color,#111827); }
.my-review-card h2 { margin:0; font-size:1.05rem; line-height:1.25; letter-spacing:-.015em; }
.my-review-card h2 a { color:inherit; text-decoration:none; }
.my-review-card h2 a:hover { text-decoration:underline; }
.my-review-card__rating-date { display:grid; justify-items:end; gap:6px; white-space:nowrap; }
.my-review-stars { letter-spacing:.05em; color:var(--review-accent); font-size:1rem; line-height:1; }
.my-review-stars span { color:rgba(148,163,184,.55); }
.my-review-date { color:var(--review-muted); font-size:.8rem; }
.my-review-card__meta-row { display:flex; flex-wrap:wrap; gap:6px 10px; align-items:center; margin-top:8px; color:var(--review-muted); font-size:.78rem; }
.my-review-card__meta-row > span:not(.my-review-status), .my-review-subratings span { display:inline-flex; align-items:center; min-height:24px; padding:3px 8px; border-radius:999px; background:rgba(148,163,184,.11); }
.my-review-title { margin:12px 0 5px; font-size:.92rem; line-height:1.35; color:var(--heading-color,#111827); }
.my-review-text { margin:0; color:var(--body-text,#334155); line-height:1.55; font-size:.92rem; }
.my-review-status { font-size:.72rem; font-weight:900; padding:4px 8px; border-radius:999px; background:rgba(148,163,184,.16); }
.my-review-status--approved { background:rgba(34,197,94,.14); color:#16a34a; }
.my-review-status--pending { background:rgba(250,204,21,.16); color:#b45309; }
.my-review-status--rejected { background:rgba(239,68,68,.14); color:#dc2626; }
.my-review-subratings { display:flex; flex-wrap:wrap; gap:7px; margin-top:10px; color:var(--review-muted); font-size:.78rem; }
.my-review-actions { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.my-review-actions .btn { min-height:38px; padding-inline:16px; }
.my-review-delete { color:#dc2626; }
.my-reviews-empty { text-align:center; padding:46px 24px; border-radius:24px; border:1px dashed rgba(148,163,184,.36); background:rgba(148,163,184,.06); }
.my-reviews-empty__icon { width:70px; height:70px; border-radius:24px; display:grid; place-items:center; margin:0 auto 14px; font-size:34px; background:rgba(250,204,21,.16); }
.my-reviews-empty h2 { margin:0 0 8px; }
.my-reviews-empty p { margin:0; color:var(--review-muted); }
.my-reviews-pagination { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-top:22px; }
.my-reviews-page-link { min-width:40px; height:40px; display:grid; place-items:center; border-radius:14px; border:1px solid var(--review-border); background:transparent; text-decoration:none; font-weight:800; color:inherit; cursor:pointer; }
.my-reviews-page-link.is-active, .my-reviews-page-link:hover:not(:disabled) { background:var(--review-accent); border-color:var(--review-accent); color:#111827; }
.my-reviews-page-link:disabled { opacity:.45; cursor:not-allowed; }
.review-modal { position:fixed; inset:0; z-index:1000; display:none; align-items:center; justify-content:center; padding:18px; }
.review-modal.is-open { display:flex; }
.review-modal__backdrop { position:absolute; inset:0; background:rgba(15,23,42,.58); backdrop-filter:blur(8px); }
.review-modal__dialog { position:relative; width:min(620px,100%); max-height:min(760px,calc(100vh - 36px)); overflow:hidden; border-radius:26px; background:var(--card-bg,#fff); box-shadow:0 28px 90px rgba(15,23,42,.28); }
.review-modal__dialog--sm { width:min(460px,100%); }
.review-modal__close { position:absolute; top:14px; right:14px; z-index:2; }
.review-modal__content { padding:28px; overflow:auto; max-height:min(760px,calc(100vh - 36px)); }
.review-modal__eyebrow { display:inline-flex; align-items:center; min-height:26px; padding:4px 10px; border-radius:999px; background:rgba(250,204,21,.18); color:#92400e; font-size:.76rem; font-weight:900; margin-bottom:12px; }
.review-modal__eyebrow--danger { background:rgba(239,68,68,.14); color:#dc2626; }
.review-modal__title { margin:0; font-size:1.45rem; letter-spacing:-.03em; color:var(--heading-color,#111827); }
.review-modal__text { margin:8px 0 18px; color:var(--review-muted); line-height:1.55; }
.review-modal-form { display:grid; gap:14px; }
.review-modal-form textarea { resize:vertical; min-height:150px; }
.review-modal-form__split { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.review-modal__actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.btn-danger { background:#dc2626; border-color:#dc2626; color:#fff; }
.btn-danger:hover { background:#b91c1c; border-color:#b91c1c; color:#fff; }
[data-theme="dark"] .my-reviews-page { --review-border:rgba(148,163,184,.20); --review-muted:rgba(203,213,225,.78); }
[data-theme="dark"] .my-reviews-stat, [data-theme="dark"] .my-review-card, [data-theme="dark"] .review-modal__dialog { background:rgba(15,23,42,.78); }
[data-theme="dark"] .my-review-card__image { background:#fff; border-color:rgba(255,255,255,.12); }
[data-theme="dark"] .my-review-text { color:rgba(226,232,240,.92); }
[data-theme="dark"] .my-review-card__meta-row > span:not(.my-review-status), [data-theme="dark"] .my-review-subratings span { background:rgba(148,163,184,.14); }
[data-theme="dark"] .my-reviews-results-head [data-result-count], [data-theme="dark"] .review-modal__eyebrow { color:#fde68a; background:rgba(250,204,21,.16); }
[data-theme="dark"] .review-modal__eyebrow--danger { color:#fecaca; background:rgba(239,68,68,.16); }
@media (prefers-color-scheme: dark) {
  body:not([data-theme="light"]) .my-reviews-page { --review-border:rgba(148,163,184,.20); --review-muted:rgba(203,213,225,.78); }
  body:not([data-theme="light"]) .my-reviews-stat, body:not([data-theme="light"]) .my-review-card, body:not([data-theme="light"]) .review-modal__dialog { background:rgba(15,23,42,.78); }
  body:not([data-theme="light"]) .my-review-card__image { background:#fff; border-color:rgba(255,255,255,.12); }
  body:not([data-theme="light"]) .my-review-text { color:rgba(226,232,240,.92); }
}
@media (max-width:1180px) { .my-reviews-page__head { grid-template-columns:1fr; } .my-reviews-stats { justify-self:stretch; max-width:none; } }
@media (max-width:920px) { .my-reviews-toolbar { grid-template-columns:1fr 1fr; } .my-review-card { grid-template-columns:118px minmax(0,1fr); } .my-review-card__image { height:118px; } }
@media (max-width:680px) { .my-reviews-toolbar { grid-template-columns:1fr; } .my-reviews-stats { grid-template-columns:repeat(2,1fr); } .my-review-card { grid-template-columns:1fr; } .my-review-card__image { height:172px; } .my-review-card__header { grid-template-columns:1fr; } .my-review-card__rating-date { justify-items:start; } .review-modal-form__split { grid-template-columns:1fr; } }

/* Keep shop-only subratings out of product review modals. */
.review-modal-form__split[hidden],
[data-shop-subratings][hidden] {
  display: none !important;
}


/* Product and shop images should sit on a neutral white tile in every theme. */
.my-review-card__image,
.my-review-card__image--shop,
[data-theme="dark"] .my-review-card__image,
[data-theme="dark"] .my-review-card__image--shop,
body:not([data-theme="light"]) .my-review-card__image,
body:not([data-theme="light"]) .my-review-card__image--shop {
  background: #fff !important;
  background-image: none !important;
}
