/* ============== CONTRACTING PAGE ============== */

/* PHILOSOPHY BLOCK */
.con-philosophy {
  position: relative;
  z-index: 2;
  padding: 4rem 2rem;
}
.philosophy-block {
  position: relative;
  background: linear-gradient(135deg, rgba(201,165,90,0.08), rgba(245, 237, 220, 0.08));
  border: 1px solid rgba(201,165,90,0.2);
  border-radius: var(--radius-xl);
  padding: 3.5rem 3rem;
  text-align: center;
  overflow: hidden;
}
.philosophy-mark {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 140px;
  font-weight: 700;
  color: var(--gold);
  opacity: 0.12;
  line-height: 0.4;
  margin-bottom: -0.5rem;
}
.philosophy-h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 1rem 0 1.25rem;
}
.philosophy-h2 em {
  font-style: italic;
  color: var(--gold);
}
.philosophy-text {
  font-size: 15.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.85;
  max-width: 640px;
  margin: 0 auto 2.5rem;
}
.philosophy-points {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 580px;
  margin: 0 auto;
  text-align: left;
}
.pp-row {
  display: flex;
  gap: 0.875rem;
  align-items: flex-start;
  padding: 1rem 1.25rem;
  background: rgba(245, 237, 220, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
}
.pp-row i {
  font-size: 22px;
  color: var(--gold);
  flex-shrink: 0;
  margin-top: 1px;
}
.pp-row span {
  font-size: 13.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.7;
}
.pp-row strong {
  display: inline;
  color: var(--text);
  font-weight: 500;
  margin-right: 4px;
}
@media (max-width: 700px) {
  .philosophy-block { padding: 2.5rem 1.5rem; }
}

.con-hero {
  position: relative;
  z-index: 2;
  padding: 7rem 2rem 4rem;
}
.con-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 3rem;
  align-items: center;
}
.gold-badge {
  background: rgba(201,165,90,0.12);
  border-color: rgba(201,165,90,0.3);
  color: var(--gold-light);
}
.con-h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(36px, 5.5vw, 60px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 1rem 0;
}
.con-h1 em {
  font-style: italic;
  color: var(--gold);
}
.con-sub {
  font-size: 16px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.85;
  margin-bottom: 2rem;
  max-width: 540px;
}
.con-cta-row {
  display: flex;
  gap: 0.875rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}
.con-trust {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.trust-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text2);
  font-weight: 400;
}
.trust-item i {
  color: var(--cyan);
  font-size: 17px;
}

/* HERO CARD */
.con-hero-card {
  position: relative;
  background: linear-gradient(145deg, rgba(0, 0, 0, 0.25) 0%, rgba(107, 39, 55,0.08) 100%);
  border: 1px solid rgba(201, 165, 90, 0.18);
  border-radius: var(--radius-xl);
  padding: 2.5rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow: hidden;
}
.hc-watermark {
  position: absolute;
  bottom: -30px;
  right: -20px;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 180px;
  font-weight: 700;
  color: var(--gold);
  opacity: 0.05;
  line-height: 1;
  pointer-events: none;
}
.hc-badge {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background: rgba(201,165,90,0.15);
  border: 1px solid rgba(201,165,90,0.3);
  color: var(--gold-light);
  font-size: 11px;
  font-weight: 500;
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.con-hero-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 1.5rem;
  letter-spacing: -0.01em;
  position: relative;
}
.hc-rows {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
}
.hc-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--glass-border);
}
.hc-row:last-child { border-bottom: none; padding-bottom: 0; }
.hc-num {
  font-family: 'Playfair Display', serif;
  font-size: 30px;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  min-width: 70px;
  letter-spacing: -0.02em;
}
.hc-row strong {
  display: block;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 2px;
}
.hc-row span {
  font-size: 12px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.55;
}

/* HOW IT WORKS */
.con-how {
  position: relative;
  z-index: 2;
  padding: 5rem 2rem;
}
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  position: relative;
}
.step-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 1.75rem;
  position: relative;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.25s var(--ease);
}
.step-card:hover {
  border-color: var(--glass-border-strong);
  transform: translateY(-4px);
}
.step-line {
  position: absolute;
  top: 36px;
  right: -8px;
  width: 16px;
  height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
}
.step-card:last-child .step-line {
  display: none;
}
.step-num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(201,165,90,0.15);
  border: 1px solid rgba(201,165,90,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Playfair Display', serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--gold);
  margin-bottom: 1rem;
}
.step-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 600;
  margin-bottom: 0.625rem;
  letter-spacing: -0.005em;
}
.step-card p {
  font-size: 13px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 1rem;
}
.step-time {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--cyan);
  letter-spacing: 0.06em;
  font-weight: 500;
  text-transform: uppercase;
  padding: 4px 10px;
  background: rgba(107, 39, 55,0.08);
  border: 1px solid rgba(107, 39, 55,0.2);
  border-radius: 999px;
}
.step-time i { font-size: 13px; }

/* TIERS */
.con-tiers {
  position: relative;
  z-index: 2;
  padding: 5rem 2rem;
}
.tier-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 1000px;
  margin: 0 auto;
}
.tier-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.3s var(--ease);
  position: relative;
}
.tier-card:hover {
  border-color: var(--glass-border-strong);
  transform: translateY(-4px);
}
.tier-featured {
  background: linear-gradient(145deg, rgba(201,165,90,0.1), rgba(201,165,90,0.02));
  border-color: rgba(201,165,90,0.3);
}
.tier-featured:hover {
  border-color: rgba(201,165,90,0.5);
  box-shadow: 0 20px 60px rgba(201,165,90,0.15);
}
.tier-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: #08080c;
  font-size: 10.5px;
  font-weight: 600;
  padding: 5px 14px;
  border-radius: 999px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.tier-eyebrow {
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--purple-light);
  margin-bottom: 0.5rem;
}
.tier-eyebrow.gold { color: var(--gold-light); }
.tier-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 0.75rem;
  letter-spacing: -0.01em;
}
.tier-desc {
  font-size: 14px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.75;
  margin-bottom: 1.5rem;
}
.tier-features {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-top: 1.25rem;
  margin-bottom: 1.5rem;
  border-top: 1px solid var(--glass-border);
}
.tf-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--text);
  font-weight: 400;
}
.tf-row i {
  color: var(--cyan);
  font-size: 17px;
  flex-shrink: 0;
}
.tier-featured .tf-row i { color: var(--gold); }
.tier-best-for {
  padding: 1rem 1.125rem;
  background: rgba(245, 237, 220, 0.04);
  border-radius: var(--radius-sm);
  font-size: 12.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.6;
}
.tier-best-for strong {
  color: var(--gold-light);
  font-weight: 500;
}

/* CARRIERS */
.con-carriers {
  position: relative;
  z-index: 2;
  padding: 5rem 2rem;
}

/* INCLUDED GRID */
.con-included {
  position: relative;
  z-index: 2;
  padding: 5rem 2rem;
}
.included-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}
.inc-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 1.75rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.25s var(--ease);
}
.inc-card:hover {
  border-color: var(--glass-border-strong);
  transform: translateY(-3px);
}
.inc-card i {
  font-size: 26px;
  color: var(--purple-light);
  display: block;
  margin-bottom: 1rem;
}
.inc-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 600;
  margin-bottom: 0.5rem;
  letter-spacing: -0.005em;
}
.inc-card p {
  font-size: 13px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.7;
}

/* FORM */
.con-form {
  position: relative;
  z-index: 2;
  padding: 5rem 2rem;
  scroll-margin-top: 80px;
}
.form-shell-con {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 3rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.form-head-con {
  text-align: center;
  margin-bottom: 2rem;
}
.form-head-con .sec-sub {
  margin: 0 auto;
}
.con-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.con-form-fields .form-field {
  display: flex;
  flex-direction: column;
}
.con-form-fields .form-field.full { grid-column: 1 / -1; }
.con-form-fields label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.con-form-fields input[type="text"],
.con-form-fields input[type="email"],
.con-form-fields input[type="tel"],
.con-form-fields select,
.con-form-fields textarea {
  background: rgba(245, 237, 220, 0.04);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 13.5px;
  padding: 0.7rem 0.875rem;
  transition: all 0.2s var(--ease);
}
.con-form-fields input:focus,
.con-form-fields select:focus,
.con-form-fields textarea:focus {
  outline: none;
  border-color: var(--purple);
  background: rgba(245, 237, 220, 0.06);
  box-shadow: 0 0 0 3px rgba(201, 165, 90, 0.18);
}
.con-form-fields select {
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A09890' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.875rem center;
  padding-right: 2.25rem;
}
.con-form-fields select option { background: var(--bg2); }
.con-form-fields textarea {
  resize: vertical;
  font-family: 'DM Sans', sans-serif;
}
.con-submit {
  width: 100%;
  justify-content: center;
  margin-top: 0.5rem;
}

.con-success {
  text-align: center;
  padding: 2rem 0;
}
.con-success h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 0.75rem;
}
.con-success p {
  font-size: 14.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.8;
  max-width: 480px;
  margin: 0 auto 2rem;
}

/* FAQ - reuse from contact page */
.con-faq {
  position: relative;
  z-index: 2;
  padding: 4rem 2rem 6rem;
}
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.faq-item {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.2s var(--ease);
}
.faq-item:hover {
  border-color: var(--glass-border-strong);
}
.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.125rem 1.375rem;
  cursor: pointer;
  list-style: none;
  font-size: 14.5px;
  font-weight: 500;
  color: var(--text);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary i {
  font-size: 18px;
  color: var(--gold);
  transition: transform 0.25s var(--ease);
}
.faq-item[open] summary i {
  transform: rotate(45deg);
}
.faq-item p {
  padding: 0 1.375rem 1.25rem;
  font-size: 13.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.8;
}

@media (max-width: 900px) {
  .con-hero-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .steps-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
  .step-line { display: none; }
  .tier-grid { grid-template-columns: 1fr; }
  .form-shell-con { padding: 2rem 1.5rem; }
  .con-form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 500px) {
  .steps-grid { grid-template-columns: 1fr; }
}

/* ============== CONTRACTING CONTACT-US BLOCK ============== */
.con-contact-block {
  position: relative;
  background: linear-gradient(135deg, rgba(201,165,90,0.1), rgba(245, 237, 220, 0.05));
  border: 1px solid rgba(201,165,90,0.25);
  border-radius: var(--radius-xl);
  padding: 3rem 2.5rem;
  text-align: center;
  overflow: hidden;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.con-contact-block::before {
  content: '';
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, var(--gold-glow), transparent 70%);
  opacity: 0.25;
  pointer-events: none;
}
.ccb-icon {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), var(--gold-dim));
  color: #08080c;
  font-size: 38px;
  margin-bottom: 1.5rem;
  box-shadow: 0 0 40px var(--gold-glow);
}
.ccb-content {
  position: relative;
  z-index: 1;
}
.ccb-text {
  font-size: 15px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.8;
  max-width: 560px;
  margin: 0.75rem auto 1.75rem;
}
.ccb-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.ccb-list-wrap {
  max-width: 480px;
  margin: 0 auto;
  padding: 1.5rem;
  background: rgba(245, 237, 220, 0.04);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  text-align: left;
}
.ccb-list-head {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 0.75rem;
  letter-spacing: 0.01em;
}
.ccb-list {
  list-style: none;
  padding: 0;
  margin: 0 0 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.ccb-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.55;
}
.ccb-list li i {
  font-size: 15px;
  color: var(--cyan);
  margin-top: 1px;
  flex-shrink: 0;
}
.ccb-list-fine {
  font-size: 11.5px;
  color: var(--text3);
  font-style: italic;
  margin: 0;
  padding-top: 0.5rem;
  border-top: 1px solid var(--glass-border);
}

@media (max-width: 700px) {
  .con-contact-block {
    padding: 2rem 1.5rem;
  }
  .ccb-icon {
    width: 68px;
    height: 68px;
    font-size: 30px;
  }
  .ccb-actions {
    flex-direction: column;
  }
  .ccb-actions a {
    width: 100%;
    justify-content: center;
  }
}
