/* ================================================================
   H5 Mall Frontend Portals v5
   Matches EXACT class names used in portal JS files
   ================================================================ */
/* ── Variables ─────────────────────────────────────── */
:root {
  --hp-bg:       #fff6f3;
  --hp-bg2:      #ffffff;
  --hp-bg3:      #fff0ea;
  --hp-border:   rgba(255,74,67,0.14);
  --hp-border2:  rgba(255,74,67,0.22);
  --hp-text:     #2a2326;
  --hp-text2:    #6f5d62;
  --hp-text3:    #a18e92;
  --hp-accent:   #ff4a43;
  --hp-accent2:  #f58a36;
  --hp-green:    #83d442;
  --hp-red:      #ff4d6d;
  --hp-yellow:   #ffd166;
  --hp-purple:   #f25797;
  --hp-orange:   #f58a36;
  --hp-r:        14px;
  --hp-r2:       10px;
  --hp-shadow:   0 14px 34px rgba(255,74,67,0.10);
  --hp-font:     var(--wp--preset--font-family--body, inherit);
  --hp-display:  var(--wp--preset--font-family--heading, var(--hp-font));
  --hp-tr:       all 0.2s ease;
}

/* ── Reset & Base ──────────────────────────────────── */
body { margin: 0; padding: 0; background: var(--hp-bg); color: var(--hp-text); font-family: inherit; }

/* ── Container ─────────────────────────────────────── */
.h5p-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 20px 60px;
  position: relative;
}

/* ── Header (page top banner) ──────────────────────── */
.h5p-header {
  padding: 36px 0 24px;
  text-align: center;
  position: relative;
}

.h5p-header::before {
  content: '';
  position: absolute;
  top: -100px; left: 50%;
  transform: translateX(-50%);
  width: 600px; height: 400px;
  background: radial-gradient(ellipse, rgba(91,107,255,0.08) 0%, transparent 70%);
  pointer-events: none;
}

.h5p-header h1 {
  font-family: var(--hp-display);
  font-size: 28px;
  font-weight: 800;
  color: var(--hp-text);
  margin: 0 0 8px;
  letter-spacing: -0.5px;
}

.h5p-header p {
  font-size: 14px;
  color: var(--hp-text2);
  margin: 0;
}

/* ── Nav bar ───────────────────────────────────────── */
.h5p-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px solid var(--hp-border);
  margin-bottom: 24px;
  gap: 12px;
  flex-wrap: wrap;
}

.h5p-nav h1 {
  font-family: var(--hp-display);
  font-size: 18px;
  font-weight: 800;
  color: var(--hp-text);
  margin: 0;
  letter-spacing: -0.3px;
}

.h5p-nav p { margin: 0; font-size: 12px; color: var(--hp-text3); }

.h5p-nav-links {
  display: flex;
  align-items: center;
  gap: 16px;
}

.h5p-nav-links a {
  font-size: 13px;
  font-weight: 500;
  color: var(--hp-text2);
  text-decoration: none;
  transition: var(--hp-tr);
}

.h5p-nav-links a:hover { color: rgba(255,255,255,.86); }

/* ── Tabs ──────────────────────────────────────────── */
.h5p-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  background: var(--hp-bg3);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-r);
  padding: 5px;
  margin-bottom: 24px;
  overflow: visible;
  justify-content: center;
}

.h5p-tab {
  flex-shrink: 0;
  padding: 8px 16px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--hp-text3);
  cursor: pointer;
  border: none;
  background: none;
  font-family: var(--hp-font);
  transition: var(--hp-tr);
  white-space: nowrap;
}

.h5p-tab:hover { color: var(--hp-text2); }

.h5p-tab-active, .h5p-tab.active {
  background: var(--hp-accent);
  color: #fff;
  box-shadow: 0 0 20px rgba(91,107,255,0.4);
}

/* ── Card ──────────────────────────────────────────── */
.h5p-card {
  background: rgba(255,255,255,0.94);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-r);
  padding: 24px;
  margin-bottom: 16px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s;
}

.h5p-card:hover { border-color: var(--hp-border2); }

/* ── Stats grid ────────────────────────────────────── */
.h5p-grid {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}

.h5p-grid-2 { grid-template-columns: repeat(2, 1fr); }
.h5p-grid-3 { grid-template-columns: repeat(3, 1fr); }
.h5p-grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 640px) {
  .h5p-grid-3, .h5p-grid-4 { grid-template-columns: repeat(2, 1fr); }
}

.h5p-stat {
  background: rgba(255,255,255,0.94);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-r2);
  padding: 18px 16px;
  text-align: center;
  transition: var(--hp-tr);
}

.h5p-stat:hover {
  border-color: rgba(91,107,255,0.3);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
}

.h5p-stat-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--hp-text3);
  margin-bottom: 8px;
}

.h5p-stat-value {
  font-family: var(--hp-font);
  font-size: 24px;
  font-weight: 800;
  color: var(--hp-text);
  letter-spacing: -0.5px;
}

/* ── Buttons ───────────────────────────────────────── */
.h5p-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: var(--hp-r2);
  font-size: 14px;
  font-weight: 600;
  font-family: var(--hp-font);
  cursor: pointer;
  transition: var(--hp-tr);
  border: 1px solid transparent;
  outline: none;
  text-decoration: none;
  white-space: nowrap;
  background: none;
  -webkit-appearance: none;
}

.h5p-btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.h5p-btn-primary {
  background: linear-gradient(135deg, var(--hp-accent), var(--hp-accent2));
  color: #fff;
  box-shadow: 0 0 24px rgba(91,107,255,0.35);
}

.h5p-btn-primary:hover:not(:disabled) {
  box-shadow: 0 0 32px rgba(91,107,255,0.55);
  transform: translateY(-1px);
}

.h5p-btn-outline {
  border-color: var(--hp-border2);
  color: var(--hp-text2);
}

.h5p-btn-outline:hover:not(:disabled) {
  background: rgba(59,130,246,0.06);
  color: var(--hp-text);
}

.h5p-btn-danger {
  background: rgba(255,77,109,0.15);
  border-color: rgba(255,77,109,0.3);
  color: var(--hp-red);
}

.h5p-btn-block { width: 100%; }

.h5p-btn-sm { padding: 6px 14px; font-size: 12px; }

/* ── Form ──────────────────────────────────────────── */
.h5p-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.h5p-field {
  margin-bottom: 16px;
}

.h5p-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--hp-text2);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.h5p-field input,
.h5p-field select,
.h5p-field textarea {
  width: 100%;
  background: var(--hp-bg3);
  border: 1px solid var(--hp-border2);
  color: var(--hp-text);
  font-family: var(--hp-font);
  font-size: 14px;
  padding: 11px 14px;
  border-radius: var(--hp-r2);
  outline: none;
  transition: var(--hp-tr);
  box-sizing: border-box;
  -webkit-appearance: none;
}

.h5p-field input:focus,
.h5p-field select:focus,
.h5p-field textarea:focus {
  border-color: var(--hp-accent);
  box-shadow: 0 0 0 3px rgba(91,107,255,0.15);
}

.h5p-field input::placeholder { color: var(--hp-text3); }
.h5p-field input[readonly] { background: rgba(255,255,255,0.04); color: var(--hp-text3); cursor: default; }
.h5p-field select option { background: #111520; color: var(--hp-text); }

.h5p-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
}

.h5p-checkbox input[type=checkbox] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--hp-accent);
  margin: 0;
  padding: 0;
}

.h5p-checkbox label {
  font-size: 13px;
  color: var(--hp-text2);
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}

/* ── Error text ────────────────────────────────────── */
.h5p-error-text {
  color: var(--hp-red);
  font-size: 13px;
  background: rgba(255,77,109,0.1);
  border: 1px solid rgba(255,77,109,0.2);
  border-radius: var(--hp-r2);
  padding: 10px 14px;
  margin-bottom: 12px;
}

/* ── Tables ────────────────────────────────────────── */
.h5p-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

.h5p-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}

.h5p-table th {
  text-align: left;
  padding: 10px 14px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--hp-text3);
  background: rgba(0,0,0,0.2);
  border-bottom: 1px solid var(--hp-border);
  white-space: nowrap;
}

.h5p-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--hp-border);
  color: var(--hp-text);
  vertical-align: middle;
}

.h5p-table tr:last-child td { border-bottom: none; }
.h5p-table tbody tr:hover { background: rgba(91,107,255,0.04); }

/* ── Badges ────────────────────────────────────────── */
.h5p-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.h5p-badge-pending  { background: rgba(255,209,102,0.15); color: var(--hp-yellow); border: 1px solid rgba(255,209,102,0.25); }
.h5p-badge-paid, .h5p-badge-approved, .h5p-badge-active { background: rgba(0,229,160,0.12); color: var(--hp-green); border: 1px solid rgba(0,229,160,0.2); }
.h5p-badge-rejected, .h5p-badge-failed { background: rgba(255,77,109,0.12); color: var(--hp-red); border: 1px solid rgba(255,77,109,0.2); }
.h5p-badge-tier1 { background: rgba(91,107,255,0.15); color: var(--hp-accent2); border: 1px solid rgba(91,107,255,0.25); }
.h5p-badge-tier2 { background: rgba(183,142,255,0.15); color: var(--hp-purple); border: 1px solid rgba(183,142,255,0.2); }
.h5p-badge-tier3 { background: rgba(255,140,66,0.15); color: var(--hp-orange); border: 1px solid rgba(255,140,66,0.2); }

/* ── Flex helpers ──────────────────────────────────── */
.h5p-flex { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.h5p-flex-between { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.h5p-gap-2 { gap: 8px; }
.h5p-gap-3 { gap: 12px; }
.h5p-text-center { text-align: center; }
.h5p-text-muted { color: var(--hp-text2); }
.h5p-text-sm { font-size: 12.5px; }
.h5p-mb-1 { margin-bottom: 4px; }
.h5p-mb-2 { margin-bottom: 8px; }
.h5p-mb-3 { margin-bottom: 16px; }
.h5p-mb-4 { margin-bottom: 24px; }
.h5p-mt-2 { margin-top: 8px; }
.h5p-mt-3 { margin-top: 16px; }
.h5p-link { color: var(--hp-accent2); text-decoration: none; }
.h5p-link:hover { text-decoration: underline; }

/* ── Loading ───────────────────────────────────────── */
.h5p-loading-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  gap: 14px;
}

.h5p-skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,0.04) 25%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.04) 75%);
  background-size: 200% 100%;
  animation: hpSkeleton 1.4s infinite;
  border-radius: 6px;
  height: 16px;
}

@keyframes hpSkeleton { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@keyframes hpSpin { to { transform: rotate(360deg); } }
@keyframes hpFadeUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* ── Empty ─────────────────────────────────────────── */
.h5p-empty {
  text-align: center;
  padding: 50px 20px;
  color: var(--hp-text3);
}

.h5p-empty-icon {
  font-size: 40px;
  display: block;
  margin-bottom: 12px;
  opacity: 0.4;
}

/* ── Share / referral ──────────────────────────────── */
.h5p-share-link-box {
  background: linear-gradient(135deg, rgba(91,107,255,0.08), rgba(183,142,255,0.05));
  border: 1px solid rgba(91,107,255,0.2);
  border-radius: var(--hp-r);
  padding: 20px;
  margin-bottom: 16px;
}

.h5p-share-link-url {
  font-family: monospace;
  font-size: 12px;
  color: var(--hp-accent2);
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--hp-border2);
  border-radius: var(--hp-r2);
  padding: 10px 12px;
  word-break: break-all;
  margin: 10px 0;
}

/* ── Social share buttons ──────────────────────────── */
.h5p-social-btns { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }

.h5p-social-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--hp-r2);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  font-family: var(--hp-font);
  transition: var(--hp-tr);
  text-decoration: none;
}

.h5p-social-btn:hover { filter: brightness(1.25); transform: translateY(-1px); }
.h5p-social-whatsapp { background: rgba(37,211,102,0.15); color: #25D366; }
.h5p-social-line     { background: rgba(0,195,0,0.12);    color: #00C300; }
.h5p-social-telegram { background: rgba(40,167,236,0.12); color: #28A7EC; }
.h5p-social-twitter  { background: rgba(29,161,242,0.12); color: #1DA1F2; }
.h5p-social-wechat   { background: rgba(9,187,7,0.12);    color: #09BB07; }

/* ── QR code ───────────────────────────────────────── */
.h5p-qr-wrap {
  text-align: center;
  margin: 16px 0;
}

.h5p-qr-wrap canvas {
  background: #fff;
  padding: 8px;
  border-radius: 8px;
  border: 1px solid var(--hp-border);
}

.h5p-qr-dl {
  display: inline-block;
  margin-top: 8px;
  font-size: 12px;
  color: var(--hp-accent2);
  text-decoration: none;
}

.h5p-qr-dl:hover { text-decoration: underline; }

/* ── Search ────────────────────────────────────────── */
.h5p-search-wrap { position: relative; margin-bottom: 16px; }

.h5p-search-input {
  width: 100%;
  background: var(--hp-bg3);
  border: 1px solid var(--hp-border2);
  color: var(--hp-text);
  font-family: var(--hp-font);
  font-size: 14px;
  padding: 10px 14px 10px 38px;
  border-radius: var(--hp-r2);
  outline: none;
  transition: var(--hp-tr);
  box-sizing: border-box;
}

.h5p-search-input:focus { border-color: var(--hp-accent); box-shadow: 0 0 0 3px rgba(91,107,255,0.15); }
.h5p-search-input::placeholder { color: var(--hp-text3); }

.h5p-search-wrap::before {
  content: '🔍';
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  pointer-events: none;
}

/* ── Modal ─────────────────────────────────────────── */
.h5p-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: hpFadeUp 0.15s ease;
}

.h5p-modal {
  background: var(--hp-bg2);
  border: 1px solid var(--hp-border2);
  border-radius: var(--hp-r);
  width: 100%;
  max-width: 500px;
  box-shadow: var(--hp-shadow);
  animation: hpFadeUp 0.2s ease;
  max-height: 90vh;
  overflow-y: auto;
}

.h5p-modal-header {
  padding: 18px 20px;
  border-bottom: 1px solid var(--hp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.h5p-modal-title {
  font-family: var(--hp-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--hp-text);
}

.h5p-modal-close {
  background: none;
  border: none;
  color: var(--hp-text3);
  cursor: pointer;
  font-size: 18px;
  padding: 4px;
  line-height: 1;
  transition: color 0.15s;
}

.h5p-modal-close:hover { color: var(--hp-text); }

.h5p-modal-body { padding: 20px; }

/* ── Toast ─────────────────────────────────────────── */
.h5p-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  padding: 12px 18px;
  border-radius: var(--hp-r2);
  font-size: 13.5px;
  font-weight: 500;
  box-shadow: var(--hp-shadow);
  z-index: 99999;
  animation: hpFadeUp 0.25s ease;
  max-width: 300px;
}

.h5p-toast-success { background: rgba(0,229,160,0.12); border: 1px solid rgba(0,229,160,0.25); color: var(--hp-green); }
.h5p-toast-error   { background: rgba(255,77,109,0.12); border: 1px solid rgba(255,77,109,0.25); color: var(--hp-red); }
.h5p-toast-info    { background: rgba(91,107,255,0.12); border: 1px solid rgba(91,107,255,0.25); color: var(--hp-accent2); }

/* ── Language switcher ─────────────────────────────── */
.h5p-lang-switcher { position: relative; display: inline-block; }

.h5p-lang-btn {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--hp-border2);
  border-radius: 6px;
  color: var(--hp-text2);
  font-size: 12px;
  font-weight: 600;
  padding: 5px 10px;
  cursor: pointer;
  font-family: var(--hp-font);
  transition: var(--hp-tr);
}

.h5p-lang-btn:hover { background: rgba(59,130,246,0.06); color: var(--hp-text); }

.h5p-lang-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--hp-bg2);
  border: 1px solid var(--hp-border2);
  border-radius: var(--hp-r2);
  min-width: 120px;
  box-shadow: var(--hp-shadow);
  z-index: 1000;
  overflow: hidden;
}

.h5p-lang-option {
  display: block;
  padding: 9px 14px;
  font-size: 13px;
  color: var(--hp-text2);
  cursor: pointer;
  transition: var(--hp-tr);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: var(--hp-font);
}

.h5p-lang-option:hover { background: rgba(59,130,246,0.06); color: var(--hp-text); }
.h5p-lang-option-active { color: var(--hp-accent2) !important; font-weight: 600; }

/* ── Page-level backgrounds ────────────────────────── */
#h5-sales-portal,
#h5-customer-portal,
#h5-register-portal,
#h5-login-portal,
#h5-agent-register-portal,
#h5-datawall {
  background: var(--hp-bg);
  min-height: 100vh;
  color: var(--hp-text);
  font-family: var(--hp-font);
}

/* Ensure WC doesn't override */
#h5-login-portal input,
#h5-register-portal input,
#h5-agent-register-portal input,
#h5-sales-portal input,
#h5-customer-portal input {
  -webkit-appearance: none;
  box-shadow: none;
}

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 600px) {
  .h5p-container { padding: 0 14px 40px; }
  .h5p-grid-2, .h5p-grid-3, .h5p-grid-4 { grid-template-columns: 1fr 1fr; }
  .h5p-tabs { gap: 2px; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .h5p-tab { padding: 7px 10px; font-size: 12px; }
  .h5p-card { padding: 16px; }
  .h5p-nav-links { width: 100%; justify-content: space-between; }
}


/* ── Theme Toggle ───────────────────────────── */
.h5p-theme-toggle-wrap { display:none !important; }
.h5p-theme-toggle {
  border: 1px solid var(--hp-border2);
  background: #ffffff;
  color: var(--hp-text);
  border-radius: 999px;
  padding: 9px 14px;
  font: 600 13px var(--hp-font);
  cursor: pointer;
}
.h5p-theme-toggle:hover { background: rgba(255,255,255,0.08); }

/* ── Light Theme ────────────────────────────── */
[data-h5-theme="light"] {
  --hp-bg: #f4f7fb;
  --hp-bg2: #ffffff;
  --hp-bg3: #eef3ff;
  --hp-border: rgba(15,23,42,0.10);
  --hp-border2: rgba(15,23,42,0.16);
  --hp-text: #0f172a;
  --hp-text2: #475569;
  --hp-text3: #64748b;
  --hp-shadow: 0 10px 30px rgba(15,23,42,0.08);
}
[data-h5-theme="light"] body,
body[data-h5-theme="light"] { background: var(--hp-bg); color: var(--hp-text); }
[data-h5-theme="light"] .h5p-card,
[data-h5-theme="light"] .h5p-stat,
[data-h5-theme="light"] .h5p-tabs,
[data-h5-theme="light"] .h5p-table-wrap,
[data-h5-theme="light"] .h5p-modal,
[data-h5-theme="light"] .h5p-share-box,
[data-h5-theme="light"] .h5p-empty,
[data-h5-theme="light"] .h5p-form,
[data-h5-theme="light"] .h5p-panel { background: rgba(255,255,255,0.94); box-shadow: var(--hp-shadow); }
[data-h5-theme="light"] input,
[data-h5-theme="light"] textarea,
[data-h5-theme="light"] select { background: #fff; color: var(--hp-text); border-color: var(--hp-border2); }
[data-h5-theme="light"] .h5p-btn-outline,
[data-h5-theme="light"] .h5p-theme-toggle { background: #fff; }


.h5p-floating-theme-toggle { display:none !important;
  
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
}
.h5p-floating-theme-toggle .h5p-theme-toggle {
  box-shadow: 0 12px 30px rgba(15,23,42,.22);
}


.h5p-nav-links a, .h5p-link { color: var(--hp-accent); }
.h5p-nav-links a:hover, .h5p-link:hover { color: rgba(255,255,255,.86); }
.h5p-card { box-shadow: var(--hp-shadow); background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,247,243,0.96)); }
.h5p-header::before { background: radial-gradient(ellipse, rgba(255,74,67,0.10) 0%, transparent 70%); }
.h5p-tab-active, .h5p-tab.active { background: linear-gradient(135deg, var(--hp-accent), var(--hp-accent2)); box-shadow: 0 12px 24px rgba(255,74,67,0.24); }
.h5p-btn-primary { background: linear-gradient(135deg, var(--hp-accent), var(--hp-accent2)); box-shadow: 0 12px 24px rgba(255,74,67,0.24); }
.h5p-btn-primary:hover:not(:disabled) { box-shadow: 0 16px 30px rgba(255,74,67,0.28); }
.h5p-btn-outline:hover:not(:disabled) { background: rgba(255,74,67,0.06); }
.h5p-input:focus, .h5p-select:focus, .h5p-textarea:focus, .h5p-field input:focus, .h5p-field select:focus, .h5p-field textarea:focus { border-color: rgba(255,74,67,0.45); box-shadow: 0 0 0 4px rgba(255,74,67,0.10); outline: none; }


/* Semi-white hover color for coral/orange UI */
.h5p-tab:hover,
.h5p-tab:focus-visible,
.h5p-btn-primary:hover:not(:disabled),
.h5p-btn-primary:focus-visible,
.h5p-link:hover,
.h5p-link:focus-visible,
.h5p-nav-links a:hover,
.h5p-nav-links a:focus-visible { color: rgba(255,255,255,.86); }
.h5p-btn-outline:hover:not(:disabled) { color: rgba(255,255,255,.86); border-color: rgba(255,255,255,.24); }
.h5p-card a:hover, .h5p-card a:focus-visible { color: rgba(255,255,255,.86); }


/* Off-canvas mobile menu */
.h5p-menu-toggle {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: linear-gradient(135deg, var(--hp-accent), var(--hp-accent2));
  color: rgba(255,255,255,0.96);
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(255,74,67,0.18);
}
.h5p-menu-toggle-icon { font-size: 16px; line-height: 1; }
.h5p-offcanvas {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(28,18,20,0.42);
  backdrop-filter: blur(3px);
  opacity: 0;
  visibility: hidden;
  transition: opacity .14s ease, visibility .14s ease;
}
.h5p-offcanvas.is-open { opacity: 1; visibility: visible; }
.h5p-offcanvas-panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(340px, 88vw);
  height: 100%;
  padding: 22px 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,244,240,0.98));
  border-left: 1px solid rgba(255,74,67,0.14);
  box-shadow: -18px 0 44px rgba(255,74,67,0.14);
  transform: translateX(100%);
  transition: transform .16s ease;
  overflow-y: auto;
}
.h5p-offcanvas.is-open .h5p-offcanvas-panel { transform: translateX(0); }
.h5p-offcanvas-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}
.h5p-offcanvas-head strong {
  color: var(--hp-text);
  font-size: 17px;
  font-weight: 800;
}
.h5p-offcanvas-close {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(255,74,67,0.14);
  background: rgba(255,255,255,0.8);
  color: var(--hp-accent);
  font-size: 24px;
  line-height: 1;
}
.h5p-offcanvas-desc {
  margin: 0 0 14px;
  color: var(--hp-text2);
  font-size: 13px;
}
.h5p-offcanvas-list {
  display: grid;
  gap: 10px;
}
.h5p-offcanvas-item {
  touch-action: manipulation;
  width: 100%;
  text-align: left;
  padding: 13px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,74,67,0.10);
  background: rgba(255,255,255,0.82);
  color: var(--hp-text);
  font-size: 14px;
  font-weight: 600;
}
.h5p-offcanvas-item.is-active,
.h5p-offcanvas-item:hover,
.h5p-offcanvas-item:focus-visible {
  background: linear-gradient(135deg, var(--hp-accent), var(--hp-accent2));
  color: rgba(255,255,255,0.92);
  border-color: transparent;
}
body.h5p-offcanvas-open { overflow: hidden; }

/* Softer form fields */
.h5p-field input,
.h5p-field select,
.h5p-field textarea,
.h5p-search-input,
[data-h5-theme="light"] input,
[data-h5-theme="light"] textarea,
[data-h5-theme="light"] select {
  background: linear-gradient(180deg, #ffffff, #fff6f3);
  padding: 12px 15px;
}
.h5p-field input[readonly] { background: linear-gradient(180deg, #fffaf8, #fff4ef); }
.h5p-search-input {
  padding: 11px 14px 11px 46px;
}
.h5p-search-wrap::before {
  left: 16px;
  font-size: 15px;
}

@media (max-width: 820px) {
  .h5p-menu-toggle { display: inline-flex; touch-action: manipulation; }
  .h5p-tabs { display: none; }
  .h5p-nav-links { gap: 10px; }
}

.h5p-search-input { padding-left: 56px !important; }
.h5p-search-wrap::before { left: 18px !important; }
