/* ═══════════════════════════════════════════
   BMH Trip Cost Calculator v2
   Styled to match bestmallorcahotels.com theme
   ═══════════════════════════════════════════ */

.bmhcc *,.bmhcc *::before,.bmhcc *::after{box-sizing:border-box;margin:0;padding:0}

.bmhcc{
  --cc-primary:#014DA0;
  --cc-primary-hover:#013d80;
  --cc-primary-light:#e0edfb;
  --cc-accent:#E8A317;
  --cc-accent-hover:#cf9010;
  --cc-cta:#db0c64;
  --cc-cta-hover:#AB0049;
  --cc-text:#1a1a1a;
  --cc-muted:#6b7280;
  --cc-border:#e5e7eb;
  --cc-bg:#ffffff;
  --cc-bg-soft:#f9fafb;
  --cc-bg-muted:#f3f4f6;
  --cc-radius:8px;
  --cc-radius-lg:12px;
  --cc-radius-xl:16px;
  --cc-shadow:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -2px rgba(0,0,0,.05);
  --cc-shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.04);
  --cc-font-body:'Source Serif 4',Georgia,'Times New Roman',serif;
  --cc-font-heading:'Cormorant Garamond',Georgia,serif;
  --cc-font-ui:'Montserrat',-apple-system,BlinkMacSystemFont,sans-serif;
  max-width:1200px;
  margin:0 auto;
  /* No horizontal padding — theme's .page-content already provides 24px */
  padding:0;
  font-family:var(--cc-font-body);
  color:var(--cc-text);
  line-height:1.65;
  font-size:.975rem;
}

/* Reset theme link styles inside calculator */
.bmhcc a,
.bmhcc a:hover {
  text-decoration:none;
  color:inherit;
}

/* ═══ Hero ═══ */
.bmhcc-hero{
  background:linear-gradient(135deg,#fef4e8 0%,#e0edfb 50%,#fde8d8 100%);
  border-radius:var(--cc-radius-xl);
  padding:20px 40px 40px;
  margin-bottom:24px;
  position:relative;
  overflow:hidden;
}
.bmhcc-hero::after{
  content:'';position:absolute;right:-60px;top:-60px;
  width:200px;height:200px;border-radius:50%;
  border:30px solid rgba(1,77,160,.06);pointer-events:none;
}
.bmhcc-eyebrow{
  display:inline-block;
  font-family:var(--cc-font-ui);font-size:.7rem;font-weight:600;
  text-transform:uppercase;letter-spacing:1px;
  color:var(--cc-primary);
  background:var(--cc-primary-light);
  padding:5px 14px;border-radius:var(--cc-radius);
  margin-bottom:14px;
}
.bmhcc .bmhcc-title{
  font-family:var(--cc-font-heading) !important;
  font-size:clamp(1.8rem,4vw,2.8rem) !important;
  font-weight:600 !important;line-height:1.1 !important;
  letter-spacing:-.5px;color:var(--cc-text);
  max-width:700px;
  margin-top:0 !important;margin-bottom:0 !important;
}
.bmhcc-subtitle{
  font-family:var(--cc-font-body);
  font-size:1rem;color:var(--cc-muted);
  margin-top:10px;max-width:640px;
}

/* ═══ Layout ═══ */
.bmhcc-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 310px;
  gap:20px;align-items:start;
}

/* ═══ Wizard card ═══ */
.bmhcc-wizard{
  background:var(--cc-bg);
  border:1px solid var(--cc-border);
  border-radius:var(--cc-radius-xl);
  box-shadow:var(--cc-shadow);
  padding:28px;
  min-width:0;
}

/* ═══ Step nav ═══ */
.bmhcc-steps-nav{
  display:grid;grid-template-columns:repeat(5,1fr);gap:6px;
  margin-bottom:24px;
}
.bmhcc-steps-nav button{
  border:1px solid var(--cc-border);border-radius:var(--cc-radius);
  padding:10px 6px;background:var(--cc-bg);
  color:var(--cc-muted);
  font-family:var(--cc-font-ui);font-size:.7rem;font-weight:600;
  cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:5px;
  text-decoration:none;
}
.bmhcc-steps-nav button:hover{border-color:var(--cc-primary);color:var(--cc-primary)}
.bmhcc-steps-nav button.active{background:var(--cc-primary);color:#fff;border-color:var(--cc-primary)}
.bmhcc-steps-nav button.done{background:#fef4e8;color:#8b6914;border-color:#f0dba8}
.bmhcc-step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;
  background:rgba(0,0,0,.06);font-size:.65rem;font-weight:700;flex-shrink:0;
}
.bmhcc-steps-nav button.active .bmhcc-step-num{background:rgba(255,255,255,.2)}
.bmhcc-steps-nav button.done .bmhcc-step-num{background:rgba(139,105,20,.12)}

/* ═══ Steps ═══ */
.bmhcc-step{display:none}
.bmhcc-step.active{display:block}
.bmhcc-kicker{
  font-family:var(--cc-font-ui);font-size:.65rem;
  text-transform:uppercase;letter-spacing:1.2px;
  font-weight:700;color:var(--cc-primary);margin-bottom:4px;
}
.bmhcc .bmhcc-step-title{
  font-family:var(--cc-font-heading) !important;
  font-size:clamp(1.4rem,3vw,1.9rem) !important;
  font-weight:600 !important;line-height:1.1 !important;
  letter-spacing:-.3px;margin-bottom:4px;
  margin-top:0 !important;
}
.bmhcc .bmhcc-intro{color:var(--cc-muted);font-size:.9rem !important;margin-bottom:18px !important;line-height:1.65 !important}

/* ═══ Fields ═══ */
.bmhcc-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.bmhcc-field{
  border:1px solid var(--cc-border);border-radius:var(--cc-radius-lg);
  background:var(--cc-bg);padding:14px 16px;
  overflow:hidden;
}
.bmhcc-field.bmhcc-full{grid-column:1/-1}
.bmhcc-field label,.bmhcc-label{
  display:block;font-family:var(--cc-font-ui);
  font-size:.75rem;font-weight:600;margin-bottom:6px;color:var(--cc-text);
}
.bmhcc-hint{font-size:.75rem;color:var(--cc-muted);margin-top:5px;display:block;font-family:var(--cc-font-ui)}

/* Auto-rooms inline link */
.bmhcc-label-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:8px;
  margin-bottom:6px;
}
.bmhcc-label-row label{margin-bottom:0}
.bmhcc .bmhcc-inline-link{
  font-family:var(--cc-font-ui);font-size:.68rem;font-weight:600;
  color:var(--cc-primary);text-decoration:none;white-space:nowrap;
}
.bmhcc .bmhcc-inline-link:hover{text-decoration:underline}

/* Inputs — no spinner, contained width */
.bmhcc input[type=number]{
  width:100%;max-width:100%;min-height:44px;
  border:1px solid var(--cc-border);border-radius:var(--cc-radius);
  background:var(--cc-bg-soft);padding:8px 12px;
  font-family:var(--cc-font-ui);font-size:.85rem;color:var(--cc-text);
  outline:none;transition:border-color .2s,box-shadow .2s;
  -moz-appearance:textfield;
}
.bmhcc input[type=number]::-webkit-outer-spin-button,
.bmhcc input[type=number]::-webkit-inner-spin-button{
  -webkit-appearance:none;margin:0;
}

/* Custom selects */
.bmhcc select{
  width:100%;max-width:100%;min-height:44px;
  border:1px solid var(--cc-border);border-radius:var(--cc-radius);
  background:var(--cc-bg-soft);padding:8px 36px 8px 12px;
  font-family:var(--cc-font-ui);font-size:.85rem;color:var(--cc-text);
  outline:none;transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:12px;
  cursor:pointer;
}
.bmhcc input[type=number]:focus,.bmhcc select:focus{
  border-color:var(--cc-primary);
  box-shadow:0 0 0 3px rgba(1,77,160,.1);
}
.bmhcc select:hover{border-color:rgba(1,77,160,.35)}

/* Validation highlight */
.bmhcc-field.bmhcc-corrected{
  border-color:#f59e0b;
  animation:bmhcc-pulse .5s ease;
}
@keyframes bmhcc-pulse{
  0%,100%{border-color:#f59e0b}
  50%{border-color:#fbbf24;box-shadow:0 0 0 3px rgba(245,158,11,.12)}
}

.bmhcc-hidden{display:none!important}

/* ═══ Choice cards (radio) ═══ */
.bmhcc-choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.bmhcc-choice{
  display:flex;gap:10px;
  border:1px solid var(--cc-border);border-radius:var(--cc-radius-lg);
  padding:12px 14px;background:var(--cc-bg);cursor:pointer;
  transition:border-color .2s,box-shadow .2s;
}
.bmhcc-choice:hover{border-color:rgba(1,77,160,.4)}
.bmhcc-choice:has(input:checked){
  border-color:var(--cc-primary);
  background:var(--cc-primary-light);
  box-shadow:0 0 0 2px rgba(1,77,160,.12);
}
.bmhcc-choice input[type=radio]{margin-top:3px;accent-color:var(--cc-primary);flex-shrink:0}
.bmhcc-choice strong{display:block;font-family:var(--cc-font-ui);font-size:.8rem;font-weight:600}
.bmhcc-choice span{display:block;color:var(--cc-muted);font-size:.75rem;margin-top:2px;font-family:var(--cc-font-ui)}

/* ═══ Toggle ═══ */
.bmhcc-toggle{
  display:flex;align-items:center;gap:10px;
  font-family:var(--cc-font-ui);font-size:.8rem;font-weight:600;cursor:pointer;
}
.bmhcc-toggle input{accent-color:var(--cc-primary)}

/* ═══ Buttons — higher specificity beats .page-content a ═══ */
.bmhcc .bmhcc-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 22px;border-radius:var(--cc-radius);
  font-family:var(--cc-font-ui);font-size:.78rem;font-weight:600;
  border:none;cursor:pointer;transition:all .2s;
  text-decoration:none !important;
  white-space:nowrap;
  color:inherit;
}
.bmhcc .bmhcc-btn-primary{background:var(--cc-primary);color:#fff !important}
.bmhcc .bmhcc-btn-primary:hover{background:var(--cc-primary-hover);color:#fff !important}
.bmhcc .bmhcc-btn-cta{background:var(--cc-cta);color:#fff !important}
.bmhcc .bmhcc-btn-cta:hover{background:var(--cc-cta-hover);color:#fff !important}
.bmhcc .bmhcc-btn-outline{background:transparent;color:var(--cc-text) !important;border:1px solid var(--cc-border)}
.bmhcc .bmhcc-btn-outline:hover{border-color:var(--cc-primary);color:var(--cc-primary) !important}
.bmhcc .bmhcc-btn-sm{padding:7px 14px;font-size:.7rem}

/* ═══ Actions row ═══ */
.bmhcc-actions{display:flex;justify-content:space-between;gap:12px;margin-top:20px}
.bmhcc-nav-actions{border-top:1px solid var(--cc-border);padding-top:20px}

/* ═══ Sidebar ═══ */
.bmhcc-sidebar{
  background:var(--cc-bg);border:1px solid var(--cc-border);
  border-radius:var(--cc-radius-xl);box-shadow:var(--cc-shadow);
  padding:22px;position:sticky;top:80px;
  min-width:0;
}
.bmhcc-panel-label{
  font-family:var(--cc-font-ui);font-size:.65rem;
  text-transform:uppercase;letter-spacing:1px;font-weight:700;
  color:var(--cc-muted);margin-bottom:6px;
}
.bmhcc .bmhcc-big{
  font-family:var(--cc-font-heading) !important;
  font-size:2.6rem !important;line-height:1 !important;font-weight:600 !important;
  letter-spacing:-1.5px;color:var(--cc-text);
  margin-bottom:0 !important;
}
.bmhcc .bmhcc-sub{color:var(--cc-muted);font-size:.82rem !important;margin:6px 0 14px !important;font-family:var(--cc-font-ui);line-height:1.5 !important}

.bmhcc-area-box{
  padding:14px;margin-bottom:14px;
  border-radius:var(--cc-radius-lg);
  background:linear-gradient(180deg,var(--cc-primary-light),var(--cc-bg));
  border:1px solid rgba(1,77,160,.12);
}
.bmhcc-area-box h4{
  font-family:var(--cc-font-heading);font-size:1.2rem;
  font-weight:600;margin:4px 0;letter-spacing:-.3px;
}
.bmhcc-area-box p{
  color:var(--cc-muted);font-size:.78rem;margin-bottom:10px;
  font-family:var(--cc-font-ui);line-height:1.5;
}

.bmhcc-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}
.bmhcc-stat{
  background:var(--cc-bg-soft);border:1px solid var(--cc-border);
  border-radius:var(--cc-radius-lg);padding:10px 12px;
}
.bmhcc-stat strong{display:block;font-family:var(--cc-font-heading);font-size:1.2rem;font-weight:600;letter-spacing:-.5px}
.bmhcc-stat span{font-family:var(--cc-font-ui);font-size:.65rem;color:var(--cc-muted);font-weight:600}

/* Compact bars */
.bmhcc-bars{display:grid;gap:5px}
.bmhcc-barline{display:grid;gap:2px}
.bmhcc-barhead{
  display:flex;justify-content:space-between;
  font-family:var(--cc-font-ui);font-size:.68rem;font-weight:600;color:var(--cc-muted);
}
.bmhcc-bar{height:5px;background:var(--cc-bg-muted);border-radius:99px;overflow:hidden}
.bmhcc-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--cc-primary),var(--cc-accent));width:var(--w);border-radius:99px;transition:width .4s ease}

/* ═══ Result mini cards ═══ */
.bmhcc-result-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0}
.bmhcc-mini{border:1px solid var(--cc-border);border-radius:var(--cc-radius-lg);background:var(--cc-bg);padding:14px}
.bmhcc-mini span{font-family:var(--cc-font-ui);font-size:.7rem;color:var(--cc-muted);font-weight:600;display:block;margin-bottom:2px}
.bmhcc-mini strong{display:block;font-family:var(--cc-font-heading);font-size:1.5rem;font-weight:600;letter-spacing:-.5px}

/* ═══ Summary ═══ */
.bmhcc-summary{
  background:var(--cc-bg-soft);border:1px solid var(--cc-border);
  border-radius:var(--cc-radius-lg);padding:14px 16px;margin-bottom:16px;
}
.bmhcc-summary p{margin:0;color:var(--cc-muted);font-family:var(--cc-font-ui);font-size:.82rem;line-height:1.6}
.bmhcc-summary strong{color:var(--cc-text)}

/* ═══ Result blocks with divider ═══ */
.bmhcc-result-block{
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--cc-border);
}
.bmhcc-block-heading{
  font-family:var(--cc-font-heading);font-size:1.25rem;
  font-weight:600;letter-spacing:-.3px;margin-bottom:14px;
  color:var(--cc-text);
}

/* ═══ Table — higher specificity beats .page-content table rules ═══ */
.bmhcc .bmhcc-table{
  width:100%;min-width:0;border-collapse:collapse;
  border:1px solid var(--cc-border);border-radius:var(--cc-radius-lg);
  overflow:hidden;font-family:var(--cc-font-ui);font-size:.8rem;
  border-spacing:0;
}
.bmhcc .bmhcc-table thead,
.bmhcc .bmhcc-table thead tr{
  background:var(--cc-bg-soft) !important;
}
.bmhcc .bmhcc-table th{
  padding:11px 14px !important;
  border-bottom:1px solid var(--cc-border) !important;
  text-align:left !important;
  background:var(--cc-bg-soft) !important;
  color:var(--cc-muted) !important;
  font-size:.65rem !important;
  text-transform:uppercase !important;
  letter-spacing:.5px !important;
  font-weight:700 !important;
  border-top:none !important;
  border-left:none !important;
  border-right:none !important;
}
.bmhcc .bmhcc-table td{
  padding:11px 14px !important;
  border-bottom:1px solid var(--cc-border) !important;
  border-top:none !important;
  border-left:none !important;
  border-right:none !important;
}
.bmhcc .bmhcc-table td:last-child{text-align:right;font-weight:700}
.bmhcc .bmhcc-table tr:last-child td{border-bottom:none !important}
.bmhcc .bmhcc-table tbody tr:nth-child(even){background:transparent !important}
.bmhcc .bmhcc-table tbody tr:hover{background:transparent !important}

/* ═══ Recommendation cards ═══ */
.bmhcc-reco-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.bmhcc-reco-card{
  border:1px solid var(--cc-border);border-radius:var(--cc-radius-lg);
  background:var(--cc-bg);padding:16px;
  display:flex;flex-direction:column;gap:8px;
  transition:box-shadow .2s,transform .15s;
}
.bmhcc-reco-card:first-child{
  border-color:rgba(1,77,160,.25);
  background:linear-gradient(180deg,var(--cc-primary-light),var(--cc-bg));
}
.bmhcc-reco-card:hover{box-shadow:var(--cc-shadow-lg);transform:translateY(-2px)}
.bmhcc-reco-rank{font-family:var(--cc-font-ui);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--cc-muted)}
.bmhcc-reco-card:first-child .bmhcc-reco-rank{color:var(--cc-primary)}
.bmhcc-reco-name{font-family:var(--cc-font-heading);font-size:1.1rem;font-weight:600;letter-spacing:-.2px;line-height:1.2}
.bmhcc-reco-reason{font-family:var(--cc-font-ui);font-size:.72rem;color:var(--cc-muted);line-height:1.5;flex:1}
.bmhcc-reco-pills{display:flex;gap:5px;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.bmhcc-reco-pills li{background:#fef4e8;color:#8b6914;border-radius:99px;padding:4px 9px;font-family:var(--cc-font-ui);font-size:.6rem;font-weight:700}
.bmhcc-reco-cta{margin-top:auto;width:fit-content}

/* ═══ Notes ═══ */
.bmhcc .bmhcc-note{font-family:var(--cc-font-ui);font-size:.7rem !important;color:var(--cc-muted);margin-top:16px !important;line-height:1.5 !important;margin-bottom:0 !important}
.bmhcc-currency-note{
  margin-top:8px;
  padding:8px 12px;
  background:var(--cc-bg-soft);
  border-radius:var(--cc-radius);
  border-left:3px solid var(--cc-border);
}

/* ═══ Mobile sticky bar ═══ */
.bmhcc-mobile-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:999;
  background:var(--cc-bg);border-top:1px solid var(--cc-border);
  box-shadow:0 -4px 20px rgba(0,0,0,.1);
  padding:10px 20px;
}
.bmhcc-mobile-bar-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:600px;margin:0 auto;gap:12px;
}
.bmhcc-mobile-bar-col{display:flex;flex-direction:column}
.bmhcc-mobile-bar-amount{
  font-family:var(--cc-font-heading);font-size:1.4rem;
  font-weight:600;letter-spacing:-.5px;line-height:1;
}
.bmhcc-mobile-bar-ppd{
  font-family:var(--cc-font-heading);font-size:1.1rem;
  font-weight:600;letter-spacing:-.3px;line-height:1;
  color:var(--cc-muted);
}
.bmhcc-mobile-bar-label{
  font-family:var(--cc-font-ui);font-size:.55rem;
  color:var(--cc-muted);font-weight:600;margin-top:1px;
}

/* ═══ Responsive ═══ */
@media(max-width:960px){
  .bmhcc-layout{grid-template-columns:1fr}
  .bmhcc-sidebar{display:none}
  .bmhcc-mobile-bar{display:block}
  .bmhcc{padding-bottom:70px}
}
@media(max-width:700px){
  .bmhcc{padding:0}
  .bmhcc-hero{padding:28px 22px;border-radius:var(--cc-radius-lg)}
  .bmhcc-wizard{border-radius:var(--cc-radius-lg);padding:20px 16px}
  .bmhcc-fields,.bmhcc-choices{grid-template-columns:1fr}
  .bmhcc-result-cards,.bmhcc-reco-grid{grid-template-columns:1fr}
  .bmhcc-steps-nav{grid-template-columns:repeat(5,1fr);gap:4px}
  .bmhcc-steps-nav button span:not(.bmhcc-step-num){display:none}
  .bmhcc-steps-nav button{padding:8px 4px}
  .bmhcc-nav-actions{flex-direction:column-reverse}
  .bmhcc-nav-actions .bmhcc .bmhcc-btn{width:100%}
}
