/* ═══════════════════════════════════════
   CONTACT PAGE — contact.css
   Save to: clicklink-website/css/contact.css
═══════════════════════════════════════ */

/* ── HERO ── */
.con-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.con-hero-bg {
  position: absolute; inset: 0;
  background-image: url('../images/contact-hero.jpg');
  background-size: cover;
  background-position: center;
  animation: conZoom 18s ease-in-out infinite alternate;
}
@keyframes conZoom { from{transform:scale(1.03);} to{transform:scale(1.10);} }
.con-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(110deg, rgba(0,18,40,.95) 0%, rgba(0,35,70,.85) 50%, rgba(0,15,35,.7) 100%);
}
.con-hero-content {
  position: relative; z-index: 2;
  max-width: 1200px; margin: 0 auto; width: 100%;
  padding: clamp(90px,12vw,120px) clamp(20px,5vw,56px) clamp(60px,8vw,80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px,5vw,64px);
  align-items: start;
}
@media(max-width:900px){ .con-hero-content { grid-template-columns: 1fr; } }

/* hero left */
.con-pill {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  border-radius: 30px; padding: 5px 14px; margin-bottom: 18px;
}
.con-pill-dot { width: 6px; height: 6px; border-radius: 50%; background: #e00611; }
.con-pill span { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.75); }
.con-hero-title {
  font-size: clamp(26px,4.5vw,46px); font-weight: 800; color: #fff;
  line-height: 1.12; margin-bottom: 16px; letter-spacing: -.5px;
}
.con-hero-title span { color: #e00611; }
.con-hero-desc {
  font-size: clamp(13px,1.4vw,15px); color: rgba(255,255,255,.72);
  line-height: 1.85; margin-bottom: 28px; word-wrap: break-word;
}
.con-hero-channels { display: flex; flex-direction: column; gap: 10px; }
.con-channel-card {
  display: flex; align-items: center; gap: 14px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px; padding: 14px 18px;
  text-decoration: none; color: inherit;
  transition: background .2s, border-color .2s;
}
.con-channel-card:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); }
.con-channel-icon { font-size: 22px; flex-shrink: 0; }
.con-channel-label { font-size: 12px; font-weight: 800; color: #fff; margin-bottom: 2px; }
.con-channel-val   { font-size: 11px; color: rgba(255,255,255,.55); }

/* Phone numbers — same card style as channel cards */
.con-phone-link {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px; padding: 12px 18px;
  text-decoration: none;
  font-family: 'Sora', sans-serif;
  font-size: 14px; font-weight: 700; color: #fff;
  transition: background .2s, border-color .2s;
}
.con-phone-link:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); }

/* hero right — quick form */
.con-quick-form {
  background: #fff; border-radius: 20px;
  padding: clamp(24px,4vw,36px);
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.con-qf-title { font-size: 18px; font-weight: 800; color: #002d59; margin-bottom: 4px; }
.con-qf-sub   { font-size: 12px; color: #5a6a82; margin-bottom: 22px; }

/* SHARED FORM ELEMENTS */
.con-form-group { margin-bottom: 14px; }
.con-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 0; }
@media(max-width:520px){ .con-form-row { grid-template-columns: 1fr; } }
.con-label {
  display: block; font-size: 10px; font-weight: 700;
  color: #5a6a82; letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 6px;
}
.con-input {
  width: 100%; background: #f8fafd; border: 1.5px solid #dde4ef;
  border-radius: 8px; padding: 11px 14px; font-size: 13px;
  font-family: 'Sora', sans-serif; color: #002d59; outline: none;
  transition: border-color .2s; box-sizing: border-box;
}
.con-input::placeholder { color: #b0bcc8; }
.con-input:focus { border-color: #004a94; }
.con-select { appearance: none; cursor: pointer; }
.con-textarea { resize: vertical; min-height: 90px; }
.con-submit-btn {
  width: 100%; background: #e00611; color: #fff; border: none;
  padding: 13px; border-radius: 10px; font-size: 13px; font-weight: 700;
  cursor: pointer; font-family: 'Sora', sans-serif; margin-top: 4px;
  transition: background .2s;
}
.con-submit-btn:hover { background: #c0050e; }
.con-form-success {
  background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 12px;
  padding: 20px; text-align: center; margin-top: 14px;
}
.con-success-icon {
  width: 44px; height: 44px; background: #16a34a; color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 800; margin: 0 auto 12px;
}
.con-form-success h3 { font-size: 14px; font-weight: 800; color: #166534; margin-bottom: 5px; }
.con-form-success p  { font-size: 12px; color: #5a6a82; }

/* ── SECTIONS ── */
.con-section-inner { max-width: 1200px; margin: 0 auto; padding: 0 clamp(16px,5vw,56px); }
.con-pill-dark {
  display: inline-flex; align-items: center; gap: 7px;
  background: #f0f4fa; border: 1px solid #dde4ef;
  border-radius: 30px; padding: 5px 14px; margin-bottom: 14px;
}
.con-pill-dot-r { width: 6px; height: 6px; border-radius: 50%; background: #e00611; }
.con-pill-dark span { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #5a6a82; }
.con-section-title {
  font-size: clamp(22px,3.5vw,30px); font-weight: 800; color: #002d59;
  margin-bottom: 10px; line-height: 1.15;
}
.con-section-title span { color: #e00611; }
.con-section-sub {
  font-size: clamp(12px,1.4vw,14px); color: #5a6a82;
  line-height: 1.8; max-width: 100%; word-wrap: break-word; margin-bottom: 0;
}

/* ═══ DIGITAL SERVICES BUDGET PLANNER ═══ */
.con-tool-section {
  padding: clamp(48px,7vw,80px) 0;
  background: #f5f7fb;
  position: relative; overflow: hidden;
}
.con-tool-section::before {
  content: ''; position: absolute; top: -80px; right: -80px;
  width: 320px; height: 320px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.04); pointer-events: none;
}
.con-tool-header { margin-bottom: 36px; }
.con-tool-header .con-section-title { color: #fff; }
.con-tool-header .con-section-sub   { color: rgba(255,255,255,.65); }
.con-tool-header .con-pill-dark {
  background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.15);
}
.con-tool-header .con-pill-dark span { color: rgba(255,255,255,.7); }

/* TOOL WRAP */
.con-tool-wrap {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px; padding: clamp(24px,4vw,40px); min-height: 300px;
}
.con-tool-step { display: none; }
.con-tool-step.active { display: block; }

/* step header */
.con-tool-step-header {
  display: flex; align-items: center; gap: 16px; margin-bottom: 28px;
}
.con-step-num {
  width: 44px; height: 44px; border-radius: 50%;
  background: #e00611; color: #fff; font-size: 15px; font-weight: 800;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.con-step-title { font-size: 18px; font-weight: 800; color: #fff; }
.con-step-sub   { font-size: 12px; color: rgba(255,255,255,.55); margin-top: 2px; }

/* step 1 form */
.con-tool-form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 20px;
}
@media(max-width:600px){ .con-tool-form-grid { grid-template-columns: 1fr; } }
.con-label-dark {
  display: block; font-size: 10px; font-weight: 700;
  color: rgba(255,255,255,.5); letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 6px;
}
.con-input-dark {
  width: 100%; background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.15);
  border-radius: 8px; padding: 11px 14px; font-size: 13px;
  font-family: 'Sora', sans-serif; color: #fff; outline: none;
  transition: border-color .2s; box-sizing: border-box;
}
.con-input-dark::placeholder { color: rgba(255,255,255,.3); }
.con-input-dark:focus { border-color: rgba(255,255,255,.45); }

/* SERVICE GRID */
.con-service-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 14px;
}
.con-svc-tile {
  background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 20px 16px; cursor: pointer;
  text-align: center; transition: all .2s;
}
.con-svc-tile:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.3); transform: translateY(-2px); }
.con-svc-tile.selected { background: rgba(224,6,17,.2); border-color: #e00611; }
.con-svc-icon { font-size: 28px; margin-bottom: 10px; }
.con-svc-name { font-size: 13px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.con-svc-desc { font-size: 11px; color: rgba(255,255,255,.5); }

/* service questions */
.con-q-group { margin-bottom: 16px; }
.con-q-label {
  font-size: 13px; font-weight: 700; color: #fff; margin-bottom: 10px; display: block;
}
.con-q-options { display: flex; gap: 8px; flex-wrap: wrap; }
.con-q-option {
  padding: 8px 16px; border-radius: 20px;
  border: 1.5px solid rgba(255,255,255,.2); color: rgba(255,255,255,.7);
  font-size: 12px; font-weight: 600; cursor: pointer; background: transparent;
  font-family: 'Sora', sans-serif; transition: all .18s;
}
.con-q-option:hover { border-color: rgba(255,255,255,.5); color: #fff; }
.con-q-option.selected { background: #e00611; border-color: #e00611; color: #fff; }
.con-q-input {
  width: 100%; max-width: 420px; background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.15); border-radius: 8px;
  padding: 11px 14px; font-size: 13px; font-family: 'Sora', sans-serif;
  color: #fff; outline: none; box-sizing: border-box;
}
.con-q-input::placeholder { color: rgba(255,255,255,.3); }
.con-q-input:focus { border-color: rgba(255,255,255,.4); }

/* tool buttons */
.con-tool-btn {
  background: #e00611; color: #fff; border: none;
  padding: 12px 28px; border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: background .2s;
}
.con-tool-btn:hover { background: #c0050e; }
.con-tool-btn-outline {
  background: transparent; color: rgba(255,255,255,.8);
  border: 1.5px solid rgba(255,255,255,.3); padding: 12px 24px;
  border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: all .2s;
}
.con-tool-btn-outline:hover { border-color: rgba(255,255,255,.6); color: #fff; }

/* ── REPORT STEP 4 ── */
.con-report-header { margin-bottom: 28px; text-align: center; }
.con-report-title  { font-size: clamp(20px,3vw,26px); font-weight: 800; color: #fff; margin-bottom: 6px; }
.con-report-sub    { font-size: 13px; color: rgba(255,255,255,.6); margin-bottom: 10px; }
.con-report-notice {
  display: inline-block; background: rgba(224,6,17,.15); border: 1px solid rgba(224,6,17,.3);
  color: #ff9fa3; font-size: 11px; font-weight: 700; padding: 5px 16px;
  border-radius: 20px; letter-spacing: .5px;
}

/* score cards */
.con-report-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 14px; margin-bottom: 24px;
}
.con-score-card {
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px; padding: 18px;
}
.con-score-card-label { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.55); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 8px; }
.con-score-bar-wrap   { height: 6px; background: rgba(255,255,255,.1); border-radius: 4px; margin-bottom: 8px; overflow: hidden; }
.con-score-bar        { height: 100%; border-radius: 4px; transition: width 1s ease; }
.con-score-val        { font-size: 22px; font-weight: 800; color: #fff; }
.con-score-note       { font-size: 11px; color: rgba(255,255,255,.45); margin-top: 3px; }

/* insight boxes */
.con-insights { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.con-insight-item {
  background: rgba(255,255,255,.06); border-left: 3px solid #e00611;
  border-radius: 0 12px 12px 0; padding: 16px 18px;
  display: flex; gap: 12px; align-items: flex-start;
}
.con-insight-icon { font-size: 20px; flex-shrink: 0; }
.con-insight-title { font-size: 13px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.con-insight-text  { font-size: 12px; color: rgba(255,255,255,.6); line-height: 1.65; word-wrap: break-word; }

/* opportunity bands */
.con-opps { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
@media(max-width:600px){ .con-opps { grid-template-columns: 1fr; } }
.con-opp-band {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px; padding: 14px 16px;
}
.con-opp-band-head {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.con-opp-badge { font-size: 10px; font-weight: 800; padding: 3px 10px; border-radius: 10px; }
.con-opp-high { background: rgba(22,163,74,.2); color: #4ade80; }
.con-opp-med  { background: rgba(251,191,36,.2); color: #fbbf24; }
.con-opp-band-title { font-size: 12px; font-weight: 700; color: #fff; }
.con-opp-band-desc  { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.6; }

/* report CTA */
.con-report-cta {
  background: rgba(224,6,17,.12); border: 1px solid rgba(224,6,17,.25);
  border-radius: 16px; padding: 24px; display: flex;
  align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 8px;
}
.con-report-cta-text { flex: 1; min-width: 200px; }
.con-report-cta-text h3 { font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 5px; }
.con-report-cta-text p  { font-size: 12px; color: rgba(255,255,255,.6); line-height: 1.65; }
.con-report-cta-btns { display: flex; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }

/* WhatsApp info card */
.con-info-card-wa {
  cursor: pointer;
  border-color: #c3f0d0;
  background: #f0fdf4;
  transition: all .2s;
}
.con-info-card-wa:hover { border-color: #25d366; box-shadow: 0 4px 16px rgba(37,211,102,.15); }
.con-wa-val { display: flex; align-items: center; gap: 8px; }
.con-wa-chip {
  background: #25d366; color: #fff;
  font-size: 10px; font-weight: 800;
  padding: 2px 9px; border-radius: 10px;
  letter-spacing: .5px;
}

/* ── INFO SECTION ── */
.con-info-section { padding: clamp(48px,7vw,80px) 0; background: #f8fafd; }
.con-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px,5vw,64px);
  align-items: start;
}
@media(max-width:768px){ .con-info-grid { grid-template-columns: 1fr; } }

/* info cards */
.con-info-cards { display: flex; flex-direction: column; gap: 12px; margin-bottom: 22px; }
.con-info-card {
  display: flex; align-items: flex-start; gap: 14px;
  background: #fff; border: 1px solid #dde4ef; border-radius: 12px; padding: 16px;
  transition: box-shadow .2s;
}
.con-info-card:hover { box-shadow: 0 4px 16px rgba(0,45,89,.07); }
.con-info-card-icon  { font-size: 22px; flex-shrink: 0; }
.con-info-card-label { font-size: 10px; font-weight: 700; color: #5a6a82; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 3px; }
.con-info-card-val   { font-size: 13px; color: #002d59; font-weight: 600; line-height: 1.5; }
.con-info-card-val a { color: #e00611; }

/* FAQ */
.con-faq-list { display: flex; flex-direction: column; gap: 10px; }
.con-faq-item { border: 1px solid #dde4ef; border-radius: 12px; overflow: hidden; background: #fff; }
.con-faq-q {
  width: 100%; background: none; border: none; padding: 15px 18px;
  font-size: 13px; font-weight: 700; color: #002d59; text-align: left;
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  font-family: 'Sora', sans-serif; transition: background .2s;
}
.con-faq-q:hover { background: #f8fafd; }
.con-faq-arrow { font-size: 10px; transition: transform .2s; flex-shrink: 0; margin-left: 10px; }
.con-faq-item.open .con-faq-arrow { transform: rotate(180deg); }
.con-faq-item.open .con-faq-q     { background: #f8fafd; color: #e00611; }
.con-faq-a {
  display: none; padding: 12px 18px 16px;
  font-size: 12px; color: #5a6a82; line-height: 1.75;
  border-top: 1px solid #f0f4fa; word-wrap: break-word;
}
.con-faq-item.open .con-faq-a { display: block; }

/* ══════════════════════════════════════
   DIGITAL GROWTH AUDIT TOOL — DGA
══════════════════════════════════════ */

/* Step progress indicator */
.dga-progress {
  display: flex; align-items: flex-start; margin-bottom: 28px;
}
.dga-prog-step { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.dga-prog-dot {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,255,255,.12); border: 2px solid rgba(255,255,255,.18);
  transition: all .3s;
}
.dga-prog-step.active .dga-prog-dot { background: #e00611; border-color: #e00611; box-shadow: 0 0 0 5px rgba(224,6,17,.2); }
.dga-prog-step.done   .dga-prog-dot { background: #4ade80; border-color: #4ade80; }
.dga-prog-label {
  font-size: 9px; font-weight: 700; color: rgba(255,255,255,.35);
  letter-spacing: .8px; text-transform: uppercase; white-space: nowrap; transition: color .3s;
}
.dga-prog-step.active .dga-prog-label { color: rgba(255,255,255,.85); }
.dga-prog-step.done   .dga-prog-label { color: #4ade80; }
.dga-prog-line {
  flex: 1; height: 2px; background: rgba(255,255,255,.1);
  margin: 13px 8px 0; transition: background .3s; min-width: 20px;
}
.dga-prog-line.done { background: #4ade80; }

/* Error message */
.dga-err {
  color: #f87171; font-size: 12px; font-weight: 600; margin-bottom: 12px;
  background: rgba(248,113,113,.08); border: 1px solid rgba(248,113,113,.2);
  border-radius: 8px; padding: 8px 14px;
}

/* Analysing step */
.dga-analyze-wrap {
  display: flex; flex-direction: column; align-items: center;
  padding: clamp(16px,4vw,32px) 0; text-align: center;
}
.dga-analyze-icon {
  font-size: 52px; margin-bottom: 18px;
  animation: dgaPulse 1.6s ease-in-out infinite;
}
@keyframes dgaPulse { 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(1.12);opacity:.85;} }

.dga-analyze-title {
  font-size: clamp(17px,2.5vw,22px); font-weight: 800; color: #fff; margin-bottom: 6px;
}
.dga-analyze-sub {
  font-size: 13px; color: rgba(255,255,255,.5); margin-bottom: 22px; min-height: 22px; transition: all .3s;
}
.dga-analyze-bar-wrap {
  width: 100%; max-width: 460px; height: 8px;
  background: rgba(255,255,255,.1); border-radius: 8px; overflow: hidden; margin-bottom: 6px;
}
.dga-analyze-bar {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, #004a94, #e00611);
  border-radius: 8px; transition: width .42s ease;
}
.dga-analyze-pct { font-size: 11px; color: rgba(255,255,255,.4); margin-bottom: 24px; }
.dga-analyze-checks {
  display: flex; flex-direction: column; gap: 9px;
  width: 100%; max-width: 380px; text-align: left;
}
.dga-check-item {
  font-size: 13px; color: rgba(255,255,255,.45);
  display: flex; align-items: center; gap: 10px; transition: color .3s;
}
.dga-chk-icon { font-size: 15px; flex-shrink: 0; }

/* Animated ellipsis */
.dga-dots::after { content: ''; animation: dgaDots 1.4s infinite; }
@keyframes dgaDots { 0%{content:'';} 33%{content:'.';} 66%{content:'..';} 100%{content:'...';} }

/* Report layout */
.dga-report-top { margin-bottom: 28px; }
.dga-report-title-row {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 20px; flex-wrap: wrap; margin-bottom: 14px;
}

/* Overall score ring */
.dga-overall-score-wrap {
  display: flex; flex-direction: column; align-items: center; flex-shrink: 0;
}
.dga-overall-label {
  font-size: 9px; font-weight: 700; color: rgba(255,255,255,.5);
  letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 5px;
}
.dga-overall-ring { position: relative; width: 80px; height: 80px; }
.dga-ring-svg { transform: rotate(-90deg); display: block; }
.dga-ring-bg   { fill: none; stroke: rgba(255,255,255,.1); stroke-width: 7; }
.dga-ring-fill {
  fill: none; stroke: #4ade80; stroke-width: 7; stroke-linecap: round;
  stroke-dasharray: 213.6; stroke-dashoffset: 213.6;
  transition: stroke-dashoffset 1.2s ease, stroke .4s;
}
.dga-ring-score {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-size: 21px; font-weight: 800; color: #fff;
}
.dga-overall-grade { font-size: 11px; font-weight: 700; margin-top: 5px; }

/* Section titles in report */
.dga-scores-title {
  font-size: 10px; font-weight: 800; color: rgba(255,255,255,.5);
  letter-spacing: 1.8px; text-transform: uppercase; margin-bottom: 14px;
}

/* WhatsApp CTA button */
.dga-wa-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(37,211,102,.12); border: 1.5px solid rgba(37,211,102,.35);
  color: #4ade80; padding: 11px 20px; border-radius: 8px;
  font-size: 13px; font-weight: 700; cursor: pointer;
  font-family: 'Sora', sans-serif; text-decoration: none;
  transition: all .2s; white-space: nowrap;
}
.dga-wa-btn:hover { background: rgba(37,211,102,.22); border-color: rgba(37,211,102,.6); }

/* ── RESPONSIVE MISC ── */
@media(max-width:480px){
  .con-hero-channels { gap: 8px; }
  .con-report-grid { grid-template-columns: 1fr; }
  .con-service-grid { grid-template-columns: 1fr 1fr; }
  .dga-progress { overflow-x: auto; }
  .dga-prog-label { font-size: 8px; }
  .dga-report-title-row { flex-direction: column-reverse; align-items: center; text-align: center; }
  .dga-overall-score-wrap { margin-bottom: 12px; }
}

/* ════════════════════════════════════
   BUDGET PLANNER TOOL — contact.css
════════════════════════════════════ */

/* Service selection grid */
.bp-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px,1fr));
  gap: 10px; margin-bottom: 16px;
}
.bp-svc-card {
  background: #ffffff; border: 1.5px solid #e5e9f0;
  border-radius: 12px; padding: 14px 12px;
  cursor: pointer; transition: all .2s; position: relative;
  box-shadow: 0 2px 8px rgba(0,45,89,.06);
}
.bp-svc-card:hover { border-color: #004a94; transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,45,89,.12); }
.bp-svc-card.selected { background: #fff5f5; border-color: #e00611; box-shadow: 0 4px 16px rgba(224,6,17,.15); }
.bp-chk { position:absolute;top:8px;right:10px;font-size:16px;color:#c7d0dd; }
.bp-svc-card.selected .bp-chk { color:#e00611; }
.bp-svc-icon { width:32px;height:32px;margin-bottom:8px;color:#004a94; }
.bp-svc-icon svg { width:100%;height:100%; }
.bp-svc-card.selected .bp-svc-icon { color:#e00611; }
.bp-svc-name { font-size:11px;font-weight:800;color:#002d59;margin-bottom:3px;line-height:1.3; }
.bp-svc-desc { font-size:10px;color:#5a6a82;line-height:1.4; }

/* Service config sections */
.bp-cfg-sec { margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.07); }
.bp-cfg-sec:last-child { border-bottom:none; }
.bp-cfg-head { display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.07);border-radius:10px;padding:12px 16px;margin-bottom:14px;border-left:3px solid #e00611; }
.bp-cfg-icon { font-size:20px;flex-shrink:0; }
.bp-cfg-name { font-size:14px;font-weight:800;color:#fff; }
.bp-svc-note { font-size:11px;color:#fbbf24;padding:7px 12px;background:rgba(251,191,36,.1);border-radius:8px;margin-bottom:10px; }

.bp-q { margin-bottom:16px; }
.bp-q-lbl { font-size:12px;font-weight:700;color:rgba(255,255,255,.85);margin-bottom:8px;display:block; }
.bp-q-note { font-size:10px;color:rgba(255,255,255,.4);font-style:italic;margin-bottom:7px; }
.bp-opts { display:flex;gap:7px;flex-wrap:wrap; }
.bp-opt {
  padding:7px 13px;border-radius:10px;
  border:1.5px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);
  font-size:11px;font-weight:600;cursor:pointer;background:transparent;
  font-family:'Sora',sans-serif;transition:all .18s;text-align:left;
}
.bp-opt:hover { border-color:rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.06); }
.bp-opt.selected { background:#e00611;border-color:#e00611;color:#fff; }
.bp-opt.selected-multi { background:rgba(0,74,148,.4);border-color:#004a94;color:#fff; }
.bp-opt-desc { display:block;font-size:9px;color:rgba(255,255,255,.45);margin-top:3px;font-weight:400; }
.bp-opt.selected .bp-opt-desc { color:rgba(255,255,255,.7); }
.bp-opt-travel { display:block;font-size:9px;color:#fbbf24;margin-top:3px;font-weight:600; }
.bp-opt-note { display:block;font-size:9px;color:rgba(255,255,255,.4);margin-top:3px; }
.bp-multi-hint { font-size:10px;color:rgba(255,255,255,.35);margin-top:5px;font-style:italic; }

/* Summary */
.bp-row { background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:16px; }
.bp-row-top { display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px; }
.bp-row-name { font-size:13px;font-weight:800;color:#002d59;display:flex;align-items:center;gap:8px; }
.bp-row-abbr { display:inline-flex;align-items:center;justify-content:center;width:36px;height:20px;border-radius:4px;color:#fff;font-size:9px;font-weight:800;letter-spacing:.5px;flex-shrink:0; }
.bp-row-det { font-size:10px;color:#5a6a82;margin:5px 0 4px;line-height:1.6; }
.bp-row-budget { font-size:11px;color:#002d59;margin-top:6px;background:#eef2fa;padding:5px 10px;border-radius:6px;display:inline-block; }
.bp-row-budget strong { color:#e00611; }
.bp-row-res { font-size:11px;color:#16a34a;margin-top:6px;font-weight:600; }

/* ── WHITE THEME OVERRIDES ── */
.con-tool-section::before { background:radial-gradient(circle,rgba(0,74,148,.06) 0%,transparent 70%); }
.con-tool-wrap { background:#ffffff;border:1px solid #e5e9f0;box-shadow:0 4px 32px rgba(0,45,89,.08); }
.con-step-title { color:#002d59; }
.con-step-sub { color:#5a6a82; }
.con-label-dark { color:#374151; }
.con-input-dark { background:#f8faff;border:1.5px solid #dde4ef;color:#002d59; }
.con-input-dark::placeholder { color:#94a3b8; }
.con-input-dark:focus { border-color:#004a94;outline:none; }
.con-input-dark option { background:#fff;color:#002d59; }

/* Step number badge stays red */
.con-step-num { background:#e00611;color:#fff; }

/* Service count text */
#bpCount { color:#002d59 !important; }

/* Config section on white */
.bp-cfg-sec { border-bottom:1px solid #e5e9f0; }
.bp-cfg-head { background:#f0f4fa;border-left:3px solid #e00611; }
.bp-cfg-abbr { display:inline-flex;align-items:center;justify-content:center;width:38px;height:26px;border-radius:6px;color:#fff;font-size:10px;font-weight:800;letter-spacing:.5px;flex-shrink:0; }
.bp-cfg-name { color:#002d59; }
.bp-q-lbl { color:#002d59; }
.bp-q-note { color:#5a6a82;font-style:italic; }
.bp-opt { border:1.5px solid #dde4ef;color:#374151;background:#fff; }
.bp-opt:hover { border-color:#004a94;color:#002d59;background:#f0f4fa; }
.bp-opt.selected { background:#e00611;border-color:#e00611;color:#fff; }
.bp-opt.selected-multi { background:#004a94;border-color:#004a94;color:#fff; }
.bp-opt-desc { color:#5a6a82; }
.bp-opt.selected .bp-opt-desc { color:rgba(255,255,255,.8); }
.bp-opt.selected-multi .bp-opt-desc { color:rgba(255,255,255,.8); }
.bp-opt-travel { color:#92400e; }
.bp-opt.selected .bp-opt-travel { color:rgba(255,255,255,.85); }
.bp-opt-note { color:#5a6a82; }
.bp-multi-hint { color:#5a6a82;font-style:italic; }
.bp-svc-note { font-size:11px;color:#5a6a82;background:#fef9ec;border:1px solid #fde68a;border-radius:7px;padding:7px 12px;margin-bottom:12px; }

/* Budget input */
.bp-budget-wrap { margin-top:16px;padding:14px 16px;background:#f8faff;border-radius:10px;border:1px solid #dde4ef; }
.bp-budget-lbl { display:block;font-size:12px;font-weight:700;color:#002d59;margin-bottom:8px; }
.bp-budget-input-row { display:flex;align-items:stretch;border-radius:8px;overflow:hidden;border:1.5px solid #dde4ef; }
.bp-budget-prefix { background:#002d59;color:#fff;padding:0 14px;font-size:11px;font-weight:700;display:flex;align-items:center;white-space:nowrap; }
.bp-budget-inp { flex:1;padding:10px 13px;border:none;font-size:13px;font-family:'Sora',sans-serif;color:#002d59;background:#fff;outline:none; }
.bp-budget-inp:focus { background:#f8faff; }
.bp-budget-note { font-size:10px;color:#5a6a82;margin-top:6px;line-height:1.6; }

/* Summary rows */
.bp-row { background:#f8faff;border:1px solid #e5e9f0;border-radius:12px;padding:16px; }

/* White theme action buttons */
.con-tool-btn-wt {
  display:block;width:100%;background:linear-gradient(135deg,#002d59,#e00611);
  color:#fff;border:none;border-radius:10px;padding:14px 24px;
  font-size:13px;font-weight:700;cursor:pointer;font-family:'Sora',sans-serif;
  transition:opacity .2s;margin-bottom:0;
}
.con-tool-btn-wt:hover { opacity:.9; }

/* Selected service count text on white */
.con-tool-section [style*="rgba(255,255,255,.4)"] { color:#5a6a82 !important; }

/* ── TOOL SECTION WHITE THEME — header + progress overrides ── */
.con-tool-section .con-tool-header .con-section-title { color:#002d59 !important; }
.con-tool-section .con-tool-header .con-section-sub   { color:#5a6a82 !important; }
.con-tool-section .con-tool-header .con-pill-dark { background:rgba(0,45,89,.07) !important; border-color:rgba(0,45,89,.12) !important; }
.con-tool-section .con-tool-header .con-pill-dark span { color:#5a6a82 !important; }

/* Progress bar on white background */
.con-tool-section .dga-prog-dot { background:#e5e9f0; border-color:#c7d0dd; }
.con-tool-section .dga-prog-label { color:#5a6a82; }
.con-tool-section .dga-prog-line { background:#e5e9f0; }
.con-tool-section .dga-prog-step.active .dga-prog-dot { background:#e00611; border-color:#e00611; box-shadow:0 0 0 5px rgba(224,6,17,.15); }
.con-tool-section .dga-prog-step.active .dga-prog-label { color:#002d59; }
.con-tool-section .dga-prog-step.done .dga-prog-dot { background:#16a34a; border-color:#16a34a; }
.con-tool-section .dga-prog-step.done .dga-prog-label { color:#16a34a; }
.con-tool-section .dga-prog-line.done { background:#16a34a; }

/* Selected count text on white */
.con-tool-section .bp-count-text { color:#5a6a82 !important; }

/* Section header text on white */
.con-pill-dark { background:rgba(0,45,89,.07);border:1px solid rgba(0,45,89,.12); }
.con-pill-dark span { color:#002d59; }
.con-pill-dot-r { width:6px;height:6px;border-radius:50%;background:#e00611; }
.con-section-title { color:#002d59; }
.con-section-sub { color:#5a6a82; }

@media(max-width:480px){
  .bp-services-grid { grid-template-columns:1fr 1fr; }
  .bp-opts { flex-direction:column; }
  .bp-opt { width:100%; }
}
