:root{
  --bg:#f3f4f6;
  --surface:#ffffff;
  --line:#e5e7eb;
  --text:#1e293b;
  --muted:#5b667a;
  --muted-2:#7a8598;
  --primary:#6f86f6;
  --primary-dark:#5b74ea;
  --green:#7fa98f;
  --shadow:0 8px 24px rgba(15,23,42,.05);
  --radius:16px;
  --shell:1280px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
}
a{text-decoration:none;color:inherit}
button{font:inherit}
.hidden{display:none!important}

.ml-shell{
  width:min(var(--shell), calc(100% - 40px));
  margin:0 auto;
}

.ml-topbar{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:30;
  backdrop-filter:blur(10px);
}

.ml-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:84px;
}

.ml-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.ml-brand-badge{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#94aafc,#7288f7);
  color:#fff;
  font-weight:800;
  font-size:1.4rem;
}

.ml-brand-text{
  font-size:1.15rem;
  font-weight:800;
  color:#1f2937;
}

.ml-nav-links{
  display:flex;
  align-items:center;
  gap:34px;
}

.ml-nav-links a{
  font-size:1rem;
  font-weight:700;
  color:#243247;
}

.ml-theme-switch{
  appearance:none;
  border:none;
  background:transparent;
  padding:0;
  cursor:pointer;
}
.ml-theme-switch-track{
  width:58px;
  height:40px;
  border-radius:14px;
  border:1px solid #d9dde5;
  background:#fff;
  position:relative;
  display:block;
}
.ml-theme-switch-label{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  font-size:1rem;
  line-height:1;
  z-index:1;
}
.ml-theme-switch-sun{left:10px;opacity:0}
.ml-theme-switch-moon{right:10px;opacity:1}
.ml-theme-switch-thumb{
  position:absolute;
  top:4px;
  right:4px;
  width:30px;
  height:30px;
  border-radius:10px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  transition:all .18s ease;
}

.ml-hero-card{
  margin-top:42px;
  padding:56px 54px 42px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:34px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.ml-hero-content{
  position:relative;
  z-index:2;
  text-align:center;
}

.ml-logo-line{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:26px;
}

.ml-logo-mark{
  font-size:9rem;
  line-height:.8;
  font-weight:800;
  color:#1f304a;
}

.ml-logo-wordmark{
  font-size:clamp(4rem,8vw,7.4rem);
  line-height:.95;
  letter-spacing:-0.05em;
}

.ml-logo-dark{color:#1f304a}
.ml-logo-green{color:#86ad93}
.ml-logo-gray{color:#737b8a}

.ml-tagline-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:26px;
  margin:18px 0 20px;
}

.ml-tagline-row span{
  width:140px;
  height:1px;
  background:#c8ced8;
}

.ml-tagline-row p{
  margin:0;
  letter-spacing:.22em;
  font-size:1rem;
  color:#6c7688;
}

.ml-hero-copy{
  max-width:860px;
  margin:0 auto;
  font-size:1.05rem;
  line-height:1.7;
  color:#4b5563;
}

.ml-hero-actions{
  display:flex;
  justify-content:center;
  gap:16px;
  margin:28px 0 20px;
  flex-wrap:wrap;
}

.ml-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 24px;
  border-radius:14px;
  font-size:1rem;
  font-weight:700;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .18s ease;
}

.ml-btn-wide{
  width:340px;
  max-width:100%;
}

.ml-btn-primary{
  background:linear-gradient(135deg,#7f95fa,#5f77ef);
  color:#fff;
  box-shadow:0 8px 18px rgba(95,119,239,.22);
}

.ml-btn-primary:hover{
  transform:translateY(-1px);
}

.ml-btn-secondary{
  background:#fff;
  border-color:#d8dde5;
  color:#1f2937;
}

.ml-btn-secondary:hover{
  background:#fafbfc;
}

.ml-btn-solid{
  background:linear-gradient(135deg,#8aa1ff,#6f86f6);
  color:#fff;
  border:none;
  box-shadow:0 8px 18px rgba(95,119,239,.22);
}

.ml-signal-pills{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:34px;
}

.ml-pill{
  background:#fff;
  border:1px solid #dce2ea;
  border-radius:999px;
  padding:14px 18px;
  font-weight:700;
  color:#2b3a4f;
}

.ml-stat-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:10px;
}

.ml-stat-card{
  display:flex;
  gap:16px;
  align-items:flex-start;
  padding:22px;
  border:1px solid #e3e8ef;
  border-radius:18px;
  background:#fff;
}

.ml-stat-icon{
  width:72px;
  height:72px;
  border-radius:22px;
  display:grid;
  place-items:center;
  font-size:2rem;
  background:#eef2ff;
  flex:0 0 auto;
}

.ml-stat-card strong{
  display:block;
  font-size:1.1rem;
  margin-bottom:6px;
}

.ml-stat-card p{
  margin:0;
  line-height:1.55;
  color:#5d687b;
}

.ml-rating{
  position:absolute;
  z-index:1;
  background:rgba(255,255,255,.92);
  border:1px solid #e3e8ef;
  border-radius:20px;
  padding:16px 20px;
  box-shadow:var(--shadow);
  font-weight:800;
  color:#7c9080;
}
.ml-rating-a{left:55px;top:182px}
.ml-rating-b{left:400px;top:124px;color:#6d6cc4}
.ml-rating-c{right:140px;top:170px;color:#d49c43}
.ml-rating-d{right:120px;bottom:308px;color:#7c9b89}

.ml-hero-bg{
  position:absolute;
  z-index:0;
  opacity:.18;
  filter:grayscale(1);
  user-select:none;
  pointer-events:none;
}
.ml-hero-left{left:26px;top:250px;font-size:10rem}
.ml-hero-mid{left:150px;top:110px;font-size:10rem}
.ml-hero-right{right:48px;top:180px;font-size:10rem}
.ml-hero-camera{right:320px;bottom:210px;font-size:8rem}
.ml-hero-bottle{right:265px;top:105px;font-size:8rem}

.ml-section{
  padding:38px 0 12px;
}

.ml-eyebrow{
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  border-radius:999px;
  background:#edf1ff;
  color:#7284c4;
  font-size:.86rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.soft-blue{background:#eef1ff}
.warm{background:#f7edd8;color:#b7831e}
.green{background:#e4f2e8;color:#5a9a74}

.ml-section-title{
  margin:0 0 12px;
  font-size:2.45rem;
  line-height:1.06;
  letter-spacing:-0.04em;
  color:#1f304a;
  font-weight:800;
}
.ml-section-title.smaller{
  font-size:1.95rem;
  line-height:1.1;
}

.ml-section-copy{
  max-width:860px;
  margin:0 0 22px;
  color:#556174;
  line-height:1.65;
  font-size:1.02rem;
}
.ml-section-copy.compact{
  max-width:720px;
}

.ml-step-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.ml-step-card,
.ml-surface-card{
  background:#fff;
  border:1px solid #e4e8ef;
  border-radius:24px;
  box-shadow:var(--shadow);
}

.ml-step-card{
  padding:24px;
}

.ml-step-num{
  width:56px;
  height:56px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#8aa1ff,#6f86f6);
  color:#0f172a;
  font-weight:800;
  font-size:1.85rem;
  margin-bottom:18px;
}

.ml-step-card h3,
.ml-surface-card h3{
  margin:0 0 12px;
  font-size:1.15rem;
  color:#1f304a;
}
.ml-step-card p{
  margin:0;
  color:#718096;
  line-height:1.6;
}

.ml-two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.ml-surface-card{
  padding:28px;
}

.ml-list{
  margin:18px 0 0 18px;
  padding:0;
  color:#4b5563;
  line-height:1.7;
}

.ml-compare-head{
  display:flex;
  justify-content:space-between;
  margin-bottom:28px;
}

.ml-chip{
  display:inline-flex;
  padding:10px 16px;
  border-radius:999px;
  font-weight:800;
}

.ml-compare-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
}
.ml-compare-grid h3{
  font-size:1.3rem;
  margin-bottom:12px;
}
.ml-compare-grid p{
  color:#4b5563;
  line-height:1.6;
}

.ml-session-card{
  margin-bottom:20px;
}
.ml-session-head,
.ml-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
}
.ml-session-head p,
.ml-muted{
  color:#64748b;
  margin:6px 0 0;
}

.ml-session-user{
  margin-top:16px;
  padding:14px 16px;
  background:#f4f8f7;
  border:1px solid #e3e8ef;
  border-radius:16px;
  color:#334155;
}

.ml-auth-grid,
.ml-work-grid-top,
.ml-work-grid-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.ml-work-grid-main{margin-top:20px}

.ml-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-top:14px;
}
.ml-form-grid.four{
  grid-template-columns:2fr 1fr 1fr 1fr;
}
.ml-form-grid .full{
  grid-column:1/-1;
}

label{
  display:grid;
  gap:8px;
}
label span{
  font-size:.95rem;
  font-weight:700;
  color:#374151;
}

input,select,textarea{
  width:100%;
  border:1px solid #d6dce5;
  border-radius:14px;
  background:#fff;
  color:#111827;
  padding:14px 14px;
  font:inherit;
  outline:none;
}
input::placeholder,textarea::placeholder{color:#8994a8}
input:focus,select:focus,textarea:focus{
  border-color:#7a93fb;
  box-shadow:0 0 0 3px rgba(122,147,251,.14);
}

.ml-message{
  min-height:22px;
  margin:12px 0 0;
}

.ml-mini-list,
.ml-purchase-list{
  display:grid;
  gap:12px;
  margin-top:16px;
}

.ml-admin-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding:16px 18px;
  border:1px solid #e4e8ef;
  border-radius:18px;
  background:#fbfcfe;
}
.ml-admin-name{
  font-weight:800;
  color:#1f304a;
  margin-bottom:4px;
}
.ml-admin-domain{
  color:#64748b;
}
.ml-admin-actions{
  display:flex;
  align-items:center;
}
.ml-btn-danger{
  min-height:40px;
  padding:0 16px;
  border-radius:12px;
  background:#fff;
  border:1px solid #efc7c7;
  color:#b42318;
  font-weight:700;
}
.ml-btn-danger:hover{
  background:#fff5f5;
}

.ml-empty-state{
  margin-top:16px;
  padding:24px;
  background:#f8fafc;
  border:1px dashed #d8dee8;
  border-radius:18px;
  color:#556174;
}
.ml-empty-state strong{
  display:block;
  margin-bottom:8px;
  color:#374151;
}

.ml-purchase-item{
  border:1px solid #e4e8ef;
  border-radius:18px;
  background:#fbfcfe;
  padding:18px;
}
.ml-purchase-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:12px;
}
.ml-purchase-title{
  font-size:1.05rem;
  font-weight:800;
  color:#1f304a;
  margin-bottom:4px;
}
.ml-purchase-sub{
  color:#64748b;
  line-height:1.5;
}
.ml-purchase-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.ml-meta-chip{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid #e2e8f0;
  background:#fff;
  color:#475569;
  font-size:.92rem;
  font-weight:600;
}

.ml-status-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:.84rem;
  font-weight:800;
  white-space:nowrap;
}
.ml-status-locked{
  background:#fff4db;
  color:#9a6b00;
}
.ml-status-ready{
  background:#e8f7ee;
  color:#1f7a45;
}
.ml-status-reviewed{
  background:#e9eefc;
  color:#4562b0;
}

.ml-browse-toolbar{
  padding:20px;
}

.ml-product-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:18px;
}

.ml-product-card{
  padding:20px;
  border:1px solid #e4e8ef;
  border-radius:20px;
  background:#fff;
  box-shadow:var(--shadow);
}
.ml-product-card h3{
  margin:0 0 8px;
}
.ml-product-sub{
  color:#64748b;
  margin:0 0 12px;
}
.ml-product-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.ml-metric-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:16px;
}

.ml-footer{
  display:flex;
  justify-content:space-between;
  gap:20px;
  padding:34px 0 48px;
  color:#6b7280;
}

/* dark mode */
body.dark-mode{
  background:#071226;
  color:#e5e7eb;
}
body.dark-mode .ml-topbar{
  background:rgba(8,18,38,.94);
  border-bottom:1px solid rgba(148,163,184,.18);
}
body.dark-mode .ml-step-card,
body.dark-mode .ml-surface-card,
body.dark-mode .ml-stat-card,
body.dark-mode .ml-hero-card,
body.dark-mode .ml-product-card,
body.dark-mode .ml-purchase-item,
body.dark-mode .ml-admin-row{
  background:#0b1830;
  border-color:rgba(148,163,184,.16);
  box-shadow:0 8px 22px rgba(0,0,0,.24);
}
body.dark-mode .ml-brand-text,
body.dark-mode .ml-nav-links a,
body.dark-mode .ml-section-title,
body.dark-mode .ml-step-card h3,
body.dark-mode .ml-surface-card h3,
body.dark-mode .ml-stat-card strong,
body.dark-mode .ml-card-head h3,
body.dark-mode .ml-session-head h3,
body.dark-mode .ml-admin-name,
body.dark-mode .ml-purchase-title{
  color:#f8fafc;
}
body.dark-mode .ml-hero-copy,
body.dark-mode .ml-section-copy,
body.dark-mode .ml-step-card p,
body.dark-mode .ml-muted,
body.dark-mode .ml-stat-card p,
body.dark-mode .ml-empty-state,
body.dark-mode .ml-empty-state p,
body.dark-mode .ml-footer,
body.dark-mode .ml-message,
body.dark-mode .ml-compare-grid p,
body.dark-mode .ml-list,
body.dark-mode #sessionStatus,
body.dark-mode #productDetailMeta,
body.dark-mode .ml-admin-domain,
body.dark-mode .ml-purchase-sub,
body.dark-mode .ml-product-sub{
  color:#cbd5e1;
}
body.dark-mode label span{
  color:#e2e8f0;
}
body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea{
  background:#0f213f;
  color:#f8fafc;
  border:1px solid rgba(148,163,184,.24);
}
body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder{
  color:#94a3b8;
}
body.dark-mode .ml-pill,
body.dark-mode .ml-chip,
body.dark-mode .ml-btn-secondary,
body.dark-mode .ml-session-user,
body.dark-mode .ml-meta-chip{
  background:#10213d;
  color:#f8fafc;
  border:1px solid rgba(148,163,184,.22);
}
body.dark-mode .ml-btn-primary,
body.dark-mode .ml-btn-solid{
  background:linear-gradient(135deg,#7a92ff,#5f77ef);
  color:#fff;
  border:none;
}
body.dark-mode .ml-empty-state{
  background:#0f213f;
  border:1px dashed rgba(148,163,184,.22);
}
body.dark-mode .ml-empty-state strong{
  color:#f8fafc;
}
body.dark-mode .ml-tagline-row p{
  color:#a9b5c7;
}
body.dark-mode .ml-tagline-row span{
  background:rgba(148,163,184,.24);
}
body.dark-mode .ml-rating{
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.20);
}
body.dark-mode .ml-btn-danger{
  background:#10213d;
  border-color:#7f1d1d;
  color:#fecaca;
}
body.dark-mode .ml-btn-danger:hover{
  background:#16294a;
}
body.dark-mode .ml-theme-switch-track{
  background:#10213d;
  border-color:rgba(148,163,184,.24);
}
body.dark-mode .ml-theme-switch-thumb{
  left:4px;
  right:auto;
  background:#1d3358;
  border-color:#2f4a77;
}
body.dark-mode .ml-theme-switch-sun{opacity:1}
body.dark-mode .ml-theme-switch-moon{opacity:.4}
body.dark-mode .ml-theme-switch-label{color:#fff}
body.dark-mode .ml-status-locked{
  background:#4a3710;
  color:#f7d27d;
}
body.dark-mode .ml-status-ready{
  background:#123424;
  color:#82d7a3;
}
body.dark-mode .ml-status-reviewed{
  background:#1a284a;
  color:#9db6ff;
}

@media (max-width:1100px){
  .ml-stat-row,
  .ml-step-grid,
  .ml-two-col,
  .ml-auth-grid,
  .ml-work-grid-top,
  .ml-work-grid-main,
  .ml-product-grid,
  .ml-metric-grid{
    grid-template-columns:1fr;
  }

  .ml-form-grid.four{
    grid-template-columns:1fr 1fr;
  }

  .ml-logo-line{
    flex-direction:column;
    gap:14px;
  }

  .ml-logo-wordmark{
    font-size:4.8rem;
  }

  .ml-tagline-row span{
    display:none;
  }

  .ml-rating,
  .ml-hero-bg{
    display:none;
  }

  .ml-section-title{
    font-size:2.2rem;
  }

  .ml-section-title.smaller{
    font-size:1.75rem;
  }
}

@media (max-width:760px){
  .ml-shell{
    width:min(var(--shell), calc(100% - 24px));
  }

  .ml-nav{
    flex-direction:column;
    gap:14px;
    padding:14px 0;
  }

  .ml-nav-links{
    gap:18px;
    flex-wrap:wrap;
    justify-content:center;
  }

  .ml-hero-card{
    padding:34px 20px 26px;
    border-radius:24px;
  }

  .ml-form-grid,
  .ml-form-grid.four{
    grid-template-columns:1fr;
  }

  .ml-section-title{
    font-size:1.9rem;
  }

  .ml-section-title.smaller{
    font-size:1.55rem;
  }

  .ml-logo-mark{
    font-size:6rem;
  }

  .ml-logo-wordmark{
    font-size:3.2rem;
  }

  .ml-theme-switch-track{
    width:54px;
  }
}

/* collapsible workspace panels */
.ml-collapsible-card{
  padding-top:18px;
}

.ml-collapse-toggle{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  background:transparent;
  border:none;
  padding:0 0 14px;
  color:inherit;
  cursor:pointer;
  font:inherit;
}

.ml-collapse-toggle span:first-child{
  font-size:1.15rem;
  font-weight:800;
  color:#1f304a;
}

.ml-collapse-icon{
  width:30px;
  height:30px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:#eef2ff;
  color:#5f77ef;
  font-size:1.1rem;
  font-weight:800;
  flex:0 0 auto;
}

.ml-collapse-body{
  padding-top:8px;
}

.ml-collapse-body.hidden{
  display:none !important;
}

body.dark-mode .ml-collapse-toggle span:first-child{
  color:#f8fafc;
}

body.dark-mode .ml-collapse-icon{
  background:#10213d;
  color:#9db6ff;
  border:1px solid rgba(148,163,184,.22);
}


/* button readability + submit/disabled state fix */
.ml-btn,
.ml-btn-primary,
.ml-btn-secondary,
.ml-btn-solid,
.ml-btn-wide{
  color:#ffffff;
}

.ml-btn-secondary{
  color:#1f2937;
}

.ml-btn-solid{
  color:#ffffff !important;
}

.ml-btn:disabled,
.ml-btn[disabled],
button:disabled{
  opacity:1 !important;
  cursor:not-allowed;
}

.ml-btn-solid:disabled,
.ml-btn-primary:disabled{
  background:linear-gradient(135deg,#a5b5fb,#8ea2f8) !important;
  color:#ffffff !important;
  border:none !important;
  box-shadow:none !important;
}

.ml-btn-secondary:disabled{
  background:#eef2f7 !important;
  color:#64748b !important;
  border:1px solid #d7dee8 !important;
  box-shadow:none !important;
}

/* specifically protect auth buttons */
#loginForm .ml-btn,
#registerForm .ml-btn{
  color:#ffffff !important;
}

#loginForm .ml-btn.ml-btn-solid{
  background:linear-gradient(135deg,#8aa1ff,#6f86f6) !important;
  color:#ffffff !important;
}

#loginForm .ml-btn.ml-btn-solid:disabled{
  background:linear-gradient(135deg,#a5b5fb,#8ea2f8) !important;
  color:#ffffff !important;
}

body.dark-mode #loginForm .ml-btn.ml-btn-solid,
body.dark-mode #registerForm .ml-btn.ml-btn-primary{
  color:#ffffff !important;
}

body.dark-mode #loginForm .ml-btn.ml-btn-solid:disabled,
body.dark-mode #registerForm .ml-btn.ml-btn-primary:disabled{
  background:linear-gradient(135deg,#7d8fcf,#6a7dc1) !important;
  color:#f8fafc !important;
}


/* pass 7 review workflow */
.ml-purchase-actions{
  margin-top:14px;
}

.ml-review-panel{
  margin-top:16px;
  padding:18px;
  border:1px solid #e4e8ef;
  border-radius:18px;
  background:#f8fafc;
}

.ml-review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.ml-review-grid .full{
  grid-column:1/-1;
}

.ml-review-submit-row{
  margin-top:16px;
  display:flex;
  justify-content:flex-start;
}

.ml-review-metric-title{
  font-size:.95rem;
  font-weight:800;
  color:#374151;
  margin-bottom:10px;
}

.ml-review-metric-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

textarea{
  resize:vertical;
}

body.dark-mode .ml-review-panel{
  background:#0f213f;
  border-color:rgba(148,163,184,.18);
}

body.dark-mode .ml-review-metric-title{
  color:#e2e8f0;
}

@media (max-width:900px){
  .ml-review-grid,
  .ml-review-metric-grid{
    grid-template-columns:1fr;
  }
}


/* pass 8 */
.ml-review-admin-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.ml-review-custom-grid{
  display:grid;
  grid-template-columns:1fr 180px;
  gap:14px;
}

body.dark-mode .ml-review-admin-actions .ml-btn-danger{
  background:#10213d;
}

@media (max-width:900px){
  .ml-review-custom-grid{
    grid-template-columns:1fr;
  }
}


/* pass 8.1 bugfix */
.ml-purchase-item .ml-review-admin-actions{
  margin-top:14px;
}

.ml-purchase-item .ml-review-admin-actions .ml-btn-danger{
  min-height:40px;
}


/* pass 9.2 */
.ml-status-deleted{
  background:#f3e8ff;
  color:#7c3aed;
}

.ml-review-admin-actions .ml-btn{
  min-height:40px;
}

body.dark-mode .ml-status-deleted{
  background:#33214f;
  color:#c4b5fd;
}


/* pass 9.3 */
.ml-review-admin-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}

.ml-purchase-actions{
  margin-top:14px;
  margin-bottom:8px;
}


/* pass 10 */
.ml-toast-host{
  position:fixed;
  top:18px;
  right:18px;
  z-index:9999;
  display:flex;
  flex-direction:column;
  gap:10px;
  pointer-events:none;
}

.ml-toast{
  min-width:220px;
  max-width:360px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,0.08);
  background:#ffffff;
  color:#1f2937;
  box-shadow:0 18px 45px rgba(15,23,42,0.12);
  transform:translateY(-8px);
  opacity:0;
  transition:opacity .2s ease, transform .2s ease;
  font-size:14px;
  font-weight:600;
}

.ml-toast.show{
  opacity:1;
  transform:translateY(0);
}

.ml-toast-success{
  border-color:#ccebd9;
  background:#f3fbf6;
  color:#166534;
}

.ml-toast-error{
  border-color:#f3c7c0;
  background:#fff5f4;
  color:#b42318;
}

.ml-toast-info{
  border-color:#d9e2f5;
  background:#f7f9ff;
  color:#1d4ed8;
}

body.dark-mode .ml-toast{
  background:#0f1b3d;
  color:#eef4ff;
  border-color:rgba(255,255,255,0.08);
  box-shadow:0 20px 48px rgba(0,0,0,0.35);
}

body.dark-mode .ml-toast-success{
  background:#112b20;
  color:#c7f0d7;
}

body.dark-mode .ml-toast-error{
  background:#3a1717;
  color:#ffd1d1;
}

body.dark-mode .ml-toast-info{
  background:#132952;
  color:#d9e6ff;
}


/* pass 11 - public platform polish */
.ml-product-card{
  position:relative;
  overflow:hidden;
}

.ml-product-card::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:3px;
  background:linear-gradient(90deg,#7f95fa,#86ad93);
  opacity:.9;
}

.ml-product-card h3{
  font-size:1.12rem;
  line-height:1.25;
  margin:0 0 8px;
  color:#1f304a;
}

.ml-product-sub{
  font-size:.95rem;
  line-height:1.55;
}

.ml-product-meta{
  margin-top:12px;
}

.ml-meta-chip{
  font-weight:700;
}

.ml-review-stat-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:18px;
}

.ml-review-stat{
  padding:16px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fbfcfe;
}

.ml-review-stat strong{
  display:block;
  font-size:1.15rem;
  color:#1f304a;
  margin-bottom:4px;
}

.ml-review-stat span{
  color:#64748b;
  font-size:.92rem;
}

.ml-detail-hero{
  padding:24px;
  border:1px solid #e4e8ef;
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
  box-shadow:var(--shadow);
}

.ml-detail-title-row{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  flex-wrap:wrap;
}

.ml-detail-title-row h3{
  margin:0;
  font-size:1.45rem;
  color:#1f304a;
}

.ml-rating-big{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid #e5e7eb;
  font-weight:800;
  color:#1f304a;
}

.ml-rating-stars{
  color:#d49c43;
  letter-spacing:.04em;
}

.ml-metric-grid{
  margin-top:18px;
}

.ml-metric-grid .ml-product-card{
  padding:18px;
}

.ml-metric-grid .ml-product-card h3{
  font-size:1.3rem;
  margin-top:6px;
}

.ml-review-card{
  border:1px solid #e4e8ef;
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:20px;
}

.ml-review-card-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.ml-review-card-title{
  font-weight:800;
  color:#1f304a;
  font-size:1rem;
}

.ml-review-card-sub{
  color:#64748b;
  font-size:.93rem;
  margin-top:4px;
}

.ml-review-body{
  color:#334155;
  line-height:1.7;
  font-size:.98rem;
  margin-top:8px;
}

.ml-signal-hot{
  background:#fff1ec;
  color:#c2410c;
  border:1px solid #fed7c3;
}

.ml-signal-strong{
  background:#edf9f0;
  color:#166534;
  border:1px solid #cdebd5;
}

.ml-signal-mixed{
  background:#fff7e8;
  color:#a16207;
  border:1px solid #fde3a7;
}

.ml-signal-early{
  background:#eef3ff;
  color:#1d4ed8;
  border:1px solid #d7e3ff;
}

.ml-empty-state{
  background:linear-gradient(180deg,#fafcff 0%,#f7f9fc 100%);
}

body.dark-mode .ml-product-card::after{
  opacity:.75;
}

body.dark-mode .ml-product-card h3,
body.dark-mode .ml-review-card-title,
body.dark-mode .ml-review-stat strong,
body.dark-mode .ml-detail-title-row h3,
body.dark-mode .ml-rating-big{
  color:#f8fafc;
}

body.dark-mode .ml-review-stat,
body.dark-mode .ml-detail-hero,
body.dark-mode .ml-review-card{
  background:#0b1830;
  border-color:rgba(148,163,184,.16);
}

body.dark-mode .ml-review-body{
  color:#dbe6f5;
}

body.dark-mode .ml-rating-big{
  background:#10213d;
  border-color:rgba(148,163,184,.16);
}

body.dark-mode .ml-signal-hot{
  background:#422018;
  color:#fdba74;
  border-color:#7c2d12;
}

body.dark-mode .ml-signal-strong{
  background:#102d21;
  color:#86efac;
  border-color:#14532d;
}

body.dark-mode .ml-signal-mixed{
  background:#3c2b11;
  color:#fcd34d;
  border-color:#854d0e;
}

body.dark-mode .ml-signal-early{
  background:#132952;
  color:#bfdbfe;
  border-color:#1d4ed8;
}

@media (max-width:980px){
  .ml-review-stat-row{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:680px){
  .ml-review-stat-row{
    grid-template-columns:1fr;
  }
}


/* pass 12 - trust and discovery */
.ml-trust-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-bottom:26px;
}

.ml-trust-card{
  padding:22px;
}

.ml-trust-icon{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#eef3ff;
  font-size:1.35rem;
  margin-bottom:14px;
}

.ml-trust-card h3{
  margin:0 0 8px;
  font-size:1.05rem;
  color:#1f304a;
}

.ml-trust-card p{
  margin:0;
  color:#64748b;
  line-height:1.65;
}

.ml-section-head-row{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:16px;
  margin:18px 0 14px;
  flex-wrap:wrap;
}

.ml-subsection-title{
  margin:4px 0 0;
  font-size:1.2rem;
  color:#1f304a;
}

.ml-inline-link{
  color:#4f6ef7;
  font-weight:700;
  text-decoration:none;
}

.ml-inline-link:hover{
  text-decoration:underline;
}

body.dark-mode .ml-trust-icon{
  background:#10213d;
}

body.dark-mode .ml-trust-card h3,
body.dark-mode .ml-subsection-title{
  color:#f8fafc;
}

body.dark-mode .ml-trust-card p{
  color:#cbd5e1;
}

body.dark-mode .ml-inline-link{
  color:#9db6ff;
}

@media (max-width:980px){
  .ml-trust-grid{
    grid-template-columns:1fr;
  }
}


/* ===== PASS 11.5 DARK MODE HERO FIX ===== */

/* dark mode hero wordmark clarity fix */
body.dark-mode .ml-hero-wordmark,
body.dark-mode .ml-hero-brandmark,
body.dark-mode .ml-hero-bg-text,
body.dark-mode .ml-hero-logo-text {
  opacity: 0.18 !important;
  filter: none !important;
  text-shadow: none !important;
  transform: none !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: geometricPrecision;
  letter-spacing: -0.02em;
}

/* slightly tighten giant brand text in dark mode */
body.dark-mode .ml-hero-wordmark {
  font-size: clamp(4.5rem, 10vw, 8.5rem) !important;
  line-height: 0.95 !important;
}

/* improve readability */
body.dark-mode .ml-hero-title,
body.dark-mode .ml-section-title,
body.dark-mode .ml-subsection-title {
  color: #f8fafc !important;
  text-shadow: none !important;
}

body.dark-mode .ml-hero-copy,
body.dark-mode .ml-section-copy,
body.dark-mode .ml-product-sub,
body.dark-mode .ml-muted {
  color: #d7e3f4 !important;
}

/* crisp floating chips */
body.dark-mode .ml-floating-rating,
body.dark-mode .ml-rating-chip {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.22);
}


/* pass 13 - stars, hero cleanup, credibility */
.ml-stars{
  display:inline-flex;
  gap:2px;
  vertical-align:middle;
  align-items:center;
  line-height:1;
  font-size:.98rem;
}

.ml-stars .full{
  color:#f5b942;
}

.ml-stars .half{
  color:#f5b942;
  opacity:.52;
}

.ml-stars .empty{
  color:#cbd5e1;
}

.ml-rating-inline{
  display:inline-block;
  margin-left:8px;
  font-weight:800;
  color:#475569;
  vertical-align:middle;
}

.ml-rating-stars .ml-stars{
  font-size:1.02rem;
}

.ml-review-card-title .ml-stars{
  margin-right:8px;
}

.ml-product-meta .ml-stars{
  margin-right:6px;
}

.ml-review-stat strong{
  font-size:1.2rem;
}

.ml-review-stat span{
  letter-spacing:0;
}

.ml-detail-hero{
  position:relative;
}

.ml-detail-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:3px;
  background:linear-gradient(90deg,#7f95fa,#86ad93);
  border-bottom-left-radius:22px;
  border-bottom-right-radius:22px;
  opacity:.95;
}

.ml-meta-chip .ml-stars{
  margin-right:6px;
}

.ml-product-card .ml-rating-big{
  min-width:98px;
  justify-content:center;
}

.ml-review-card{
  transition:transform .18s ease, box-shadow .18s ease;
}

.ml-review-card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 42px rgba(15,23,42,0.11);
}

.ml-trust-card:hover,
.ml-product-card:hover{
  transform:translateY(-2px);
}

body.dark-mode .ml-stars .empty{
  color:#475569;
}

body.dark-mode .ml-rating-inline{
  color:#cbd5e1;
}

/* clean hero ghost text in dark mode */
body.dark-mode .ml-hero-wordmark,
body.dark-mode .ml-hero-brandmark,
body.dark-mode .ml-hero-bg-text,
body.dark-mode .ml-hero-logo-text{
  opacity:.14 !important;
  filter:none !important;
  text-shadow:none !important;
  transform:none !important;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:geometricPrecision;
  letter-spacing:-0.02em;
}

/* if the background text still exists, make it quieter */
body.dark-mode .ml-hero-wordmark{
  font-size:clamp(4.4rem, 9vw, 8.1rem) !important;
  line-height:.95 !important;
}

/* fully hide the oversized ghost mark if needed */
body.dark-mode .ml-hero-bg-text.is-oversized,
body.dark-mode .ml-hero-wordmark.is-oversized{
  display:none !important;
}

body.dark-mode .ml-floating-rating,
body.dark-mode .ml-rating-chip{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:0 10px 30px rgba(0,0,0,.22);
}

body.dark-mode .ml-review-card:hover{
  box-shadow:0 20px 42px rgba(0,0,0,0.32);
}


/* pass 13b - strongest dark hero cleanup */
body.dark-mode .ml-hero-bg-text,
body.dark-mode .ml-hero-wordmark{
  opacity:.10 !important;
}


/* ===== pass 13.1 actual hero selector fix ===== */

/* the real hero brand elements in this build */
body.dark-mode .ml-logo-mark{
  background:#10213d !important;
  color:#e5edff !important;
  box-shadow:none !important;
  border:1px solid rgba(157,182,255,.18) !important;
}

body.dark-mode .ml-logo-wordmark{
  opacity:.96 !important;
  text-shadow:none !important;
  filter:none !important;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:geometricPrecision;
}

/* tighten the large wordmark so it feels cleaner in dark mode */
body.dark-mode .ml-logo-wordmark{
  letter-spacing:-0.03em !important;
}

/* make hero copy crisper */
body.dark-mode .ml-tagline-row p,
body.dark-mode .ml-hero-copy{
  color:#dbe6f5 !important;
  text-shadow:none !important;
}

/* soften decorative background objects in dark mode */
body.dark-mode .ml-hero-bg{
  opacity:.18 !important;
  filter:none !important;
}

/* floating ratings stay crisp */
body.dark-mode .ml-rating{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:0 10px 28px rgba(0,0,0,.24) !important;
}

/* optional: tone down the hero card contrast a little */
body.dark-mode .ml-hero-card{
  background:linear-gradient(180deg,#0c1730 0%, #101d39 100%) !important;
}


/* ===== pass 13.1 actual hero selector fix ===== */

/* the real hero brand elements in this build */
body.dark-mode .ml-logo-mark{
  background:#10213d !important;
  color:#e5edff !important;
  box-shadow:none !important;
  border:1px solid rgba(157,182,255,.18) !important;
}

body.dark-mode .ml-logo-wordmark{
  opacity:.96 !important;
  text-shadow:none !important;
  filter:none !important;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:geometricPrecision;
}

/* tighten the large wordmark so it feels cleaner in dark mode */
body.dark-mode .ml-logo-wordmark{
  letter-spacing:-0.03em !important;
}

/* make hero copy crisper */
body.dark-mode .ml-tagline-row p,
body.dark-mode .ml-hero-copy{
  color:#dbe6f5 !important;
  text-shadow:none !important;
}

/* soften decorative background objects in dark mode */
body.dark-mode .ml-hero-bg{
  opacity:.18 !important;
  filter:none !important;
}

/* floating ratings stay crisp */
body.dark-mode .ml-rating{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:0 10px 28px rgba(0,0,0,.24) !important;
}

/* optional: tone down the hero card contrast a little */
body.dark-mode .ml-hero-card{
  background:linear-gradient(180deg,#0c1730 0%, #101d39 100%) !important;
}


/* review form turnstile */
.ml-turnstile-inline{
  margin: 14px 0 10px;
  min-height: 65px;
}


/* pass 13.5 helpful votes */
.ml-helpful-row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
  color:#64748b;
  font-size:.94rem;
}

.ml-helpful-btn{
  border:1px solid #e2e8f0;
  background:#fff;
  color:#1f304a;
  border-radius:999px;
  padding:8px 12px;
  font-weight:800;
  cursor:pointer;
}

.ml-helpful-btn:hover{
  background:#f8fafc;
  transform:translateY(-1px);
}

.ml-helpful-btn:disabled{
  opacity:.55;
  cursor:not-allowed;
  transform:none;
}

body.dark-mode .ml-helpful-row{
  color:#cbd5e1;
}

body.dark-mode .ml-helpful-btn{
  background:#10213d;
  color:#eef4ff;
  border-color:rgba(148,163,184,.2);
}

body.dark-mode .ml-helpful-btn:hover{
  background:#132952;
}


/* helpful vote active state */
.ml-helpful-btn.active{
  background:#edf9f0;
  border-color:#86d39b;
  color:#166534;
}

body.dark-mode .ml-helpful-btn.active{
  background:#123524;
  border-color:#22c55e;
  color:#bbf7d0;
}


/* pass 14 - signal scoring */
.ml-signal-steady{
  background:#eef6ff;
  color:#1d4ed8;
  border:1px solid #cfe3ff;
}

body.dark-mode .ml-signal-steady{
  background:#132952;
  color:#bfdbfe;
  border-color:#1d4ed8;
}


/* pass 15 - shareable product links */
button.ml-meta-chip{
  cursor:pointer;
  font:inherit;
}

button.ml-meta-chip:hover{
  transform:translateY(-1px);
}


.ml-copy-product-link {
  border: 1px dashed #6366f1;
  color: #6366f1;
  font-weight: 600;
}

.ml-copy-product-link:hover {
  background: rgba(99,102,241,0.08);
}


/* pass 15.1 - make product share action obvious */
.ml-copy-product-link {
  border: 1px dashed #6366f1 !important;
  color: #6366f1 !important;
  font-weight: 800 !important;
  background: rgba(99,102,241,0.06) !important;
}

.ml-copy-product-link:hover {
  background: rgba(99,102,241,0.12) !important;
}

body.dark-mode .ml-copy-product-link {
  border-color: #9db6ff !important;
  color: #dbe6ff !important;
  background: rgba(157,182,255,0.12) !important;
}


/* pass 17 - review follow-up timeline */
.ml-review-updates{
  margin-top:16px;
  padding-left:16px;
  border-left:3px solid #dbeafe;
}

.ml-review-updates-title{
  font-weight:900;
  color:#1f304a;
  margin-bottom:10px;
}

.ml-review-update-item{
  padding:12px 0;
}

.ml-followup-box{
  margin-top:14px;
  padding:14px;
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#f8fafc;
}

.ml-followup-box summary{
  cursor:pointer;
  font-weight:900;
  color:#1f304a;
}

.ml-followup-form{
  margin-top:12px;
}

.ml-followup-form textarea{
  width:100%;
  resize:vertical;
  margin-bottom:10px;
}

body.dark-mode .ml-review-updates{
  border-left-color:#1d4ed8;
}

body.dark-mode .ml-review-updates-title,
body.dark-mode .ml-followup-box summary{
  color:#f8fafc;
}

body.dark-mode .ml-followup-box{
  background:#10213d;
  border-color:rgba(148,163,184,.18);
}


/* pass 17 timeline rendering */
.ml-review-timeline{
  margin-top:16px;
  padding:4px 0 4px 0;
}

.ml-timeline-item{
  display:grid;
  grid-template-columns:34px 1fr;
  gap:12px;
  position:relative;
  padding:0 0 18px;
}

.ml-timeline-item:not(:last-child)::after{
  content:"";
  position:absolute;
  left:16px;
  top:32px;
  bottom:-2px;
  width:2px;
  background:linear-gradient(180deg,#c7d2fe,#dbeafe);
}

.ml-timeline-dot{
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#eef2ff;
  color:#4f46e5;
  border:1px solid #c7d2fe;
  font-weight:900;
  z-index:1;
}

.ml-timeline-initial .ml-timeline-dot{
  background:#ecfdf5;
  color:#047857;
  border-color:#bbf7d0;
}

.ml-timeline-content{
  background:#ffffff;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:14px 16px;
}

.ml-timeline-kicker{
  font-weight:900;
  color:#1f304a;
  margin-bottom:3px;
}

.ml-timeline-date{
  color:#64748b;
  font-size:.92rem;
  margin-bottom:8px;
}

.ml-timeline-text{
  color:#334155;
  line-height:1.55;
  white-space:pre-wrap;
}

body.dark-mode .ml-timeline-item:not(:last-child)::after{
  background:linear-gradient(180deg,#334155,#1d4ed8);
}

body.dark-mode .ml-timeline-dot{
  background:#172554;
  color:#dbeafe;
  border-color:#1d4ed8;
}

body.dark-mode .ml-timeline-initial .ml-timeline-dot{
  background:#064e3b;
  color:#bbf7d0;
  border-color:#047857;
}

body.dark-mode .ml-timeline-content{
  background:#0f1f3a;
  border-color:rgba(148,163,184,.2);
}

body.dark-mode .ml-timeline-kicker{
  color:#f8fafc;
}

body.dark-mode .ml-timeline-date{
  color:#cbd5e1;
}

body.dark-mode .ml-timeline-text{
  color:#e2e8f0;
}


/* pass 17.1 - follow-up moderation */
.ml-delete-review-update{
  margin-top:12px;
  padding:8px 12px;
  font-size:.9rem;
}


/* pass 21 - short share link */
.ml-copy-short-link {
  border: 1px dashed #0f766e !important;
  color: #0f766e !important;
  font-weight: 800 !important;
  background: rgba(15,118,110,0.06) !important;
}

.ml-copy-short-link:hover {
  background: rgba(15,118,110,0.12) !important;
}

body.dark-mode .ml-copy-short-link {
  border-color: #5eead4 !important;
  color: #ccfbf1 !important;
  background: rgba(45,212,191,0.12) !important;
}


/* pass 22 + 26 - credibility and buy-again prominence */
.ml-cred-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 12px;
}

.ml-cred-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid #dbeafe;
  background:#f8fafc;
  color:#334155;
  font-weight:800;
  font-size:.88rem;
}

.ml-buyagain-chip{
  background:#ecfdf5 !important;
  border-color:#bbf7d0 !important;
  color:#047857 !important;
}

.ml-no-buyagain-chip{
  background:#fff7ed !important;
  border-color:#fed7aa !important;
  color:#c2410c !important;
}

body.dark-mode .ml-cred-chip{
  background:#10213d;
  border-color:rgba(148,163,184,.22);
  color:#e2e8f0;
}

body.dark-mode .ml-buyagain-chip{
  background:#064e3b !important;
  border-color:#047857 !important;
  color:#bbf7d0 !important;
}

body.dark-mode .ml-no-buyagain-chip{
  background:#431407 !important;
  border-color:#9a3412 !important;
  color:#fed7aa !important;
}


/* pass 24 - review journey badge */
.ml-journey-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:8px 0 4px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid #c7d2fe;
  background:#eef2ff;
  color:#3730a3;
  font-weight:900;
  cursor:pointer;
}

.ml-journey-badge:hover{
  background:#e0e7ff;
  transform:translateY(-1px);
}

.ml-review-timeline.pulse{
  animation: mlTimelinePulse 1.2s ease;
}

@keyframes mlTimelinePulse{
  0%{ box-shadow:0 0 0 rgba(99,102,241,0); }
  30%{ box-shadow:0 0 0 6px rgba(99,102,241,.18); }
  100%{ box-shadow:0 0 0 rgba(99,102,241,0); }
}

body.dark-mode .ml-journey-badge{
  background:#172554;
  border-color:#1d4ed8;
  color:#dbeafe;
}

body.dark-mode .ml-journey-badge:hover{
  background:#1e3a8a;
}


/* pass 23 - credibility score */
.ml-credible-chip{
  background:#f5f3ff !important;
  border-color:#ddd6fe !important;
  color:#5b21b6 !important;
  font-weight:900 !important;
}

body.dark-mode .ml-credible-chip{
  background:#2e1065 !important;
  border-color:#7c3aed !important;
  color:#ddd6fe !important;
}


/* pass 25 - trust positioning */
.ml-trust-banner{
  width:100%;
  padding:14px 18px;
  margin-bottom:14px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  font-weight:900;
  text-align:center;
  border-radius:10px;
}

.ml-trust-inline{
  margin-bottom:10px;
  padding:8px 12px;
  border-radius:8px;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  font-size:.9rem;
  font-weight:800;
  color:#475569;
}

body.dark-mode .ml-trust-banner{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}

body.dark-mode .ml-trust-inline{
  background:#0f172a;
  border-color:#334155;
  color:#cbd5f5;
}


/* pass 27 - follow-up nudge */
.ml-followup-nudge{
  margin-top:10px;
  padding:10px 14px;
  border-radius:10px;
  background:#f0fdf4;
  border:1px solid #bbf7d0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:800;
  gap:10px;
}

.ml-followup-cta{
  padding:6px 12px;
  font-size:.85rem;
}

body.dark-mode .ml-followup-nudge{
  background:#052e16;
  border-color:#065f46;
  color:#bbf7d0;
}


/* pass 28 - anonymous read-mode */
.ml-anon-review-cta{
  margin-top:14px;
  padding:14px;
  border-radius:16px;
  border:1px solid #dbeafe;
  background:#f8fafc;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.ml-anon-review-cta div{
  display:flex;
  flex-direction:column;
  gap:3px;
}

.ml-anon-review-cta span{
  color:#64748b;
}

.ml-public-reader-note{
  margin-top:10px;
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:#eef2ff;
  border:1px solid #c7d2fe;
  color:#3730a3;
  font-weight:900;
}

body.dark-mode .ml-anon-review-cta{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-anon-review-cta span{
  color:#cbd5e1;
}

body.dark-mode .ml-public-reader-note{
  background:#172554;
  border-color:#1d4ed8;
  color:#dbeafe;
}


/* pass 30 - decision summary */
.ml-decision-summary{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:10px;
  margin-bottom:14px;
}

.ml-decision-item{
  padding:10px 12px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  font-weight:900;
  font-size:.95rem;
}

body.dark-mode .ml-decision-item{
  background:#0f172a;
  border-color:#334155;
  color:#e2e8f0;
}


/* pass 31 - timeline emphasis */

.ml-review-timeline{
  position:relative;
  padding-left:18px;
  border-left:2px solid #e2e8f0;
}

.ml-review-update{
  position:relative;
  margin-bottom:14px;
  padding-left:12px;
}

.ml-review-update::before{
  content:'';
  position:absolute;
  left:-10px;
  top:6px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#6366f1;
}

.ml-update-day{
  font-size:.8rem;
  font-weight:900;
  color:#6366f1;
  margin-bottom:4px;
}

.ml-review-update:last-child::before{
  background:#22c55e;
}

.ml-review-update:last-child{
  border-left:0;
}

body.dark-mode .ml-review-timeline{
  border-left-color:#334155;
}

body.dark-mode .ml-update-day{
  color:#818cf8;
}


/* pass 31.5 - retailer source chip */
.ml-retailer-chip{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-weight:900;
  color:#334155;
}

body.dark-mode .ml-retailer-chip{
  color:#e2e8f0;
}


/* pass 32 - deep-link highlight */
.ml-deeplink-highlight{
  animation: mlDeepLinkPulse 1.7s ease;
}

@keyframes mlDeepLinkPulse{
  0%{
    box-shadow:0 0 0 0 rgba(99,102,241,.0);
    outline:0 solid rgba(99,102,241,.0);
  }
  35%{
    box-shadow:0 0 0 8px rgba(99,102,241,.16);
    outline:2px solid rgba(99,102,241,.35);
  }
  100%{
    box-shadow:0 0 0 0 rgba(99,102,241,.0);
    outline:0 solid rgba(99,102,241,.0);
  }
}


/* pass 32.5 - copy review/update links */
.ml-copy-deeplink{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid #dbeafe;
  background:#f8fafc;
  color:#334155;
  border-radius:999px;
  padding:7px 11px;
  font-weight:900;
  cursor:pointer;
}

.ml-copy-deeplink:hover{
  background:#eef2ff;
  transform:translateY(-1px);
}

body.dark-mode .ml-copy-deeplink{
  background:#0f172a;
  border-color:#334155;
  color:#e2e8f0;
}

body.dark-mode .ml-copy-deeplink:hover{
  background:#172554;
}


/* pass 33 - deterministic pros/cons insights */
.ml-pros-cons{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:12px;
  margin:14px 0 16px;
}

.ml-pros,
.ml-cons,
.ml-pros-cons-empty{
  padding:14px;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:#f8fafc;
}

.ml-pros strong{
  color:#047857;
}

.ml-cons strong{
  color:#b42318;
}

.ml-pros ul,
.ml-cons ul{
  margin:10px 0 0;
  padding-left:20px;
}

.ml-pros li,
.ml-cons li{
  margin:6px 0;
  color:#334155;
}

.ml-pros p,
.ml-cons p,
.ml-pros-cons-empty p{
  margin:8px 0 0;
  color:#64748b;
}

body.dark-mode .ml-pros,
body.dark-mode .ml-cons,
body.dark-mode .ml-pros-cons-empty{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-pros li,
body.dark-mode .ml-cons li{
  color:#e2e8f0;
}

body.dark-mode .ml-pros p,
body.dark-mode .ml-cons p,
body.dark-mode .ml-pros-cons-empty p{
  color:#cbd5e1;
}


/* pass 35 - confidence meter */
.ml-confidence{
  margin:10px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}

.ml-confidence-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px;
  font-weight:900;
  color:#334155;
}

.ml-confidence-top strong{
  color:#4f46e5;
}

.ml-confidence-bar{
  height:10px;
  border-radius:999px;
  background:#e2e8f0;
  overflow:hidden;
}

.ml-confidence-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#6366f1,#22c55e);
  transition:width .35s ease;
}

body.dark-mode .ml-confidence{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-confidence-top{
  color:#e2e8f0;
}

body.dark-mode .ml-confidence-top strong{
  color:#c4b5fd;
}

body.dark-mode .ml-confidence-bar{
  background:#334155;
}


/* pass 38 - why this score */
.ml-confidence-breakdown{
  margin:10px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:#f8fafc;
}

.ml-confidence-breakdown summary{
  cursor:pointer;
  font-weight:900;
  color:#4f46e5;
  margin-bottom:8px;
}

.ml-cb-row{
  display:grid;
  grid-template-columns:170px 1fr 48px;
  align-items:center;
  gap:10px;
  margin:8px 0;
  font-size:.9rem;
}

.ml-cb-bar{
  height:8px;
  border-radius:999px;
  background:#e2e8f0;
  overflow:hidden;
}

.ml-cb-bar div{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#6366f1,#22c55e);
}

.ml-cb-row strong{
  text-align:right;
}

body.dark-mode .ml-confidence-breakdown{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-confidence-breakdown summary{
  color:#c4b5fd;
}

body.dark-mode .ml-cb-bar{
  background:#334155;
}


/* pass 39 - missing confidence signals */
.ml-missing-signals{
  margin:10px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #fde68a;
  background:#fffbeb;
  color:#78350f;
}

.ml-missing-signals strong{
  display:block;
  margin-bottom:6px;
  font-weight:900;
}

.ml-missing-signals ul{
  margin:6px 0 0;
  padding-left:20px;
}

.ml-missing-signals li{
  margin:4px 0;
}

.ml-missing-signals.strong{
  border-color:#bbf7d0;
  background:#f0fdf4;
  color:#14532d;
}

.ml-missing-signals.strong span{
  display:block;
  color:#166534;
}

body.dark-mode .ml-missing-signals{
  background:#422006;
  border-color:#92400e;
  color:#fde68a;
}

body.dark-mode .ml-missing-signals.strong{
  background:#052e16;
  border-color:#166534;
  color:#bbf7d0;
}

body.dark-mode .ml-missing-signals.strong span{
  color:#dcfce7;
}


/* pass 41 - missing signal CTAs */
.ml-missing-signals li{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.ml-missing-signals li em{
  font-style:normal;
  opacity:.75;
}

.ml-missing-action,
.ml-missing-action-link{
  display:inline-flex;
  align-items:center;
  border:1px solid #fcd34d;
  background:#fff7ed;
  color:#92400e;
  border-radius:999px;
  padding:5px 10px;
  font-size:.82rem;
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
}

.ml-missing-action:hover,
.ml-missing-action-link:hover{
  background:#ffedd5;
}

body.dark-mode .ml-missing-action,
body.dark-mode .ml-missing-action-link{
  background:#431407;
  border-color:#92400e;
  color:#fde68a;
}

body.dark-mode .ml-missing-action:hover,
body.dark-mode .ml-missing-action-link:hover{
  background:#713f12;
}


/* pass 42 - prioritized missing signal rows */
.ml-missing-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.ml-missing-row span{
  flex:1;
}

.ml-missing-row.primary{
  font-weight:900;
}

.ml-missing-row.primary::marker{
  content:'★ ';
}


/* pass 43 - signal momentum */
.ml-signal-momentum{
  margin:10px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:#f8fafc;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.ml-signal-momentum strong{
  font-weight:900;
}

.ml-signal-momentum span{
  color:#64748b;
}

.ml-signal-momentum.up{
  border-color:#bbf7d0;
  background:#f0fdf4;
  color:#14532d;
}

.ml-signal-momentum.up span{
  color:#166534;
}

.ml-signal-momentum.down{
  border-color:#fecaca;
  background:#fef2f2;
  color:#991b1b;
}

.ml-signal-momentum.down span{
  color:#b91c1c;
}

.ml-signal-momentum.stable,
.ml-signal-momentum.forming{
  border-color:#dbeafe;
  background:#eff6ff;
  color:#1e3a8a;
}

body.dark-mode .ml-signal-momentum{
  background:#0f172a;
  border-color:#334155;
}


/* pass 44 - confidence history */
.ml-confidence-history{
  margin:10px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1e3a8a;
}

.ml-confidence-history-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
  font-weight:900;
}

.ml-confidence-history svg{
  width:100%;
  max-width:280px;
  height:58px;
  display:block;
  color:#4f46e5;
}

.ml-confidence-history circle{
  fill:#ffffff;
  stroke:#4f46e5;
  stroke-width:3;
}

.ml-confidence-history-note{
  margin-top:6px;
  font-size:.86rem;
  color:#475569;
}

body.dark-mode .ml-confidence-history{
  background:#0f172a;
  border-color:#334155;
  color:#c4b5fd;
}

body.dark-mode .ml-confidence-history-note{
  color:#cbd5e1;
}

body.dark-mode .ml-confidence-history circle{
  fill:#0f172a;
}


/* footer */
.ml-footer{
  margin-top:40px;
  border-top:1px solid #e5e7eb;
  background:#ffffff;
}

.ml-footer-inner{
  max-width:1100px;
  margin:0 auto;
  padding:18px 16px;
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  justify-content:space-between;
  align-items:center;
  font-size:.9rem;
}

.ml-footer-left{
  display:flex;
  gap:10px;
  align-items:center;
  font-weight:600;
  color:#111827;
}

.ml-footer-left span{
  font-weight:400;
  color:#6b7280;
}

.ml-footer-links{
  display:flex;
  gap:16px;
}

.ml-footer-links a{
  color:#4f46e5;
  text-decoration:none;
  font-weight:500;
}

.ml-footer-links a:hover{
  text-decoration:underline;
}

.ml-footer-meta{
  color:#6b7280;
}

body.dark-mode .ml-footer{
  background:#020617;
  border-color:#1e293b;
}

body.dark-mode .ml-footer-left{
  color:#e5e7eb;
}

body.dark-mode .ml-footer-left span,
body.dark-mode .ml-footer-meta{
  color:#94a3b8;
}


/* pass 46 - trust amplification */
.ml-trust-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 14px;
}

.ml-trust-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:6px 10px;
  border-radius:999px;
  font-size:.84rem;
  font-weight:900;
  border:1px solid #e2e8f0;
  background:#f8fafc;
  color:#334155;
}

.ml-trust-badge.verified{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#047857;
}

.ml-trust-badge.delayed{
  background:#eef2ff;
  border-color:#c7d2fe;
  color:#3730a3;
}

.ml-trust-badge.evidence{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#9a3412;
}

.ml-trust-context{
  margin:-6px 0 14px;
  font-size:.88rem;
  font-weight:800;
  color:#64748b;
}

body.dark-mode .ml-trust-badge{
  background:#0f172a;
  border-color:#334155;
  color:#e2e8f0;
}

body.dark-mode .ml-trust-badge.verified{
  background:#052e16;
  border-color:#166534;
  color:#bbf7d0;
}

body.dark-mode .ml-trust-badge.delayed{
  background:#172554;
  border-color:#1d4ed8;
  color:#dbeafe;
}

body.dark-mode .ml-trust-badge.evidence{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}

body.dark-mode .ml-trust-context{
  color:#cbd5e1;
}


/* pass 47 - member contact panel */
.ml-contact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:14px;
}

.ml-contact-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:16px;
  border-radius:16px;
  border:1px solid #e2e8f0;
  background:#f8fafc;
  color:#334155;
  text-decoration:none;
}

.ml-contact-card strong{
  font-size:1rem;
  color:#111827;
}

.ml-contact-card span{
  color:#64748b;
  line-height:1.4;
}

.ml-contact-card em{
  font-style:normal;
  font-weight:900;
  color:#4f46e5;
}

.ml-contact-card:hover{
  background:#eef2ff;
  transform:translateY(-1px);
}

body.dark-mode .ml-contact-card{
  background:#0f172a;
  border-color:#334155;
  color:#e2e8f0;
}

body.dark-mode .ml-contact-card strong{
  color:#f8fafc;
}

body.dark-mode .ml-contact-card span{
  color:#cbd5e1;
}


/* contact section width refinement */
#contact{
  max-width:1100px;
  margin-left:auto;
  margin-right:auto;
}

#contact .ml-contact-grid{
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}


/* Pass 46.1 — tighten contact-to-footer spacing */
#contact {
  padding-bottom: 24px;
  margin-bottom: 0;
}

/* ensure footer doesn’t add extra top gap */
.ml-footer {
  margin-top: 8px;
}


/* pass 48 - admin user filters */
.ml-admin-user-toolbar{
  display:grid;
  grid-template-columns:auto minmax(220px,1fr) minmax(160px,220px);
  gap:10px;
  align-items:center;
  margin:14px 0;
}

.ml-admin-badges{
  display:flex;
  gap:6px;
  margin-top:8px;
  flex-wrap:wrap;
}

.ml-admin-badge{
  display:inline-flex;
  padding:4px 8px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:900;
  border:1px solid #e2e8f0;
}

.ml-admin-badge.active{
  background:#ecfdf5;
  color:#047857;
  border-color:#bbf7d0;
}

.ml-admin-badge.disabled{
  background:#fef2f2;
  color:#b91c1c;
  border-color:#fecaca;
}

.ml-admin-badge.admin{
  background:#eef2ff;
  color:#3730a3;
  border-color:#c7d2fe;
}

.ml-admin-badge.user{
  background:#f8fafc;
  color:#334155;
}

@media (max-width: 760px){
  .ml-admin-user-toolbar{
    grid-template-columns:1fr;
  }
}


.ml-review-images{
  display:flex;
  gap:10px;
  margin-top:10px;
  flex-wrap:wrap;
}

.ml-review-image{
  position:relative;
}

.ml-review-image img{
  width:120px;
  height:120px;
  object-fit:cover;
  border-radius:10px;
  border:1px solid #e2e8f0;
}

.ml-img-delete{
  position:absolute;
  top:4px;
  right:4px;
  background:#dc2626;
  color:#fff;
  border:none;
  border-radius:50%;
  width:22px;
  height:22px;
  cursor:pointer;
}


/* pass 49D - image preview modal */
.ml-img-preview-btn{
  border:0;
  padding:0;
  background:transparent;
  cursor:zoom-in;
}

.ml-image-modal.hidden{
  display:none;
}

.ml-image-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.ml-image-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(4px);
}

.ml-image-modal-inner{
  position:relative;
  z-index:1;
  max-width:min(96vw,1100px);
  max-height:92vh;
  display:flex;
  align-items:center;
  justify-content:center;
}

.ml-image-modal-inner img{
  max-width:100%;
  max-height:92vh;
  border-radius:18px;
  background:#fff;
  box-shadow:0 24px 70px rgba(0,0,0,.35);
}

.ml-image-modal-close{
  position:absolute;
  top:-16px;
  right:-16px;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid #e5e7eb;
  background:#fff;
  color:#111827;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
  z-index:2;
}


/* pass 49D fix - keep image delete above preview button */
.ml-review-image{
  position:relative;
}

.ml-img-delete{
  z-index:5;
}

.ml-img-preview-btn{
  display:block;
}


/* pass 50 - review image UX polish */
.ml-review-images{
  align-items:flex-start;
}

.ml-review-image{
  border-radius:14px;
}

.ml-img-preview-btn{
  position:relative;
  overflow:hidden;
  border-radius:14px;
}

.ml-img-preview-btn img{
  transition:transform .16s ease, filter .16s ease;
}

.ml-img-preview-btn:hover img{
  transform:scale(1.04);
  filter:brightness(.92);
}

.ml-img-view-hint{
  position:absolute;
  left:8px;
  bottom:8px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(15,23,42,.72);
  color:#fff;
  font-size:.72rem;
  font-weight:900;
  opacity:0;
  transform:translateY(3px);
  transition:opacity .16s ease, transform .16s ease;
}

.ml-img-preview-btn:hover .ml-img-view-hint{
  opacity:1;
  transform:translateY(0);
}

.ml-img-size{
  position:absolute;
  left:8px;
  top:8px;
  padding:3px 7px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:#334155;
  font-size:.7rem;
  font-weight:900;
  border:1px solid rgba(226,232,240,.9);
}

.ml-img-delete{
  box-shadow:0 6px 14px rgba(220,38,38,.25);
}

body.dark-mode .ml-img-size{
  background:rgba(15,23,42,.92);
  color:#e2e8f0;
  border-color:#334155;
}


/* pass 51 - review credibility badges */
.ml-review-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 12px;
}

.ml-review-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:5px 9px;
  border-radius:999px;
  font-size:.8rem;
  font-weight:900;
  border:1px solid #e2e8f0;
  background:#f8fafc;
  color:#334155;
}

.ml-review-badge.verified{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#047857;
}

.ml-review-badge.time{
  background:#eef2ff;
  border-color:#c7d2fe;
  color:#3730a3;
}

.ml-review-badge.updates{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#1d4ed8;
}

.ml-review-badge.photos{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#9a3412;
}

.ml-review-badge.buyagain{
  background:#f0fdf4;
  border-color:#bbf7d0;
  color:#166534;
}

.ml-review-badge.nobuy{
  background:#fef2f2;
  border-color:#fecaca;
  color:#991b1b;
}

body.dark-mode .ml-review-badge{
  background:#0f172a;
  border-color:#334155;
  color:#e2e8f0;
}

body.dark-mode .ml-review-badge.verified,
body.dark-mode .ml-review-badge.buyagain{
  background:#052e16;
  border-color:#166534;
  color:#bbf7d0;
}

body.dark-mode .ml-review-badge.time,
body.dark-mode .ml-review-badge.updates{
  background:#172554;
  border-color:#1d4ed8;
  color:#dbeafe;
}

body.dark-mode .ml-review-badge.photos{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}

body.dark-mode .ml-review-badge.nobuy{
  background:#450a0a;
  border-color:#991b1b;
  color:#fecaca;
}


/* pass 53 - product visual proof badge */
.ml-product-proof{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:10px;
  flex-wrap:wrap;
}

.ml-product-proof-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  font-size:.82rem;
  font-weight:900;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
}

.ml-product-proof-meta{
  font-size:.8rem;
  color:#475569;
  font-weight:600;
}

body.dark-mode .ml-product-proof-badge{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}

body.dark-mode .ml-product-proof-meta{
  color:#cbd5f5;
}


/* pass 54 - per-review image indicator */
.ml-review-img-indicator{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-left:8px;
  padding:2px 6px;
  border-radius:999px;
  font-size:.72rem;
  font-weight:900;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  vertical-align:middle;
}

body.dark-mode .ml-review-img-indicator{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}


/* pass 55B - recovery codes */
.ml-recovery-codes-panel{
  margin-top:14px;
  padding:16px;
  border-radius:18px;
  border:1px solid #fed7aa;
  background:#fff7ed;
  color:#7c2d12;
}

.ml-recovery-codes-head{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:12px;
}

.ml-recovery-codes-head strong{
  font-size:1rem;
  color:#7c2d12;
}

.ml-recovery-codes-head span,
.ml-warning-text{
  color:#9a3412;
  line-height:1.4;
}

.ml-recovery-codes-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:8px;
  margin:12px 0;
}

.ml-recovery-codes-list code{
  display:block;
  padding:10px;
  border-radius:12px;
  background:#fff;
  border:1px solid #fed7aa;
  color:#111827;
  font-weight:900;
  letter-spacing:.04em;
}

.ml-warning-text{
  margin-top:10px;
  font-size:.9rem;
  font-weight:700;
}

body.dark-mode .ml-recovery-codes-panel{
  background:#431407;
  border-color:#9a3412;
  color:#fed7aa;
}

body.dark-mode .ml-recovery-codes-head strong,
body.dark-mode .ml-recovery-codes-head span,
body.dark-mode .ml-warning-text{
  color:#fed7aa;
}

body.dark-mode .ml-recovery-codes-list code{
  background:#0f172a;
  border-color:#9a3412;
  color:#f8fafc;
}


/* pass 55C polish - reset password UX */
.ml-auth-helper{
  margin-top:10px;
  font-weight:800;
}

.ml-auth-helper a{
  color:#4f46e5;
  text-decoration:none;
}

.ml-auth-helper a:hover{
  text-decoration:underline;
}

#recoveryResetForm{
  opacity:.96;
}

#reset-password{
  scroll-margin-top:110px;
}

.ml-hint{
  display:block;
  margin-top:6px;
  color:#64748b;
  font-size:.82rem;
  line-height:1.35;
}

body.dark-mode .ml-hint{
  color:#cbd5e1;
}


/* pass 56 - recovery code manager */
#recoveryCodeManagerCard{
  margin-bottom:18px;
}

#recoveryCodeManagerOutput{
  margin-top:14px;
}

#downloadRecoveryCodesBtn{
  margin-top:10px;
}


/* pass 56 fix - recovery manager + disabled button polish */
#recoveryCodeManagerCard{
  margin-bottom:18px;
}

#recoveryCodeManagerOutput{
  margin-top:14px;
}

#downloadRecoveryCodesBtn{
  margin-top:10px;
}

.ml-btn:disabled,
.ml-btn[disabled]{
  opacity:.55;
  cursor:not-allowed;
  filter:none;
  box-shadow:none;
}

.ml-btn:disabled:hover,
.ml-btn[disabled]:hover{
  transform:none;
  background:inherit;
  color:inherit;
}

.ml-btn-primary:disabled,
.ml-btn-primary[disabled],
.ml-btn-primary:disabled:hover,
.ml-btn-primary[disabled]:hover{
  background:#7c8df8;
  color:#fff;
}

.ml-btn-secondary:disabled,
.ml-btn-secondary[disabled],
.ml-btn-secondary:disabled:hover,
.ml-btn-secondary[disabled]:hover{
  background:#f8fafc;
  color:#64748b;
}


/* pass 57 - ownership signals */
.ml-review-signals{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:6px;
}

.ml-review-signal{
  font-size:.75rem;
  font-weight:800;
  padding:4px 8px;
  border-radius:999px;
  background:#eef2ff;
  color:#3730a3;
}

.ml-review-signal.strong{
  background:#dcfce7;
  color:#166534;
}

.ml-review-signal.weak{
  background:#fef3c7;
  color:#92400e;
}

body.dark-mode .ml-review-signal{
  background:#1e293b;
  color:#c7d2fe;
}

body.dark-mode .ml-review-signal.strong{
  background:#064e3b;
  color:#6ee7b7;
}

body.dark-mode .ml-review-signal.weak{
  background:#451a03;
  color:#fcd34d;
}


/* pass 58 - review sorting and filters */
.ml-review-controls{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:end;
  margin:18px 0;
  padding:14px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#f8fafc;
}

.ml-review-controls label{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:190px;
  font-weight:800;
  color:#334155;
}

.ml-review-controls span{
  font-size:.85rem;
}

body.dark-mode .ml-review-controls{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-review-controls label{
  color:#e2e8f0;
}


/* pass 59 - top credibility review */
.ml-top-review-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:12px;
  padding:7px 11px;
  border-radius:999px;
  background:#fef3c7;
  border:1px solid #fde68a;
  color:#92400e;
  font-size:.82rem;
  font-weight:900;
}

body.dark-mode .ml-top-review-badge{
  background:#451a03;
  border-color:#92400e;
  color:#fcd34d;
}


/* pass 60 - image gallery modal polish */
.ml-image-preview-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(15,23,42,.82);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
}

.ml-image-preview-modal.hidden{
  display:none;
}

.ml-image-preview-frame{
  max-width:min(92vw,1100px);
  max-height:88vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.ml-image-preview-frame img{
  max-width:100%;
  max-height:78vh;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 24px 80px rgba(0,0,0,.35);
  background:#fff;
}

.ml-image-preview-caption{
  color:#fff;
  font-weight:900;
  font-size:.95rem;
}

.ml-image-preview-close,
.ml-image-preview-nav{
  border:none;
  cursor:pointer;
  color:#fff;
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(8px);
}

.ml-image-preview-close{
  position:absolute;
  top:18px;
  right:22px;
  width:44px;
  height:44px;
  border-radius:999px;
  font-size:2rem;
  line-height:1;
}

.ml-image-preview-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border-radius:999px;
  font-size:2.4rem;
  display:flex;
  align-items:center;
  justify-content:center;
}

.ml-image-preview-nav.prev{
  left:24px;
}

.ml-image-preview-nav.next{
  right:24px;
}

.ml-image-preview-close:hover,
.ml-image-preview-nav:hover{
  background:rgba(255,255,255,.24);
}

@media (max-width: 720px){
  .ml-image-preview-modal{
    padding:18px;
  }

  .ml-image-preview-nav{
    width:42px;
    height:42px;
    font-size:2rem;
  }

  .ml-image-preview-nav.prev{
    left:10px;
  }

  .ml-image-preview-nav.next{
    right:10px;
  }
}


/* pass 61 - upload UX */
.ml-upload-box{
  margin-top:10px;
}

.ml-upload-dropzone{
  border:2px dashed #cbd5f5;
  padding:18px;
  border-radius:14px;
  text-align:center;
  cursor:pointer;
  background:#f8fafc;
}

.ml-upload-dropzone.dragover{
  background:#eef2ff;
  border-color:#6366f1;
}

.ml-upload-preview{
  display:flex;
  gap:10px;
  margin-top:10px;
}

.ml-upload-thumb{
  position:relative;
  width:90px;
  height:90px;
}

.ml-upload-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:10px;
}

.ml-upload-remove{
  position:absolute;
  top:-6px;
  right:-6px;
  background:#ef4444;
  color:#fff;
  border:none;
  border-radius:999px;
  width:22px;
  height:22px;
  cursor:pointer;
  font-size:14px;
}

body.dark-mode .ml-upload-dropzone{
  background:#0f172a;
  border-color:#475569;
}


/* pass 61 final polish - review submit layout */
.ml-review-submit-row{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:stretch;
}

.ml-review-submit-row .ml-btn{
  width:100%;
}

.ml-turnstile-inline{
  align-self:flex-start;
}

@media (max-width: 720px){
  .ml-turnstile-inline{
    max-width:100%;
    overflow:hidden;
  }
}


/* pass 64 - upload feedback */
.ml-upload-status{
  margin-top:8px;
  font-size:.88rem;
  font-weight:800;
  color:#166534;
}

.ml-upload-status.error{
  color:#b91c1c;
}

.ml-upload-thumb{
  width:112px;
  height:112px;
}

.ml-upload-size{
  position:absolute;
  left:6px;
  bottom:6px;
  max-width:calc(100% - 12px);
  padding:3px 6px;
  border-radius:999px;
  background:rgba(15,23,42,.78);
  color:#fff;
  font-size:.68rem;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

body.dark-mode .ml-upload-status{
  color:#86efac;
}

body.dark-mode .ml-upload-status.error{
  color:#fca5a5;
}


/* pass 66 - ownership timeline emphasis */
.ml-review-timeline-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  margin:14px 0 8px;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}

.ml-review-timeline-head strong{
  color:#111827;
  font-weight:900;
}

.ml-review-timeline-head span{
  color:#64748b;
  font-size:.86rem;
  font-weight:800;
}

.ml-review-timeline-head.active{
  background:#ecfdf5;
  border-color:#bbf7d0;
}

.ml-review-timeline-head.active span{
  color:#047857;
}

body.dark-mode .ml-review-timeline-head{
  background:#0f172a;
  border-color:#334155;
}

body.dark-mode .ml-review-timeline-head strong{
  color:#f8fafc;
}

body.dark-mode .ml-review-timeline-head span{
  color:#cbd5e1;
}

body.dark-mode .ml-review-timeline-head.active{
  background:#052e16;
  border-color:#166534;
}

body.dark-mode .ml-review-timeline-head.active span{
  color:#bbf7d0;
}


/* pass 67 - timeline toggle */
.ml-timeline-toggle{
  margin-top:6px;
  background:none;
  border:none;
  color:#4f46e5;
  font-weight:900;
  cursor:pointer;
  font-size:.85rem;
}

.ml-timeline-body.collapsed{
  display:none;
}


/* pass 68 - visual timeline polish */
.ml-timeline-toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#eef2ff;
  color:#4f46e5;
}

.ml-timeline-toggle::before{
  content:"▸";
  font-size:.8rem;
}

.ml-timeline-toggle:not(:has(+ .collapsed))::before{
  content:"▾";
}

.ml-timeline-body{
  margin-top:12px;
  padding-left:22px;
  border-left:2px solid #dbeafe;
  animation:mlTimelineFade .18s ease-out;
}

.ml-timeline-body.collapsed{
  display:none;
}

.ml-timeline-body .ml-update-card,
.ml-timeline-body .ml-review-update,
.ml-timeline-body article{
  position:relative;
}

.ml-timeline-body .ml-update-card::before,
.ml-timeline-body .ml-review-update::before,
.ml-timeline-body article::before{
  content:"";
  position:absolute;
  left:-30px;
  top:18px;
  width:12px;
  height:12px;
  border-radius:999px;
  background:#6366f1;
  box-shadow:0 0 0 4px #eef2ff;
}

@keyframes mlTimelineFade{
  from{ opacity:0; transform:translateY(-4px); }
  to{ opacity:1; transform:translateY(0); }
}

body.dark-mode .ml-timeline-toggle{
  background:#1e1b4b;
  color:#c7d2fe;
}

body.dark-mode .ml-timeline-body{
  border-left-color:#334155;
}

body.dark-mode .ml-timeline-body .ml-update-card::before,
body.dark-mode .ml-timeline-body .ml-review-update::before,
body.dark-mode .ml-timeline-body article::before{
  background:#818cf8;
  box-shadow:0 0 0 4px #1e1b4b;
}


/* pass 68 tweak - deterministic timeline arrow */
.ml-timeline-toggle::before{
  content:"▸";
}

.ml-timeline-toggle.expanded::before{
  content:"▾";
}


/* pass 70 - motion + interaction polish */

.ml-review-card,
.ml-purchase-item,
.ml-surface-card{
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background-color .18s ease;
}

.ml-review-card:hover,
.ml-purchase-item:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(15,23,42,.08);
}

.ml-btn{
  transition:
    transform .12s ease,
    box-shadow .15s ease,
    opacity .15s ease;
}

.ml-btn:hover{
  transform:translateY(-1px);
}

.ml-btn:active{
  transform:translateY(1px) scale(.99);
}

.ml-top-review-badge{
  animation:mlTopReviewGlow 2.8s ease-in-out infinite;
}

@keyframes mlTopReviewGlow{
  0%,100%{
    box-shadow:0 0 0 rgba(251,191,36,0);
  }
  50%{
    box-shadow:0 0 18px rgba(251,191,36,.18);
  }
}

.ml-upload-thumb{
  animation:mlThumbIn .18s ease-out;
}

@keyframes mlThumbIn{
  from{
    opacity:0;
    transform:scale(.92);
  }
  to{
    opacity:1;
    transform:scale(1);
  }
}

.ml-timeline-body{
  overflow:hidden;
  transform-origin:top;
}

.ml-timeline-body:not(.collapsed){
  animation:mlTimelineExpand .18s ease-out;
}

@keyframes mlTimelineExpand{
  from{
    opacity:0;
    transform:translateY(-6px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.ml-cred-chip,
.ml-meta-chip,
.ml-review-signal{
  transition:
    background-color .15s ease,
    color .15s ease,
    transform .12s ease;
}

.ml-cred-chip:hover,
.ml-meta-chip:hover,
.ml-review-signal:hover{
  transform:translateY(-1px);
}

.ml-review-images img{
  transition:
    transform .18s ease,
    box-shadow .18s ease;
}

.ml-review-images img:hover{
  transform:scale(1.03);
  box-shadow:0 8px 20px rgba(15,23,42,.16);
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}


/* pass 71 - product comparison */
.ml-compare-product-btn{
  border:1px solid #c7d2fe;
  background:#eef2ff;
  color:#3730a3;
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
  cursor:pointer;
}

.ml-compare-product-btn.selected{
  background:#3730a3;
  color:#fff;
}

.ml-compare-tray{
  position:fixed;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  z-index:5000;
  width:min(920px,calc(100vw - 28px));
}

.ml-compare-tray.hidden{
  display:none;
}

.ml-compare-tray-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border-radius:20px;
  background:#111827;
  color:#fff;
  box-shadow:0 18px 50px rgba(15,23,42,.25);
}

.ml-compare-tray-inner span{
  flex:1;
  color:#cbd5e1;
  font-weight:700;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.ml-compare-actions{
  display:flex;
  gap:8px;
}

.ml-compare-modal.hidden{
  display:none;
}

.ml-compare-modal{
  position:fixed;
  inset:0;
  z-index:9999;
}

.ml-compare-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.72);
}

.ml-compare-panel{
  position:relative;
  z-index:1;
  width:min(980px,calc(100vw - 32px));
  max-height:86vh;
  overflow:auto;
  margin:7vh auto;
  border-radius:24px;
  background:#fff;
  box-shadow:0 24px 80px rgba(0,0,0,.35);
}

.ml-compare-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:18px 20px;
  border-bottom:1px solid #e5e7eb;
}

.ml-compare-head strong{
  display:block;
  font-size:1.15rem;
}

.ml-compare-head span{
  display:block;
  color:#64748b;
  margin-top:3px;
}

.ml-compare-close{
  border:none;
  background:#f1f5f9;
  border-radius:999px;
  width:38px;
  height:38px;
  font-size:1.5rem;
  cursor:pointer;
}

.ml-compare-table-wrap{
  overflow:auto;
}

.ml-compare-table{
  width:100%;
  border-collapse:collapse;
}

.ml-compare-table th,
.ml-compare-table td{
  padding:14px 16px;
  border-bottom:1px solid #e5e7eb;
  text-align:left;
}

.ml-compare-table th{
  background:#f8fafc;
  color:#334155;
}

.ml-compare-table td:first-child{
  font-weight:900;
  color:#475569;
}

body.dark-mode .ml-compare-panel{
  background:#0f172a;
  color:#e2e8f0;
}

body.dark-mode .ml-compare-head,
body.dark-mode .ml-compare-table th,
body.dark-mode .ml-compare-table td{
  border-color:#334155;
}

body.dark-mode .ml-compare-table th{
  background:#111827;
  color:#e2e8f0;
}

body.dark-mode .ml-compare-close{
  background:#1e293b;
  color:#e2e8f0;
}

@media(max-width:720px){
  .ml-compare-tray-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .ml-compare-actions{
    justify-content:flex-end;
  }
}


/* pass 73 - compare winner highlights */
.ml-compare-table td.winner{
  background:#ecfdf5;
  color:#047857;
  font-weight:900;
  box-shadow:inset 4px 0 0 #22c55e;
}

.ml-compare-trusted{
  margin-top:6px;
  display:inline-flex;
  padding:4px 8px;
  border-radius:999px;
  background:#fef3c7;
  color:#92400e;
  font-size:.72rem;
  font-weight:900;
  white-space:nowrap;
}

body.dark-mode .ml-compare-table td.winner{
  background:#052e16;
  color:#bbf7d0;
  box-shadow:inset 4px 0 0 #22c55e;
}

body.dark-mode .ml-compare-trusted{
  background:#451a03;
  color:#fcd34d;
}


/* pass 74 - compare summary actions */
.ml-compare-head-actions{
  display:flex;
  align-items:center;
  gap:8px;
}

@media(max-width:720px){
  .ml-compare-head{
    flex-direction:column;
  }

  .ml-compare-head-actions{
    justify-content:flex-end;
  }
}


/* pass 75 - compare insights */
.ml-compare-insights{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
  padding:18px 20px 0;
}

.ml-compare-insight-card{
  padding:14px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}

.ml-compare-insight-card strong{
  display:block;
  color:#0f172a;
  font-size:.84rem;
  margin-bottom:6px;
}

.ml-compare-insight-card span{
  color:#334155;
  font-weight:900;
}

body.dark-mode .ml-compare-insight-card{
  background:#111827;
  border-color:#334155;
}

body.dark-mode .ml-compare-insight-card strong{
  color:#cbd5e1;
}

body.dark-mode .ml-compare-insight-card span{
  color:#f8fafc;
}


/* pass 76 - compare open product action */
.ml-compare-open-product{
  margin-top:8px;
  display:inline-flex;
  border:1px solid #c7d2fe;
  background:#eef2ff;
  color:#3730a3;
  border-radius:999px;
  padding:5px 9px;
  font-size:.75rem;
  font-weight:900;
  cursor:pointer;
}

.ml-compare-open-product:hover{
  background:#3730a3;
  color:#fff;
}

body.dark-mode .ml-compare-open-product{
  background:#1e1b4b;
  border-color:#3730a3;
  color:#c7d2fe;
}

body.dark-mode .ml-compare-open-product:hover{
  background:#3730a3;
  color:#fff;
}


/* pass 79 - reviewer reputation */
.ml-reviewer-reputation{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}

.ml-reviewer-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:5px 10px;
  border-radius:999px;
  background:#eef2ff;
  color:#3730a3;
  font-size:.78rem;
  font-weight:800;
}

body.dark-mode .ml-reviewer-badge{
  background:#1e1b4b;
  color:#c7d2fe;
}


/* pass 79 - reviewer reputation */
.ml-reviewer-reputation{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}

.ml-reviewer-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:5px 10px;
  border-radius:999px;
  background:#eef2ff;
  color:#3730a3;
  font-size:.78rem;
  font-weight:800;
}

body.dark-mode .ml-reviewer-badge{
  background:#1e1b4b;
  color:#c7d2fe;
}

