:root{
  --brand:#f36b21;
  --brand-soft: rgba(243,107,33,.10);

  --bg:#ffffff;
  --card:#ffffff;
  --line: rgba(15,23,42,.10);

  --text:#0f172a;
  --muted: rgba(15,23,42,.60);

  --shadow: 0 10px 28px rgba(15,23,42,.10);
  --r: 14px;

  /* premium gold for rating */
  --gold: #D4AF37;
  --gold-deep:#B8860B;
  --gold-soft: rgba(212,175,55,.16);

  --pad: 14px;
  --font: Inter,system-ui;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:var(--font);
  background: var(--bg);
  color: var(--text);
}

/* ================= TOP BAR ================= */
.topBar{
  position: sticky;
  top: 0;
  z-index: 50;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px var(--pad);
  border-bottom: 1px solid var(--line);
  background: #fff;
}

.iconBtn{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: none;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: rgba(15,23,42,.78);
  cursor:pointer;
  text-decoration:none;
}
.iconBtn:active{ transform: scale(.98); }
.iconBtn.ghost{
  background: #fff;
}

.topBarMid{
  flex:1;
  min-width: 0;
}
.topTitle{
  display:flex;
  align-items:center;
  gap: 10px;
  font-weight: 950;
  font-size: large;
  padding-bottom: 10px;
}
.topTitle i{ color: var(--gold-deep); font-size: large;}
.topSub{
  display:flex;
  align-items:center;
  gap: 8px;
  margin-top: 2px;
  font-size: small;
  color: var(--muted);
}

/* ================= TABS ================= */
.tabs{
  display:flex;
  gap: 10px;
  padding: 10px var(--pad) 12px;
  background: #fff;
  border-bottom: 1px solid var(--line);
}

.tab{
  flex:1;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: 10px 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  font-weight: 900;
  font-size: medium;
  cursor:pointer;
  color: rgba(15,23,42,.85);
}

.tab i{ color: rgba(15,23,42,.55);  font-size: medium;}

.tab.active{
  border-color: rgba(184,134,11,.28);
  background: linear-gradient(180deg, rgba(255,247,214,.92), rgba(255,239,184,.70));
  color: #3a2a00;
  box-shadow: 0 10px 22px rgba(184,134,11,.10);
}

.tab.active i{ color: var(--gold-deep); }

.pillCount{
  min-width: 28px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(33, 42, 68, 0.06);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size: medium;
  font-weight: 950;
}
.tab.active .pillCount{
  background: rgba(184,134,11,.16);
}

/* ================= PAGE ================= */
.page{
  max-width: 760px;
  margin: 0 auto;
  padding: var(--pad);
}

.list{
  display:flex;
  flex-direction:column;
  gap: 12px;
}

/* ================= CARD ================= */
.card{
  background: #fffdf7;
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 14px;
}

.cardTop{
  display:flex;
  gap: 12px;
}

.thumb{
  width: 58px;
  height: 58px;
  border-radius: 14px;
  background: #f1f1f1;
  border: 1px solid rgba(15,23,42,.06);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}
.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.cardMeta{
  flex:1;
  min-width:0;
}
.titleRow{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
}
.productTitle{
  font-weight: 950;
  font-size: 14px;
  line-height: 1.25;
}
.badge{
  font-size: 11px;
  font-weight: 950;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(184,134,11,.20);
  background: rgba(212,175,55,.12);
  color: #3a2a00;
  display:inline-flex;
  align-items:center;
  gap: 6px;
}

.subLine{
  margin-top: 6px;
  color: rgba(15,23,42,.64);
  font-size: 12px;
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}
.subLine i{ color: rgba(15,23,42,.45); }

.smallSupplier{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(15,23,42,.65);
  display:flex;
  align-items:center;
  gap: 8px;
}
.smallSupplier i{ color: var(--brand); opacity:.9; }

/* ================= GOLD STARS ================= */
.stars{
  margin-top: 10px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.starBtn{
  border:none;
  background: transparent;
  padding: 0;
  cursor:pointer;
  font-size: 22px;
  line-height: 1;
  color: rgba(15,23,42,.22);
  transform-origin:center;
}
.starBtn.active{
  color: var(--gold);
  text-shadow: 0 8px 20px rgba(212,175,55,.18);
}
.starBtn:active{ transform: scale(.96); }

.ratingHint{
  margin-left: 6px;
  font-size: 12px;
  color: rgba(15,23,42,.55);
  display:flex;
  align-items:center;
  gap: 8px;
}
.ratingHint i{ color: var(--gold-deep); }

/* ================= TEXTAREA ================= */
.note{
  margin-top: 10px;
  width: 100%;
  min-height: 76px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.12);
  padding: 10px 12px;
  font-family: inherit;
  resize: none;
  outline: none;
  background: #fff;
}
.note:focus{
  border-color: rgba(184,134,11,.36);
  box-shadow: 0 0 0 4px rgba(212,175,55,.14);
}

/* ================= ACTIONS ================= */
.actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  margin-top: 12px;
}

.miniInfo{
  font-size: 12px;
  color: rgba(15,23,42,.60);
  display:flex;
  align-items:center;
  gap: 8px;
}
.miniInfo i{ color: rgba(15,23,42,.45); }

.btn{
  border: none;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 950;
  cursor:pointer;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
}

.btn.primary{
  background: linear-gradient(180deg, rgba(255,247,214,.96), rgba(255,239,184,.78));
  border: 1px solid rgba(184,134,11,.30);
  color: #3a2a00;
  box-shadow: 0 10px 22px rgba(184,134,11,.10);
}

.btn.primary i{ color: var(--gold-deep); }

.btn.ghost{
  background:#f1f1f1;
  color: rgba(15,23,42,.85);
}

.btn.disabled,
.btn:disabled{
  opacity: .60;
  cursor:not-allowed;
}

/* ================= REVIEWED CARD ================= */
.reviewedRow{
  margin-top: 10px;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  align-items:flex-start;
}

.reviewedLeft{
  display:flex;
  gap: 10px;
  align-items:center;
}

.smallStars{
  display:flex;
  gap: 4px;
  font-size: 14px;
  color: rgba(15,23,42,.22);
}
.smallStars .on{ color: var(--gold); }

.quote{
  color: rgba(15,23,42,.80);
  font-size: 13px;
  line-height: 1.35;
}
.timeAgo{
  font-size: 12px;
  color: rgba(15,23,42,.55);
  white-space: nowrap;
}

/* ================= STATES ================= */
.stateBlock{
  border: 1px dashed rgba(15,23,42,.18);
  border-radius: var(--r);
  padding: 18px;
  background: #fff;
}

.stateBlock.error{
  border-color: rgba(157,16,34,.25);
  background: rgba(255,231,234,.35);
}

.stateBlock.empty{
  border-color: rgba(184,134,11,.25);
  background: rgba(255,247,214,.45);
}

.stateHead{
  font-weight: 950;
  display:flex;
  align-items:center;
  gap: 10px;
}

.stateText{
  margin-top: 8px;
  color: rgba(15,23,42,.70);
  font-size: 13px;
  line-height: 1.35;
}

.emptyHint{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(15,23,42,.65);
  display:flex;
  align-items:flex-start;
  gap: 10px;
}

/* ================= Skeletons ================= */
.skeletonGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.skCard{
  height: 132px;
  border-radius: var(--r);
  background: linear-gradient(90deg, rgba(15,23,42,.05), rgba(15,23,42,.08), rgba(15,23,42,.05));
  background-size: 200% 100%;
  animation: shimmer 1.2s infinite;
  border: 1px solid rgba(15,23,42,.06);
}
@keyframes shimmer{
  0%{ background-position: 0% 0; }
  100%{ background-position: 200% 0; }
}

.productRating {
    padding-top: 12px;
}