/* =====================================================
   HFT — Frontend Stylesheet
   hostingfreetrial.com
===================================================== */

:root {
  --hft-primary:    #4f46e5;
  --hft-primary-d:  #3730a3;
  --hft-accent:     #06b6d4;
  --hft-green:      #16a34a;
  --hft-yellow:     #d97706;
  --hft-red:        #dc2626;
  --hft-text:       #111827;
  --hft-text-2:     #6b7280;
  --hft-border:     #e5e7eb;
  --hft-bg:         #f9fafb;
  --hft-white:      #ffffff;
  --hft-radius:     10px;
  --hft-shadow:     0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --hft-shadow-lg:  0 8px 32px rgba(0,0,0,.12);
  --hft-font:       'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* =====================================================
   RESET SCOPE
===================================================== */
.hft-wrap *, .hft-homepage *, .hft-lead-form-wrap * {
  box-sizing: border-box;
}

/* =====================================================
   HERO
===================================================== */
.hft-hero {
  background: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #1e3a5f 100%);
  color: #fff;
  padding: 80px 20px 100px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hft-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(6,182,212,.15) 0%, transparent 60%),
              radial-gradient(ellipse at 30% 80%, rgba(79,70,229,.2) 0%, transparent 50%);
  pointer-events: none;
}
.hft-hero-inner { position: relative; max-width: 760px; margin: 0 auto; }

.hft-hero-eyebrow {
  display: inline-block;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 30px;
  padding: 6px 18px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .5px;
  margin-bottom: 24px;
  backdrop-filter: blur(4px);
}
.hft-hero-title {
  font-size: clamp(36px, 6vw, 58px);
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 20px;
  letter-spacing: -1px;
}
.hft-gradient-text {
  background: linear-gradient(90deg, #67e8f9, #818cf8);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hft-hero-sub {
  font-size: 18px;
  color: rgba(255,255,255,.8);
  max-width: 580px;
  margin: 0 auto 32px;
  line-height: 1.6;
}
.hft-hero-cta-group { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 48px; }

.hft-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 14px 28px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: all .2s;
  cursor: pointer;
  border: 2px solid transparent;
}
.hft-btn--primary {
  background: var(--hft-primary);
  color: #fff;
  box-shadow: 0 4px 20px rgba(79,70,229,.4);
}
.hft-btn--primary:hover { background: var(--hft-primary-d); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(79,70,229,.5); color: #fff; }
.hft-btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.hft-btn--ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; color: #fff; }
.hft-btn--sm { padding: 9px 18px; font-size: 13px; }

.hft-hero-stats { display: flex; gap: 32px; justify-content: center; flex-wrap: wrap; }
.hft-stat { text-align: center; }
.hft-stat strong { display: block; font-size: 28px; font-weight: 800; color: #67e8f9; }
.hft-stat span { font-size: 12px; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .5px; }

.hft-hero-wave { position: absolute; bottom: 0; left: 0; right: 0; color: #f9fafb; line-height: 0; }
.hft-hero-wave svg { width: 100%; height: 60px; }

/* =====================================================
   TRUST BAR
===================================================== */
.hft-trust-bar { background: #fff; border-bottom: 1px solid var(--hft-border); padding: 16px 20px; }
.hft-trust-inner { display: flex; gap: 32px; justify-content: center; flex-wrap: wrap; max-width: 1100px; margin: 0 auto; }
.hft-trust-item { font-size: 13px; font-weight: 600; color: var(--hft-text-2); }

/* =====================================================
   SECTIONS
===================================================== */
.hft-section-header { text-align: center; margin-bottom: 40px; }
.hft-section-title { font-size: 30px; font-weight: 800; color: var(--hft-text); margin: 0 0 10px; }
.hft-section-desc { font-size: 16px; color: var(--hft-text-2); margin: 0; }
.hft-featured-section { padding: 70px 20px; background: var(--hft-bg); }

/* =====================================================
   PROVIDER CARDS
===================================================== */
.hft-cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; max-width: 1100px; margin: 0 auto; }

.hft-card {
  background: #fff;
  border: 1px solid var(--hft-border);
  border-radius: 14px;
  padding: 28px 24px;
  box-shadow: var(--hft-shadow);
  transition: box-shadow .2s, transform .2s;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hft-card:hover { box-shadow: var(--hft-shadow-lg); transform: translateY(-3px); }
.hft-card--featured { border-color: #818cf8; border-width: 2px; }

.hft-card-logo { max-height: 40px; max-width: 140px; object-fit: contain; }
.hft-card-logo-placeholder {
  width: 56px; height: 56px;
  background: linear-gradient(135deg,#4f46e5,#06b6d4);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 18px;
}
.hft-card-name { font-size: 20px; font-weight: 800; color: var(--hft-text); margin: 0; }
.hft-card-tagline { font-size: 13px; color: var(--hft-text-2); margin: 0; }
.hft-card-stars { color: #f59e0b; font-size: 16px; }
.hft-card-stars span { font-size: 12px; color: var(--hft-text-2); margin-left: 4px; }
.hft-card-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.hft-card-pros { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 4px; }
.hft-card-pros li { font-size: 13px; color: var(--hft-text); }
.hft-card-footer { margin-top: auto; display: flex; flex-direction: column; gap: 8px; }
.hft-card-pricing { font-size: 11px; color: var(--hft-text-2); }

/* =====================================================
   BADGES
===================================================== */
.hft-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 30px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: .2px;
}

/* =====================================================
   FILTERS
===================================================== */
.hft-wrap { max-width: 1300px; margin: 0 auto; padding: 0 16px; font-family: var(--hft-font); }

.hft-filters {
  background: #fff;
  border: 1px solid var(--hft-border);
  border-radius: 12px;
  padding: 20px 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
  margin-bottom: 20px;
  box-shadow: var(--hft-shadow);
}
.hft-filter-group { display: flex; flex-direction: column; gap: 5px; min-width: 140px; }
.hft-filter-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--hft-text-2); }
.hft-search-input, .hft-select {
  border: 1px solid var(--hft-border);
  border-radius: 7px;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--hft-text);
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
}
.hft-search-input:focus, .hft-select:focus {
  outline: none;
  border-color: var(--hft-primary);
  box-shadow: 0 0 0 3px rgba(79,70,229,.12);
}
.hft-filter-toggle { justify-content: flex-end; }
.hft-filter-toggle label { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; font-weight: 600; color: var(--hft-text); padding: 8px 0; }
.hft-reset-btn {
  padding: 8px 16px;
  border: 1px solid var(--hft-border);
  border-radius: 7px;
  background: #fff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: var(--hft-text-2);
  transition: all .15s;
  align-self: flex-end;
}
.hft-reset-btn:hover { border-color: var(--hft-primary); color: var(--hft-primary); }

.hft-results-count { font-size: 13px; color: var(--hft-text-2); margin-bottom: 10px; }
.hft-results-count span { font-weight: 700; color: var(--hft-primary); }

/* =====================================================
   TABLE
===================================================== */
.hft-table-wrap { overflow-x: auto; border-radius: 12px; border: 1px solid var(--hft-border); box-shadow: var(--hft-shadow); }

.hft-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  background: #fff;
}
.hft-th {
  background: #f8f9ff;
  padding: 13px 14px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--hft-text-2);
  border-bottom: 1px solid var(--hft-border);
  white-space: nowrap;
}
.hft-sortable { cursor: pointer; user-select: none; }
.hft-sortable:hover { color: var(--hft-primary); background: #f0f0ff; }
.hft-sort-arrow { opacity: .4; font-size: 10px; }
.hft-sort-arrow.active { opacity: 1; color: var(--hft-primary); }

.hft-row { border-bottom: 1px solid var(--hft-border); transition: background .15s; }
.hft-row:hover { background: #fafbff; }
.hft-row--featured { background: #fafaff; }
.hft-row--featured td:first-child { border-left: 3px solid var(--hft-primary); }
.hft-row[style*="display:none"] { display: none !important; }

.hft-td { padding: 14px 14px; vertical-align: middle; }
.hft-td--name { display: flex; align-items: center; gap: 12px; min-width: 180px; }
.hft-featured-badge {
  display: block;
  background: linear-gradient(90deg,#f59e0b,#ef4444);
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 20px;
  white-space: nowrap;
  margin-bottom: 4px;
  letter-spacing: .3px;
}
.hft-logo { max-height: 32px; max-width: 80px; object-fit: contain; flex-shrink: 0; }
.hft-provider-name { font-weight: 700; color: var(--hft-text); text-decoration: none; font-size: 14px; }
.hft-provider-name:hover { color: var(--hft-primary); }
.hft-tagline { font-size: 11px; color: var(--hft-text-2); margin-top: 2px; }
.hft-geo { font-size: 12px; }

.hft-stars { color: #f59e0b; font-size: 14px; letter-spacing: 1px; }
.hft-rating-num { font-size: 11px; color: var(--hft-text-2); display: block; margin-top: 2px; }

.hft-td--verified { white-space: nowrap; }
.hft-verified { font-size: 11px; font-weight: 600; border-radius: 20px; padding: 3px 10px; display: inline-block; }
.hft-verified--fresh { background: #d1fae5; color: #065f46; }
.hft-verified--aging { background: #fef3c7; color: #92400e; }
.hft-verified--stale { background: #fee2e2; color: #991b1b; }
.hft-unverified { font-size: 11px; background: #f3f4f6; color: #6b7280; padding: 3px 10px; border-radius: 20px; display: inline-block; }

.hft-cta-btn {
  display: inline-block;
  background: var(--hft-primary);
  color: #fff !important;
  padding: 8px 16px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s, transform .15s;
}
.hft-cta-btn:hover { background: var(--hft-primary-d); transform: translateY(-1px); }

.hft-disclosure { font-size: 10px; color: var(--hft-text-2); margin-top: 4px; }

.hft-table-footer { padding: 16px 0; text-align: center; }
.hft-data-note { font-size: 12px; color: var(--hft-text-2); }
.hft-empty { text-align: center; padding: 40px; color: var(--hft-text-2); font-size: 15px; }

/* =====================================================
   METHODOLOGY
===================================================== */
.hft-methodology { padding: 70px 20px; background: #fff; }
.hft-method-inner { max-width: 1100px; margin: 0 auto; }
.hft-method-inner .hft-section-title { text-align: center; margin-bottom: 10px; }
.hft-method-inner .hft-section-desc { text-align: center; margin-bottom: 40px; }
.hft-method-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 20px; }
.hft-method-card { background: var(--hft-bg); border: 1px solid var(--hft-border); border-radius: 12px; padding: 24px; }
.hft-method-icon { font-size: 32px; margin-bottom: 12px; }
.hft-method-title { font-size: 15px; font-weight: 700; color: var(--hft-text); margin: 0 0 6px; }
.hft-method-desc { font-size: 13px; color: var(--hft-text-2); margin: 0; line-height: 1.5; }

/* =====================================================
   LEAD CAPTURE
===================================================== */
.hft-lead-section {
  background: linear-gradient(135deg,#4f46e5,#06b6d4);
  padding: 70px 20px;
  text-align: center;
  color: #fff;
}
.hft-lead-inner { max-width: 620px; margin: 0 auto; }
.hft-lead-section h2 { font-size: 30px; font-weight: 800; margin: 0 0 12px; }
.hft-lead-section p { font-size: 16px; color: rgba(255,255,255,.85); margin: 0 0 28px; }

.hft-lead-form-wrap { width: 100%; }
.hft-lead-title { font-size: 22px; font-weight: 800; color: var(--hft-text); margin: 0 0 6px; }
.hft-lead-desc { font-size: 14px; color: var(--hft-text-2); margin: 0 0 16px; }

.hft-lead-fields { display: flex; gap: 10px; flex-wrap: wrap; }
.hft-lead-input {
  flex: 1;
  min-width: 160px;
  padding: 13px 16px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.15);
  color: #fff;
  font-size: 14px;
  backdrop-filter: blur(6px);
  transition: border-color .15s;
}
.hft-lead-input::placeholder { color: rgba(255,255,255,.6); }
.hft-lead-input:focus { outline: none; border-color: #fff; background: rgba(255,255,255,.2); }

/* Inline form (non-hero) */
.hft-lead-form--modal .hft-lead-input,
.hft-lead-form-wrap:not(.hft-lead-form--modal) .hft-lead-input {
  background: #fff;
  color: var(--hft-text);
  border-color: var(--hft-border);
}
.hft-lead-form-wrap:not(.hft-lead-form--modal) .hft-lead-input::placeholder { color: #9ca3af; }

.hft-lead-submit {
  padding: 13px 24px;
  background: #fff;
  color: var(--hft-primary);
  font-weight: 800;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
  white-space: nowrap;
  transition: all .2s;
  box-shadow: 0 4px 14px rgba(0,0,0,.15);
}
.hft-lead-submit:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.2); }

/* section context — dark bg submit becomes gradient */
.hft-lead-section .hft-lead-submit { background: #fff; color: var(--hft-primary); }

.hft-lead-message { margin-top: 12px; padding: 12px 16px; border-radius: 8px; font-size: 14px; font-weight: 600; }
.hft-lead-message.success { background: #d1fae5; color: #065f46; }
.hft-lead-message.error   { background: #fee2e2; color: #991b1b; }

.hft-lead-privacy { font-size: 11px; color: rgba(255,255,255,.6); margin-top: 10px; }

/* =====================================================
   MODAL
===================================================== */
.hft-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  z-index: 99999;
  opacity: 0; pointer-events: none;
  transition: opacity .25s;
}
.hft-modal-overlay.active { opacity: 1; pointer-events: all; }

.hft-modal {
  background: #fff;
  border-radius: 16px;
  padding: 40px 36px;
  max-width: 480px;
  width: 90%;
  text-align: center;
  position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  transform: scale(.95) translateY(20px);
  transition: transform .3s;
}
.hft-modal-overlay.active .hft-modal { transform: scale(1) translateY(0); }

.hft-modal-close {
  position: absolute; top: 14px; right: 16px;
  background: none; border: none; font-size: 20px;
  cursor: pointer; color: #9ca3af; line-height: 1;
  transition: color .15s;
}
.hft-modal-close:hover { color: var(--hft-text); }
.hft-modal-icon { font-size: 48px; margin-bottom: 12px; }
.hft-modal-title { font-size: 24px; font-weight: 800; color: var(--hft-text); margin: 0 0 8px; }
.hft-modal-desc { font-size: 14px; color: var(--hft-text-2); margin: 0 0 20px; line-height: 1.5; }
.hft-modal-skip { margin-top: 14px; font-size: 12px; color: var(--hft-text-2); }
.hft-modal-skip a { color: var(--hft-text-2); text-decoration: underline; }
.hft-modal-skip a:hover { color: var(--hft-text); }

/* Modal has dark bg styling for its inputs */
.hft-lead-form--modal .hft-lead-fields { flex-direction: column; }
.hft-lead-form--modal .hft-lead-input { background: var(--hft-bg); color: var(--hft-text); border-color: var(--hft-border); min-width: unset; width: 100%; }
.hft-lead-form--modal .hft-lead-input::placeholder { color: #9ca3af; }
.hft-lead-form--modal .hft-lead-submit { background: var(--hft-primary); color: #fff; width: 100%; }
.hft-lead-form--modal .hft-lead-submit:hover { background: var(--hft-primary-d); }
.hft-lead-form--modal .hft-lead-privacy { color: var(--hft-text-2); }

/* =====================================================
   RESPONSIVE
===================================================== */
@media (max-width: 768px) {
  .hft-hero { padding: 50px 16px 80px; }
  .hft-hero-stats { gap: 20px; }
  .hft-stat strong { font-size: 22px; }
  .hft-filters { flex-direction: column; }
  .hft-filter-group { min-width: unset; width: 100%; }
  .hft-th, .hft-td { padding: 10px 10px; font-size: 12px; }
  .hft-lead-fields { flex-direction: column; }
  .hft-lead-input, .hft-lead-submit { width: 100%; }
  .hft-hero-cta-group { flex-direction: column; align-items: center; }
  .hft-cards-grid { grid-template-columns: 1fr; }
}
