/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--font-body);
  font-weight:600;
  font-size:0.95rem;
  padding:12px 26px;
  border-radius:8px;
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.btn:hover{
  transform:translateY(-1px);
  text-decoration:none;
}

.btn-primary{
  background:linear-gradient(135deg, var(--std-blue), var(--std-teal));
  color:#FFFFFF;
  box-shadow:0 4px 14px rgba(74,144,217,0.35);
}

.btn-outline{
  background:transparent;
  border-color:var(--std-navy);
  color:var(--std-navy);
}

.btn-platinum{
  background:linear-gradient(135deg, var(--ent-graphite-alt), var(--ent-graphite));
  color:var(--ent-text);
  box-shadow:0 4px 14px rgba(61,66,80,0.35);
}

.btn-block{
  display:block;
  width:100%;
  text-align:center;
}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(135deg, var(--std-bg-start), var(--std-bg-end));
  padding:104px 0 80px;
}

.hero .container{
  display:flex;
  align-items:center;
  gap:48px;
}

.hero-content{
  flex:1;
}

.hero-logo{
  flex-shrink:0;
  width:180px;
  height:172px;
}

.hero h1{
  color:var(--std-navy);
  margin-bottom:0.3em;
}

.hero .tagline{
  font-size:1.15rem;
  color:var(--text-muted);
  margin-bottom:1.2em;
}

.hero .lead{
  max-width:560px;
  margin-bottom:1.6em;
}

.hero-ctas{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.version-row{
  margin-top:28px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ---------- Badges ---------- */
.badge{
  display:inline-block;
  font-size:0.75rem;
  font-weight:700;
  padding:3px 10px;
  border-radius:5px;
  background:#FFFFFF;
  border:1px solid var(--std-border);
  color:var(--std-navy);
}

.badge-gray{
  background:#EFEFF1;
  color:var(--text-muted);
  border-color:var(--border);
}

.badge-platinum{
  background:linear-gradient(135deg, var(--ent-graphite-alt), var(--ent-graphite));
  color:var(--ent-text);
  border:none;
}

/* ---------- Feature grid ---------- */
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:32px;
}

.feature-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:10px;
  padding:24px;
}

.feature-card h3{
  color:var(--std-navy);
  margin-bottom:0.4em;
}

.feature-card p{
  font-size:1rem;        /* 16px - keep it readable, never squint-text */
  line-height:1.7;       /* a bit more breathing room between lines */
  color:var(--text);
  margin:0;
}

.feature-card .icon{
  font-size:1.8rem;
  margin-bottom:0.4em;
  display:block;
}

/* ---------- Tabs strip (decorative) ---------- */
.tabs-strip{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:24px 0;
}

.tabs-strip span{
  background:#FFFFFF;
  border:1px solid var(--border);
  border-radius:6px;
  padding:6px 14px;
  font-size:0.85rem;
  color:var(--text);
}

/* ---------- Pricing cards ---------- */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:32px;
  align-items:stretch;
}

.price-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:14px;
  padding:28px;
  display:flex;
  flex-direction:column;
}

.price-card h3{
  margin-bottom:0.2em;
}

.price-card .price{
  font-family:var(--font-heading);
  font-size:2.1rem;
  margin:0.3em 0 0.6em 0;
}

.price-card .price small{
  font-size:0.95rem;
  font-weight:400;
  color:var(--text-muted);
}

.price-card ul{
  list-style:none;
  padding-left:0;
  margin:0 0 24px 0;
  flex:1;
}

.price-card ul li{
  padding:5px 0 5px 26px;
  position:relative;
  font-size:0.92rem;
}

.price-card ul li::before{
  content:"\2713";
  position:absolute;
  left:0;
  color:var(--std-teal);
  font-weight:700;
}

.price-card.enterprise{
  position:relative;
  border:3px solid transparent;
  border-radius:14px;
  background:
    linear-gradient(var(--card-bg), var(--card-bg)) padding-box,
    linear-gradient(135deg, var(--ent-border-1) 0%, var(--ent-border-2) 22%, var(--ent-border-3) 45%, var(--ent-border-4) 60%, var(--ent-border-5) 80%, var(--ent-border-3) 100%) border-box;
}

.price-card.enterprise ul li::before{
  color:var(--ent-graphite-alt);
}

.price-card.enterprise .price-card-badge{
  position:absolute;
  top:-14px;
  right:24px;
}

.price-card.standard{
  border-color:var(--std-border);
}

/* ---------- Feature comparison table ---------- */
.table-wrap{
  overflow-x:auto;
  margin:24px 0;
}

table{
  width:100%;
  border-collapse:collapse;
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  font-size:0.92rem;
}

th, td{
  text-align:left;
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}

th:not(:first-child), td:not(:first-child){
  text-align:center;
}

th{
  background:#FAFAF7;
  font-weight:700;
  font-size:0.8rem;
  text-transform:uppercase;
  letter-spacing:0.4px;
  color:var(--text-muted);
}

tr:last-child td{ border-bottom:none; }

td.yes{ color:var(--std-teal); font-weight:700; }
td.no{ color:var(--text-muted); }

/* ---------- Cards / tips / warnings (shared with docs) ---------- */
.card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:6px;
  padding:14px 18px;
  margin:14px 0;
}

.tip, .warning{
  border-radius:6px;
  padding:12px 16px;
  margin:16px 0;
  border-left:4px solid;
  font-size:0.94rem;
}

.tip{
  background:var(--tip-bg);
  border-left-color:var(--tip-border);
}

.warning{
  background:var(--warn-bg);
  border-left-color:var(--warn-border);
}

.tip strong.label, .warning strong.label{
  display:block;
  margin-bottom:4px;
  font-size:0.78rem;
  text-transform:uppercase;
  letter-spacing:0.5px;
}

.tip strong.label{ color:#6B4F0E; }
.warning strong.label{ color:#A23C3C; }

/* ---------- FAQ ---------- */
details{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:6px;
  padding:11px 16px;
  margin-bottom:8px;
}

details summary{
  font-weight:600;
  cursor:pointer;
}

details[open] summary{
  margin-bottom:8px;
}

/* ---------- Simple page header (non-home pages) ---------- */
.page-hero{
  background:linear-gradient(135deg, var(--std-bg-start), var(--std-bg-end));
  padding:48px 0;
  text-align:center;
}

.page-hero h1{
  color:var(--std-navy);
  margin-bottom:0.3em;
}

/* ---------- Steps ---------- */
ol.steps{
  list-style:none;
  padding-left:0;
  counter-reset: step;
}

ol.steps > li{
  position:relative;
  padding-left:2.6em;
  margin-bottom:16px;
}

ol.steps > li::before{
  counter-increment: step;
  content: counter(step);
  position:absolute;
  left:0;
  top:-1px;
  width:1.7em;
  height:1.7em;
  border-radius:50%;
  background:var(--std-teal);
  color:#FFFFFF;
  font-weight:700;
  font-size:0.8rem;
  display:flex;
  align-items:center;
  justify-content:center;
}

ol.steps > li > strong{
  display:block;
  margin-bottom:2px;
}

/* ---------- Contact form ---------- */
.form-field{
  margin-bottom:18px;
  display:flex;
  flex-direction:column;
}

.form-field label{
  font-weight:600;
  margin-bottom:6px;
  font-size:0.9rem;
}

.form-field input,
.form-field textarea{
  font-family:var(--font-body);
  font-size:0.95rem;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:6px;
}

.form-field textarea{
  resize:vertical;
  min-height:120px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .feature-grid{
    grid-template-columns:repeat(2, 1fr);
  }

  .pricing-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 800px){
  .hero .container{
    flex-direction:column;
    text-align:center;
  }

  .hero-ctas{
    justify-content:center;
  }

  .hero-logo{
    width:120px;
    height:115px;
  }

  .feature-grid{
    grid-template-columns:1fr;
  }
}
