/* ============================================================
   MACHINE HIRE CALCULATOR — WSE Sydney
   Original gold/navy design, aligned to the v29 design system.
   Class prefix: .mhc-  (scoped under .v29-page)
   ============================================================ */

.v29-page .mhc-wrap { max-width: 860px; margin: 0 auto; }

/* ---- the calculator input card ---- */
.v29-page .mhc-card {
  background: #fff;
  border: 1px solid rgba(212,175,55,0.18);
  border-radius: 22px;
  padding: 34px 30px;
  box-shadow: 0 30px 70px -28px rgba(15,36,71,0.22), 0 0 0 1px rgba(212,175,55,0.05);
}
.v29-page .mhc-card-head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 20px; margin-bottom: 24px;
  border-bottom: 1px solid rgba(212,175,55,0.15);
}
.v29-page .mhc-step {
  width: 34px; height: 34px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--v29-navy-deep), var(--v29-navy-mid));
  color: var(--v29-gold); border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Space Grotesk',sans-serif; font-weight: 700; font-size: 12px;
}
.v29-page .mhc-step-title { font-weight: 700; font-size: 15px; color: var(--v29-text-dark); }
.v29-page .mhc-step-sub { font-size: 12.5px; color: var(--v29-text-light); }

.v29-page .mhc-field { margin-bottom: 20px; }
.v29-page .mhc-label {
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--v29-text-mid); font-weight: 600; margin-bottom: 9px;
}
.v29-page .mhc-label .req { color: #b91c1c; font-size: 9px; letter-spacing: 0.05em; padding: 3px 9px; background: rgba(185,28,28,0.07); border: 1px solid rgba(185,28,28,0.2); border-radius: 100px; }
.v29-page .mhc-label .req.ok { color: #15803d; background: rgba(21,128,61,0.08); border-color: rgba(21,128,61,0.22); }
.v29-page .mhc-label .req.ok::before { content: '✓ '; }
.v29-page .mhc-label .pricelink { color: var(--v29-gold-dark); text-decoration: none; font-size: 10px; border-bottom: 1px solid rgba(133,104,16,0.3); }
.v29-page .mhc-label .pricelink:hover { color: var(--v29-gold); }

.v29-page .mhc-select, .v29-page .mhc-money {
  width: 100%; height: 56px; border: 2px solid #eef0f3; border-radius: 14px;
  background: var(--v29-paper); transition: border-color .25s, box-shadow .25s, background .25s;
  font-family: 'Space Grotesk',sans-serif;
}
.v29-page .mhc-select {
  padding: 0 48px 0 18px; font-size: 15px; font-weight: 600; color: var(--v29-text-dark);
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d4af37' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 18px center; background-size: 14px;
}
.v29-page .mhc-select:hover { border-color: var(--v29-gold); background-color: #fff; }
.v29-page .mhc-select:focus { outline: none; border-color: var(--v29-navy-deep); background-color: #fff; box-shadow: 0 0 0 4px rgba(10,22,40,0.06); }
.v29-page .mhc-select:disabled { opacity: 0.55; cursor: not-allowed; }

.v29-page .mhc-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.v29-page .mhc-money { display: flex; align-items: center; padding: 0 16px; }
.v29-page .mhc-money:hover { border-color: var(--v29-gold); background: #fff; }
.v29-page .mhc-money:focus-within { border-color: var(--v29-navy-deep); background: #fff; box-shadow: 0 0 0 4px rgba(10,22,40,0.06); }
.v29-page .mhc-money .sym { color: var(--v29-gold-dark); font-weight: 700; font-size: 20px; margin-right: 7px; }
.v29-page .mhc-money input { flex: 1; min-width: 0; border: none; outline: none; background: transparent; font-size: 19px; font-weight: 500; color: var(--v29-text-dark); font-family: inherit; }
.v29-page .mhc-money input::placeholder { color: #cbd2dc; font-weight: 400; }
.v29-page .mhc-money .unit { color: #9aa3af; font-size: 12px; font-family: 'JetBrains Mono', monospace; }

.v29-page .mhc-hint {
  margin-top: 9px; padding: 9px 13px; font-size: 11.5px; line-height: 1.45;
  background: rgba(212,175,55,0.07); border: 1px solid rgba(212,175,55,0.2); border-radius: 10px;
  color: var(--v29-gold-dark); display: none;
}
.v29-page .mhc-hint.show { display: block; }
.v29-page .mhc-hint strong { color: var(--v29-text-dark); font-family: 'JetBrains Mono', monospace; }

.v29-page .mhc-autonote {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  margin-top: 6px; padding: 12px; font-size: 12px; font-weight: 600; letter-spacing: 0.02em;
  color: var(--v29-gold-dark); background: rgba(212,175,55,0.06);
  border: 1px solid rgba(212,175,55,0.2); border-radius: 12px;
}
.v29-page .mhc-autonote svg { color: var(--v29-gold); flex-shrink: 0; }

/* ---- the result card (dark navy, gold accents) ---- */
.v29-page .mhc-result {
  margin-top: 18px; border-radius: 22px; padding: 32px 30px; color: #fff; position: relative; overflow: hidden;
  background: linear-gradient(135deg, #000 0%, var(--v29-navy-deep) 35%, var(--v29-navy-mid) 75%, var(--v29-navy-deep) 100%);
  box-shadow: 0 40px 80px -28px rgba(0,0,0,0.45), 0 0 0 1px rgba(212,175,55,0.15);
  display: none;
}
.v29-page .mhc-result.show { display: block; animation: mhcIn .6s cubic-bezier(.16,1,.3,1); }
@keyframes mhcIn { from { opacity:0; transform: translateY(16px); } to { opacity:1; transform:none; } }
.v29-page .mhc-result-glow { position: absolute; top: -50%; right: -15%; width: 420px; height: 420px; background: radial-gradient(circle, rgba(212,175,55,0.2), transparent 62%); pointer-events: none; }
.v29-page .mhc-rc { position: relative; z-index: 2; }
.v29-page .mhc-rlabel {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 14px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--v29-gold); font-weight: 600; padding: 6px 13px;
  background: rgba(212,175,55,0.1); border: 1px solid rgba(212,175,55,0.3); border-radius: 100px;
}
.v29-page .mhc-rlabel .dot { width: 6px; height: 6px; background: var(--v29-gold); border-radius: 50%; box-shadow: 0 0 8px var(--v29-gold); animation: mhcPulse 1.8s infinite; }
@keyframes mhcPulse { 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:.4;transform:scale(1.4);} }
.v29-page .mhc-machine {
  display: inline-flex; align-items: center; gap: 9px; margin-bottom: 18px;
  font-size: 12px; color: #fff; padding: 8px 15px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: 100px;
}
.v29-page .mhc-machine .mdot { width: 6px; height: 6px; background: var(--v29-gold); border-radius: 50%; box-shadow: 0 0 8px var(--v29-gold); }

.v29-page .mhc-rates { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; margin-bottom: 18px; }
.v29-page .mhc-rate { padding: 18px; border-radius: 16px; }
.v29-page .mhc-rate.wet { background: linear-gradient(135deg, rgba(212,175,55,0.13), rgba(212,175,55,0.03)); border: 1px solid rgba(212,175,55,0.3); }
.v29-page .mhc-rate.dry { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); }
.v29-page .mhc-rate-tag { font-family: 'Space Grotesk',sans-serif; font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 700; margin-bottom: 9px; }
.v29-page .mhc-rate.wet .mhc-rate-tag { color: var(--v29-gold); }
.v29-page .mhc-rate.dry .mhc-rate-tag { color: rgba(255,255,255,0.6); }
.v29-page .mhc-rate-num { font-family: 'Space Grotesk',sans-serif; font-weight: 300; line-height: .9; letter-spacing: -1.5px; }
.v29-page .mhc-rate.wet .mhc-rate-num { font-size: 52px; }
.v29-page .mhc-rate.dry .mhc-rate-num { font-size: 36px; }
.v29-page .mhc-rate-num .sym { font-size: 0.4em; vertical-align: top; color: rgba(255,255,255,0.45); margin-right: 2px; }
.v29-page .mhc-rate.wet .mhc-rate-num .big { background: linear-gradient(135deg,#fff,#d4af37 55%,#f5d76e); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.v29-page .mhc-rate.dry .mhc-rate-num .big { color: rgba(255,255,255,0.95); }
.v29-page .mhc-rate-num .cents { font-size: 0.4em; color: rgba(255,255,255,0.4); }
.v29-page .mhc-rate-num .per { font-size: 0.24em; color: rgba(255,255,255,0.4); font-family: 'JetBrains Mono', monospace; margin-left: 4px; letter-spacing: 0; }
.v29-page .mhc-rate-meta { margin-top: 8px; font-family: 'Space Grotesk',sans-serif; font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255,255,255,0.45); font-weight: 600; }

.v29-page .mhc-proj { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 16px 18px; }
.v29-page .mhc-proj-title { font-family: 'Space Grotesk',sans-serif; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--v29-gold); font-weight: 700; margin-bottom: 12px; }
.v29-page .mhc-proj-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.v29-page .mhc-proj-lbl { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(255,255,255,0.5); margin-bottom: 4px; }
.v29-page .mhc-proj-val { font-family: 'Space Grotesk',sans-serif; font-size: 19px; font-weight: 500; color: #fff; letter-spacing: -.5px; }

.v29-page .mhc-divider { height: 1px; margin: 22px 0 18px; background: linear-gradient(90deg, transparent, rgba(212,175,55,0.4), transparent); position: relative; }
.v29-page .mhc-divider::before { content: '✦'; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); color: var(--v29-gold); background: var(--v29-navy-deep); padding: 0 12px; font-size: 11px; }

.v29-page .mhc-breakdown { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.v29-page .mhc-bd { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; padding: 14px 16px; }
.v29-page .mhc-bd-lbl { font-family: 'Space Grotesk',sans-serif; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); font-weight: 700; margin-bottom: 6px; }
.v29-page .mhc-bd-val { font-family: 'Space Grotesk',sans-serif; font-size: 20px; font-weight: 500; color: #fff; letter-spacing: -.5px; }
.v29-page .mhc-bd-val .sm { font-size: 12px; color: rgba(255,255,255,0.4); margin-left: 3px; font-family: 'JetBrains Mono', monospace; }

.v29-page .mhc-result-cta {
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center; justify-content: space-between;
  margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(212,175,55,0.15);
}
.v29-page .mhc-result-note { font-size: 11.5px; color: rgba(255,255,255,0.55); line-height: 1.45; flex: 1 1 260px; }
.v29-page .mhc-result-btn {
  display: inline-flex; align-items: center; gap: 9px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--v29-gold), var(--v29-gold-light)); color: var(--v29-navy-deep);
  padding: 12px 22px; border-radius: 12px; text-decoration: none;
  font-family: 'Space Grotesk',sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  box-shadow: 0 8px 22px -6px rgba(212,175,55,0.5); transition: transform .25s, box-shadow .25s;
}
.v29-page .mhc-result-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 30px -6px rgba(212,175,55,0.7); }

.v29-page .mhc-err { font-size: 11.5px; color: #b91c1c; margin-top: 6px; display: none; font-weight: 500; }
.v29-page .mhc-err.show { display: block; }
.v29-page .mhc-money.err, .v29-page .mhc-select.err { border-color: #b91c1c; background: #fef2f2; }

@media (max-width: 640px) {
  .v29-page .mhc-card { padding: 26px 20px; }
  .v29-page .mhc-row2 { grid-template-columns: 1fr; }
  .v29-page .mhc-rates { grid-template-columns: 1fr; }
  .v29-page .mhc-rate.wet .mhc-rate-num { font-size: 44px; }
  .v29-page .mhc-proj-grid { grid-template-columns: 1fr; gap: 10px; }
  .v29-page .mhc-breakdown { grid-template-columns: 1fr; }
  .v29-page .mhc-result-cta { flex-direction: column; align-items: stretch; }
  .v29-page .mhc-result-btn { justify-content: center; }
}

/* ---- review prompt (shows once after a few uses) ---- */
.v29-page .mhc-review {
  display: none;
  margin-top: 16px; border-radius: 18px; padding: 20px 24px;
  background: linear-gradient(135deg, rgba(212,175,55,0.1), rgba(212,175,55,0.03));
  border: 1px solid rgba(212,175,55,0.3);
  align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.v29-page .mhc-review.show { display: flex; animation: mhcIn .5s cubic-bezier(.16,1,.3,1); }
.v29-page .mhc-review-text { flex: 1 1 280px; }
.v29-page .mhc-review-title { font-family: 'Space Grotesk',sans-serif; font-size: 17px; font-weight: 700; color: var(--v29-text-dark); margin-bottom: 4px; }
.v29-page .mhc-review-title .star { color: var(--v29-gold); }
.v29-page .mhc-review-sub { font-size: 13px; color: var(--v29-text-mid); line-height: 1.5; }
.v29-page .mhc-review-actions { display: flex; gap: 12px; align-items: center; flex-shrink: 0; }
.v29-page .mhc-review-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--v29-gold), var(--v29-gold-light)); color: var(--v29-navy-deep);
  padding: 11px 20px; border-radius: 12px; text-decoration: none;
  font-family: 'Space Grotesk',sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  box-shadow: 0 8px 20px -6px rgba(212,175,55,0.5); transition: transform .25s, box-shadow .25s;
}
.v29-page .mhc-review-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px -6px rgba(212,175,55,0.7); }
.v29-page .mhc-review-dismiss { background: none; border: none; color: var(--v29-text-light); cursor: pointer; font-size: 12.5px; font-weight: 500; font-family: inherit; }
.v29-page .mhc-review-dismiss:hover { color: var(--v29-text-dark); }
@media (max-width: 640px) {
  .v29-page .mhc-review { flex-direction: column; align-items: flex-start; }
  .v29-page .mhc-review-actions { width: 100%; }
  .v29-page .mhc-review-btn { flex: 1; justify-content: center; }
}

/* indicative-only disclaimer under the calculator card */
.v29-page .mhc-disclaimer {
  margin-top: 16px; padding: 13px 16px;
  font-size: 11.5px; line-height: 1.55; color: var(--v29-text-light);
  background: rgba(0,0,0,0.02); border: 1px solid var(--v29-border); border-left: 3px solid rgba(212,175,55,0.4);
  border-radius: 10px;
}
.v29-page .mhc-disclaimer a { color: var(--v29-navy-mid); font-weight: 600; text-decoration: none; border-bottom: 1px solid rgba(26,58,110,0.3); }
.v29-page .mhc-disclaimer a:hover { color: var(--v29-gold-dark); }
