/* ═══════════════════════════════════════════════════════════
   LAUNCHOUSE — contact.css
   Contact Page — Full Theme Match
   Navy #2d3250 · Raleway / Bebas Neue · Accent #f9b17a
═══════════════════════════════════════════════════════════ */

/* ── Shared vars ── */
:root {
  --navy:        #2d3250;
  --navy-mid:    #424769;
  --navy-light:  #676f9d;
  --navy-dark:   #1a1e3a;
  --navy-card:   #222748;
  --white:       #ffffff;
  --w70:         rgba(255,255,255,0.70);
  --w60:         rgba(255,255,255,0.60);
  --w40:         rgba(255,255,255,0.40);
  --w20:         rgba(255,255,255,0.20);
  --w10:         rgba(255,255,255,0.10);
  --w06:         rgba(255,255,255,0.06);
  --w03:         rgba(255,255,255,0.03);
  --accent:      #f9b17a;
  --acc-dark:    #e8934a;
  --acc-glow:    rgba(249,177,122,0.28);
  --acc-10:      rgba(249,177,122,0.10);
  --acc-20:      rgba(249,177,122,0.20);
  --green:       #4ade80;
  --green-10:    rgba(74,222,128,0.12);
  --red:         #f87171;
  --red-10:      rgba(248,113,113,0.12);
  --ease:        cubic-bezier(0.4,0,0.2,1);
  --spring:      cubic-bezier(0.34,1.56,0.64,1);
  --t:           0.32s;
  --nav-h:       76px;
  --bn-h:        76px;
}

/* ── Utilities ── */
.section-container { max-width:1200px; margin:0 auto; padding:0 36px; }
.section-eyebrow {
  display:inline-block; font-size:11px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--accent); margin-bottom:14px;
}
.section-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px,5.5vw,68px);
  letter-spacing:1px; line-height:1.0; color:var(--white);
}
.title-accent { color:var(--accent); }

/* Buttons */
.btn-primary {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 28px; background:var(--accent); color:var(--navy-dark);
  font-size:14px; font-weight:700; border-radius:12px;
  border:none; cursor:pointer; font-family:'Raleway',sans-serif;
  box-shadow:0 6px 24px var(--acc-glow); text-decoration:none;
  transition:background var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
}
.btn-primary:hover { background:var(--acc-dark); transform:translateY(-2px) scale(1.02); box-shadow:0 12px 36px rgba(249,177,122,.42); }
.btn-primary.btn-large { padding:16px 36px; font-size:15px; border-radius:14px; }
.btn-outline-white {
  display:inline-flex; align-items:center; padding:14px 28px;
  border:1.5px solid rgba(255,255,255,.3); color:var(--white);
  font-size:14px; font-weight:600; border-radius:14px; text-decoration:none;
  transition:background var(--t) var(--ease),border-color var(--t) var(--ease);
}
.btn-outline-white:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.5); }

/* Reveal */
[data-reveal] { opacity:0; transition:opacity .7s var(--ease),transform .7s var(--ease); }
[data-reveal="fade-up"]    { transform:translateY(40px); }
[data-reveal="fade-left"]  { transform:translateX(60px); }
[data-reveal="fade-right"] { transform:translateX(-60px); }
[data-reveal="clip-up"]    { transform:translateY(100%); display:inline-block; overflow:hidden; opacity:1; }
[data-reveal].revealed { opacity:1; transform:translate(0,0); }
[data-reveal="clip-up"].revealed { transform:translateY(0); }

/* ═══════════════════════════════════════════
   1 — HERO
═══════════════════════════════════════════ */
.ct-hero {
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:120px 36px 110px;
  background:linear-gradient(160deg, var(--navy-dark) 0%, var(--navy) 50%, #1d2142 100%);
  text-align:center;
}

.ct-canvas {
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none;
}
.ct-hero-grain {
  position:absolute; inset:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.45;
}
.ct-hero-grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(103,111,157,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(103,111,157,.08) 1px,transparent 1px);
  background-size:60px 60px;
  animation:ctGridMove 28s linear infinite;
}
@keyframes ctGridMove { from{background-position:0 0} to{background-position:60px 60px} }

/* Floating orbs */
.ct-orb {
  position:absolute; border-radius:50%; pointer-events:none;
  filter:blur(80px); animation:ctOrbFloat linear infinite;
}
.ct-orb--1 {
  width:420px; height:420px; top:-100px; right:-80px;
  background:radial-gradient(circle, rgba(249,177,122,.14) 0%, transparent 70%);
  animation-duration:22s; animation-delay:-6s;
}
.ct-orb--2 {
  width:340px; height:340px; bottom:-60px; left:-60px;
  background:radial-gradient(circle, rgba(103,111,157,.2) 0%, transparent 70%);
  animation-duration:28s; animation-delay:-14s;
}
.ct-orb--3 {
  width:260px; height:260px; top:40%; left:55%;
  background:radial-gradient(circle, rgba(249,177,122,.08) 0%, transparent 70%);
  animation-duration:18s;
}
@keyframes ctOrbFloat {
  0%,100% { transform:translateY(0) scale(1); }
  33%     { transform:translateY(-30px) scale(1.05); }
  66%     { transform:translateY(20px) scale(.97); }
}

.ct-hero-inner {
  position:relative; z-index:2;
  max-width:820px; width:100%;
}

/* Eyebrow */
.ct-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 20px;
  background:var(--acc-10);
  border:1px solid rgba(249,177,122,.22);
  border-radius:100px;
  font-size:12px; font-weight:600; letter-spacing:.4px;
  color:var(--accent); margin-bottom:28px;
}
.ct-ey-dot {
  width:7px; height:7px; background:var(--accent); border-radius:50%;
  animation:ctEyPulse 2s ease-in-out infinite; flex-shrink:0;
}
@keyframes ctEyPulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.5);opacity:.6} }
.ct-ey-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px;
  background:rgba(74,222,128,.12);
  border:1px solid rgba(74,222,128,.25);
  border-radius:100px;
  font-size:10px; font-weight:700; letter-spacing:.5px;
  color:#4ade80; text-transform:uppercase;
}

/* Title */
.ct-hero-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(80px,12vw,160px);
  line-height:.92; letter-spacing:4px;
  margin-bottom:28px; overflow:hidden;
}
.ctht-line { display:block; }
.ctht-accent {
  color:var(--accent);
  text-shadow:0 0 100px rgba(249,177,122,.5);
}

.ct-hero-sub {
  font-size:17px; color:var(--w60); line-height:1.8;
  max-width:600px; margin:0 auto 44px;
}

/* Quick action buttons */
.ct-hero-quick {
  display:flex; align-items:stretch; justify-content:center;
  gap:12px; flex-wrap:wrap;
}
.ct-quick-btn {
  display:flex; align-items:center; gap:14px;
  padding:14px 20px;
  background:var(--w06);
  border:1px solid var(--w10);
  border-radius:16px;
  text-decoration:none;
  min-width:220px;
  transition:border-color var(--t) var(--ease),background var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
  position:relative; overflow:hidden;
}
.ct-quick-btn::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--acc-10),transparent);
  opacity:0;
  transition:opacity var(--t) var(--ease);
}
.ct-quick-btn:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(0,0,0,.3); }
.ct-quick-btn:hover::before { opacity:1; }
.ct-quick--wa:hover  { border-color:rgba(37,211,102,.35); }
.ct-quick--call:hover{ border-color:rgba(249,177,122,.35); }
.ct-quick--mail:hover{ border-color:rgba(103,111,157,.5); }

.ct-qb-icon {
  width:40px; height:40px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; flex-shrink:0;
  transition:transform var(--t) var(--spring);
}
.ct-quick-btn:hover .ct-qb-icon { transform:scale(1.1) rotate(-5deg); }
.ct-quick--wa  .ct-qb-icon { background:rgba(37,211,102,.12); color:#25d366; }
.ct-quick--call .ct-qb-icon { background:var(--acc-10); color:var(--accent); }
.ct-quick--mail .ct-qb-icon { background:rgba(103,111,157,.15); color:var(--navy-light); }

.ct-qb-text { flex:1; text-align:left; position:relative; z-index:1; }
.ct-qb-text span { display:block; font-size:14px; font-weight:700; color:var(--white); margin-bottom:2px; }
.ct-qb-text em   { display:block; font-size:11.5px; font-style:normal; color:var(--w40); }

.ct-qb-arrow {
  font-size:11px; color:var(--w40);
  position:relative; z-index:1;
  transition:transform var(--t) var(--ease),color var(--t) var(--ease);
}
.ct-quick-btn:hover .ct-qb-arrow { transform:translateX(3px); color:var(--accent); }

/* Scroll hint */
.ct-hero-scroll {
  position:absolute; bottom:32px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  color:var(--w40); z-index:3;
}
.ct-scroll-line {
  width:1px; height:48px;
  background:linear-gradient(to bottom, var(--accent), transparent);
  animation:ctScrollAnim 2.2s ease-in-out infinite;
}
@keyframes ctScrollAnim {
  0%  { transform:scaleY(0); transform-origin:top; opacity:1; }
  50% { transform:scaleY(1); transform-origin:top; }
  51% { transform:scaleY(1); transform-origin:bottom; }
  100%{ transform:scaleY(0); transform-origin:bottom; opacity:0; }
}

/* ═══════════════════════════════════════════
   2 — MAIN CONTACT SPLIT
═══════════════════════════════════════════ */
.ct-main {
  padding:120px 0;
  background:var(--navy);
  border-top:1px solid var(--w06);
}
.ct-main-inner {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:64px;
  align-items:start;
}

/* ── Step Bar ── */
.ct-step-bar {
  display:flex; align-items:center;
  gap:0; margin-bottom:44px;
}
.ct-step {
  display:flex; align-items:center; gap:10px;
  cursor:default;
}
.ct-step-num {
  width:32px; height:32px; border-radius:50%;
  background:var(--w06);
  border:1.5px solid var(--w10);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--w40);
  transition:background var(--t) var(--ease),border-color var(--t) var(--ease),color var(--t) var(--ease),box-shadow var(--t) var(--ease);
  flex-shrink:0;
}
.ct-step span {
  font-size:12px; font-weight:600; color:var(--w40); letter-spacing:.3px;
  transition:color var(--t) var(--ease);
}
.ct-step.active .ct-step-num {
  background:var(--accent); border-color:transparent; color:var(--navy-dark);
  box-shadow:0 0 0 4px var(--acc-10), 0 4px 16px var(--acc-glow);
}
.ct-step.active span  { color:var(--accent); }
.ct-step.done .ct-step-num  { background:var(--green-10); border-color:rgba(74,222,128,.3); color:#4ade80; }
.ct-step.done span    { color:#4ade80; }
.ct-step-line {
  flex:1; height:1.5px;
  background:linear-gradient(to right, var(--w10), var(--w06));
  margin:0 12px;
  transition:background var(--t) var(--ease);
}
.ct-step-line.active { background:linear-gradient(to right, var(--accent), var(--w10)); }

/* ── Form ── */
.ct-form {
  background:var(--navy-card);
  border:1px solid var(--w06);
  border-radius:28px;
  padding:48px 44px;
  position:relative;
  overflow:hidden;
}
.ct-form::before {
  content:'';
  position:absolute; top:-80px; right:-80px;
  width:300px; height:300px;
  background:radial-gradient(circle, var(--acc-10) 0%, transparent 70%);
  pointer-events:none;
}

/* Step panels */
.ct-step-panel {
  display:none;
  animation:ctPanelIn .4s var(--ease);
}
.ct-step-panel.active { display:block; }
@keyframes ctPanelIn { from{opacity:0;transform:translateX(24px)} to{opacity:1;transform:translateX(0)} }
.ct-step-panel.slide-back { animation:ctPanelBack .4s var(--ease); }
@keyframes ctPanelBack { from{opacity:0;transform:translateX(-24px)} to{opacity:1;transform:translateX(0)} }

.ct-form-header {
  margin-bottom:28px;
}
.ct-form-header h2 {
  font-family:'Bebas Neue',sans-serif;
  font-size:28px; letter-spacing:.8px; color:var(--white); margin-bottom:6px;
}
.ct-form-header p { font-size:14px; color:var(--w60); }

/* Fields */
.ct-field-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

.ct-field { margin-bottom:20px; }

.ct-input-wrap {
  position:relative;
  display:flex; align-items:center;
}
.ct-field-icon {
  position:absolute; left:14px;
  font-size:13px; color:var(--w40);
  z-index:2; pointer-events:none;
  transition:color var(--t) var(--ease);
}
.ct-input-wrap:focus-within .ct-field-icon { color:var(--accent); }

.ct-input-wrap input,
.ct-input-wrap textarea {
  width:100%;
  background:var(--w06);
  border:1.5px solid var(--w10);
  border-radius:14px;
  padding:18px 16px 8px 40px;
  font-family:'Raleway',sans-serif;
  font-size:14px; font-weight:500; color:var(--white);
  outline:none;
  transition:border-color var(--t) var(--ease), background var(--t) var(--ease),box-shadow var(--t) var(--ease);
  resize:none;
}
.ct-input-wrap textarea { padding-top:22px; }

.ct-input-wrap input:focus,
.ct-input-wrap textarea:focus {
  border-color:rgba(249,177,122,.5);
  background:rgba(249,177,122,.04);
  box-shadow:0 0 0 3px var(--acc-10);
}

/* Floating label */
.ct-input-wrap label {
  position:absolute;
  left:40px;
  top:50%; transform:translateY(-50%);
  font-size:14px; font-weight:500; color:var(--w40);
  pointer-events:none;
  transition:top var(--t) var(--ease), font-size var(--t) var(--ease),
             color var(--t) var(--ease), transform var(--t) var(--ease);
  z-index:2;
}
.ct-textarea-wrap label { top:26px; }
.ct-input-wrap input:focus     ~ label,
.ct-input-wrap input:not(:placeholder-shown) ~ label,
.ct-input-wrap textarea:focus  ~ label,
.ct-input-wrap textarea:not(:placeholder-shown) ~ label {
  top:10px; font-size:10px; font-weight:700; letter-spacing:.6px;
  color:var(--accent); transform:none;
}
.ct-textarea-wrap input:focus ~ label,
.ct-textarea-wrap textarea:focus ~ label,
.ct-textarea-wrap textarea:not(:placeholder-shown) ~ label { top:10px; }

/* Animated bottom line */
.ct-field-line {
  position:absolute; bottom:0; left:0; right:0;
  height:2px; border-radius:0 0 14px 14px;
  background:linear-gradient(to right, var(--accent), var(--acc-dark));
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
  pointer-events:none;
}
.ct-input-wrap:focus-within .ct-field-line { transform:scaleX(1); }

/* Validation states */
.ct-field.is-valid .ct-input-wrap input,
.ct-field.is-valid .ct-input-wrap textarea {
  border-color:rgba(74,222,128,.4);
  background:rgba(74,222,128,.04);
}
.ct-field.is-invalid .ct-input-wrap input,
.ct-field.is-invalid .ct-input-wrap textarea {
  border-color:rgba(248,113,113,.45);
  background:rgba(248,113,113,.04);
}
.ct-field-err {
  display:block; font-size:11px; font-weight:600;
  color:var(--red); margin-top:5px; padding-left:4px;
  min-height:16px;
  transition:opacity .3s var(--ease);
}

/* Select */
.ct-select-wrap select {
  width:100%;
  background:var(--w06);
  border:1.5px solid var(--w10);
  border-radius:14px;
  padding:20px 40px 10px 40px;
  display:flex;
  align-items:center;
  line-height:1.4;
  font-family:'Raleway',sans-serif;
  font-size:14px; font-weight:500; color:var(--white);
  outline:none; cursor:pointer; appearance:none;
  transition:border-color var(--t) var(--ease), background var(--t) var(--ease);
}
 
.ct-select-wrap select:invalid {
  color: var(--w40);
}

.ct-select-wrap {
  position: relative;
}

.ct-select-wrap select {
  height: 56px;
}

.ct-select-wrap select:focus { border-color:rgba(249,177,122,.5); background:rgba(249,177,122,.04); box-shadow:0 0 0 3px var(--acc-10); }
.ct-select-label {
  position:absolute; left:40px; top:14px;
  font-size:10px; font-weight:700; letter-spacing:.6px;
  color:var(--accent); pointer-events:none; z-index:2;
}
.ct-select-arrow {
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  font-size:11px; color:var(--w40); pointer-events:none; z-index:2;
}

/* Goal cards */
.ct-goal-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:10px;
  margin-bottom:4px;
}
.ct-goal-card {
  position:relative; cursor:pointer;
}
.ct-goal-card input { position:absolute; opacity:0; width:0; height:0; }
.ct-gc-inner {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:16px 10px;
  background:var(--w06);
  border:1.5px solid var(--w10);
  border-radius:14px;
  font-size:12px; font-weight:700; color:var(--w60);
  text-align:center;
  transition:background var(--t) var(--ease),border-color var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--spring);
}
.ct-gc-inner i { font-size:20px; color:var(--w40); transition:color var(--t) var(--ease),transform var(--t) var(--spring); }
.ct-goal-card:hover .ct-gc-inner { border-color:rgba(249,177,122,.25); background:var(--acc-10); color:var(--white); }
.ct-goal-card:hover .ct-gc-inner i { color:var(--accent); transform:scale(1.15); }
.ct-goal-card input:checked ~ .ct-gc-inner {
  background:var(--acc-10); border-color:rgba(249,177,122,.45); color:var(--accent);
  transform:scale(1.03);
  box-shadow:0 6px 20px var(--acc-10);
}
.ct-goal-card input:checked ~ .ct-gc-inner i { color:var(--accent); }

.ct-gc-check {
  position:absolute; top:8px; right:8px;
  width:18px; height:18px; border-radius:50%;
  background:var(--accent); color:var(--navy-dark);
  display:flex; align-items:center; justify-content:center;
  font-size:9px;
  transform:scale(0); opacity:0;
  transition:transform var(--t) var(--spring), opacity var(--t) var(--ease);
}
.ct-goal-card input:checked ~ .ct-gc-check { transform:scale(1); opacity:1; }

/* Char count */
.ct-char-count {
  text-align:right; font-size:11px; color:var(--w40); margin-top:4px;
}

/* Preferred time */
.ct-preferred-time { margin-bottom:28px; }
.ct-pt-label {
  font-size:12px; font-weight:700; color:var(--w60); letter-spacing:.5px;
  margin-bottom:10px; display:flex; align-items:center; gap:7px;
}
.ct-pt-label i { color:var(--accent); }
.ct-pt-options { display:flex; gap:8px; flex-wrap:wrap; }
.ct-pt-opt {
  display:flex; align-items:center;
  cursor:pointer;
}
.ct-pt-opt input { position:absolute; opacity:0; width:0; height:0; }
.ct-pt-opt span {
  display:block; padding:7px 16px;
  background:var(--w06);
  border:1.5px solid var(--w10);
  border-radius:100px;
  font-size:12px; font-weight:600; color:var(--w60);
  transition:background var(--t) var(--ease),border-color var(--t) var(--ease),color var(--t) var(--ease);
}
.ct-pt-opt:hover span { border-color:rgba(249,177,122,.25); color:var(--white); }
.ct-pt-opt input:checked ~ span {
  background:var(--acc-10); border-color:rgba(249,177,122,.45); color:var(--accent);
}

/* Nav buttons */
.ct-step-nav { display:flex; gap:12px; align-items:center; justify-content:space-between; }
.ct-back-btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:11px 20px;
  background:transparent; border:1.5px solid var(--w10);
  border-radius:12px; color:var(--w60);
  font-size:13px; font-weight:600;
  cursor:pointer; font-family:'Raleway',sans-serif;
  transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease);
}
.ct-back-btn:hover { border-color:var(--w20); color:var(--white); background:var(--w06); }

.ct-next-btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 28px;
  background:var(--accent); color:var(--navy-dark);
  border:none; border-radius:12px; cursor:pointer;
  font-family:'Raleway',sans-serif;
  font-size:14px; font-weight:700;
  box-shadow:0 6px 24px var(--acc-glow);
  transition:background var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
}
.ct-next-btn:hover { background:var(--acc-dark); transform:translateY(-2px) scale(1.02); box-shadow:0 12px 36px rgba(249,177,122,.42); }
.ct-next-btn i { font-size:12px; transition:transform var(--t) var(--ease); }
.ct-next-btn:hover i { transform:translateX(4px); }

/* Submit button */
.ct-submit-btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px;
  background:var(--accent); color:var(--navy-dark);
  border:none; border-radius:12px; cursor:pointer;
  font-family:'Raleway',sans-serif;
  font-size:14px; font-weight:700;
  box-shadow:0 6px 24px var(--acc-glow);
  position:relative;
  transition:background var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
  overflow:hidden;
}
.ct-submit-btn:hover { background:var(--acc-dark); transform:translateY(-2px) scale(1.02); }
.ct-submit-btn.is-loading .ct-submit-text  { opacity:0; }
.ct-submit-btn.is-loading .ct-submit-icon  { opacity:0; }
.ct-submit-btn.is-loading .ct-submit-loader { opacity:1; }
.ct-submit-loader {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; opacity:0;
  transition:opacity .2s;
}
.ct-submit-icon { font-size:14px; transition:transform var(--t) var(--ease); }
.ct-submit-btn:hover .ct-submit-icon { transform:rotate(-30deg) scale(1.2); }

/* Success state */
.ct-success {
  display:none; text-align:center;
  padding:20px 0 10px;
  animation:ctSuccessIn .6s var(--spring);
}
.ct-success.show { display:block; }
@keyframes ctSuccessIn { from{opacity:0;transform:scale(.85)} to{opacity:1;transform:scale(1)} }

.ct-success-ring {
  width:80px; height:80px;
  border-radius:50%;
  border:2px solid rgba(74,222,128,.4);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 24px;
  animation:ctSuccessRing .8s var(--ease) forwards;
}
@keyframes ctSuccessRing { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }

.ct-success-icon {
  width:56px; height:56px; border-radius:50%;
  background:rgba(74,222,128,.15);
  border:2px solid rgba(74,222,128,.5);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:#4ade80;
  animation:ctCheckDraw .5s var(--spring) .3s both;
}
@keyframes ctCheckDraw { from{transform:scale(0)} to{transform:scale(1)} }

.ct-success h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:36px; letter-spacing:1px; color:var(--white); margin-bottom:12px;
}
.ct-success p { font-size:15px; color:var(--w60); line-height:1.75; margin-bottom:28px; }

.ct-success-wa {
  display:inline-flex; align-items:center; gap:9px;
  padding:12px 28px;
  background:#25d366; color:white;
  font-size:14px; font-weight:700;
  border-radius:12px;
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  transition:background var(--t) var(--ease),transform var(--t) var(--spring);
}
.ct-success-wa:hover { background:#1ebc59; transform:translateY(-2px); }

/* ── Info column ── */
.ct-info-col { display:flex; flex-direction:column; gap:14px; }

.ct-info-card {
  display:flex; align-items:flex-start; gap:16px;
  padding:22px 20px;
  background:var(--navy-card);
  border:1px solid var(--w06);
  border-radius:18px;
  position:relative; overflow:hidden;
  transition:border-color var(--t) var(--ease),transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
}
.ct-info-card:hover {
  border-color:rgba(249,177,122,.2);
  transform:translateX(4px);
  box-shadow:0 8px 32px rgba(0,0,0,.25);
}
.ct-info-card:hover .ct-ic-glow { opacity:1; }

.ct-ic-glow {
  position:absolute; right:-40px; top:-40px;
  width:120px; height:120px;
  background:radial-gradient(circle, var(--acc-10) 0%, transparent 70%);
  opacity:0; pointer-events:none;
  transition:opacity .5s var(--ease);
}

.ct-ic-icon {
  width:44px; height:44px; border-radius:13px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:18px;
  background:rgba(37,211,102,.12); color:#25d366;
  transition:transform var(--t) var(--spring);
}
.ct-info-card:hover .ct-ic-icon { transform:scale(1.1) rotate(-5deg); }
.ct-ic--phone { background:var(--acc-10);  color:var(--accent); }
.ct-ic--mail  { background:rgba(103,111,157,.18); color:var(--navy-light); }
.ct-ic--loc   { background:rgba(248,113,113,.12); color:#f87171; }
.ct-ic--hours { background:var(--acc-10);  color:var(--accent); }

.ct-ic-content h4 {
  font-size:14px; font-weight:800; color:var(--white); margin-bottom:4px;
}
.ct-ic-content p { font-size:12.5px; color:var(--w60); line-height:1.6; margin-bottom:8px; }

.ct-ic-link {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; color:var(--accent);
  transition:gap var(--t) var(--ease);
}
.ct-ic-link:hover { gap:10px; }
.ct-ic-link i { font-size:10px; }

/* Hours card */
.ct-hours-card {
  padding:22px 20px;
  background:var(--navy-card);
  border:1px solid var(--w06);
  border-radius:18px;
  transition:border-color var(--t) var(--ease), transform var(--t) var(--spring);
}
.ct-hours-card:hover { border-color:rgba(249,177,122,.18); transform:translateX(4px); }

.ct-hours-header {
  display:flex; align-items:center; gap:12px; margin-bottom:16px;
}
.ct-hours-header h4 { font-size:14px; font-weight:800; color:var(--white); }

.ct-hours-list { display:flex; flex-direction:column; gap:0; }
.ct-hour-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:9px 0;
  border-bottom:1px solid var(--w06);
  font-size:13px; color:var(--w60);
}
.ct-hour-row:last-child { border-bottom:none; padding-bottom:0; }
.ct-hr-time { font-weight:700; color:var(--white); }

.ct-open-now {
  margin-top:14px; padding:8px 14px;
  border-radius:100px;
  font-size:11px; font-weight:700; letter-spacing:.6px;
  text-align:center;
}
.ct-open-now.is-open {
  background:rgba(74,222,128,.1);
  border:1px solid rgba(74,222,128,.25);
  color:#4ade80;
}
.ct-open-now.is-closed {
  background:rgba(248,113,113,.1);
  border:1px solid rgba(248,113,113,.25);
  color:#f87171;
}

/* Socials card */
.ct-socials-card {
  padding:18px 20px;
  background:var(--navy-card);
  border:1px solid var(--w06);
  border-radius:18px;
  transition:border-color var(--t) var(--ease);
}
.ct-socials-card:hover { border-color:rgba(249,177,122,.15); }
.ct-socials-card p { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--w40); margin-bottom:12px; }

.ct-social-row { display:flex; gap:10px; }
.ct-soc {
  width:38px; height:38px; border-radius:11px;
  background:var(--w06); border:1px solid var(--w10);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; color:var(--w60);
  transition:background var(--t) var(--ease),border-color var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--spring);
}
.ct-soc:hover { background:var(--acc-10); border-color:rgba(249,177,122,.3); color:var(--accent); transform:translateY(-3px) scale(1.08); }

/* ═══════════════════════════════════════════
   3 — MAP SECTION
═══════════════════════════════════════════ */
.ct-map-section {
  padding:120px 0 0;
  background:linear-gradient(160deg, var(--navy-dark) 0%, var(--navy) 100%);
  border-top:1px solid var(--w06);
  overflow:hidden;
}

.ct-map-header { text-align:center; margin-bottom:56px; }

.ct-map-wrap {
  position:relative;
  height:480px;
  margin:0 36px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid var(--w10);
  box-shadow:0 24px 80px rgba(0,0,0,.45);
}

.ct-map-wrap iframe {
  width:100%; height:100%; border:0;
  filter:invert(90%) hue-rotate(180deg) saturate(0.6) brightness(0.85);
  display:block;
}

.ct-map-overlay {
  position:absolute; inset:0;
  z-index:2; pointer-events:none;
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:28px 32px;
}

.ct-map-pin {
  background:rgba(22,26,50,.9);
  backdrop-filter:blur(16px);
  border:1px solid var(--w10);
  border-radius:16px;
  padding:14px 18px;
  display:flex; align-items:center; gap:14px;
  pointer-events:auto;
  animation:ctPinFloat 3s ease-in-out infinite;
}
@keyframes ctPinFloat {
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-6px); }
}
.ct-pin-icon {
  width:42px; height:42px; border-radius:50%;
  background:var(--acc-10); border:1.5px solid rgba(249,177,122,.3);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--accent); flex-shrink:0; position:relative;
}
.ct-pin-pulse {
  position:absolute; inset:-6px; border-radius:50%;
  border:1.5px solid rgba(249,177,122,.3);
  animation:ctPinPulse 2.5s ease-out infinite;
}
@keyframes ctPinPulse {
  0%  { transform:scale(1); opacity:.7; }
  100%{ transform:scale(1.8); opacity:0; }
}
.ct-pin-label strong { display:block; font-size:13px; font-weight:800; color:var(--white); margin-bottom:2px; }
.ct-pin-label span   { display:block; font-size:11px; color:var(--w60); }

.ct-map-cta {
  background:var(--accent); color:var(--navy-dark);
  padding:12px 22px; border-radius:12px;
  font-size:13px; font-weight:700;
  display:inline-flex; align-items:center; gap:8px;
  pointer-events:auto;
  box-shadow:0 4px 20px var(--acc-glow);
  transition:background var(--t) var(--ease),transform var(--t) var(--spring);
}
.ct-map-cta:hover { background:var(--acc-dark); transform:scale(1.04); }

/* Directions strip */
.ct-directions-strip {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:24px;
  padding:44px 0 80px;
}
.ct-dir-item {
  display:flex; align-items:flex-start; gap:14px; flex:1;
}
.ct-dir-icon {
  width:42px; height:42px; border-radius:12px; flex-shrink:0;
  background:var(--acc-10); border:1px solid rgba(249,177,122,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--accent);
  transition:transform var(--t) var(--spring);
}
.ct-dir-item:hover .ct-dir-icon { transform:scale(1.1) rotate(-5deg); }
.ct-dir-item strong { display:block; font-size:14px; font-weight:800; color:var(--white); margin-bottom:4px; }
.ct-dir-item p { font-size:13px; color:var(--w60); line-height:1.65; }
.ct-dir-div { width:1px; background:linear-gradient(to bottom,transparent,var(--w10),transparent); flex-shrink:0; }

/* ═══════════════════════════════════════════
   4 — FINAL CTA
═══════════════════════════════════════════ */
.ct-cta {
  position:relative;
  background:linear-gradient(135deg, var(--acc-dark) 0%, #c97030 100%);
  padding:130px 36px;
  text-align:center; overflow:hidden;
}
.ct-cta::before {
  content:'';
  position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  opacity:.6;
}
.ct-cta-bg-text {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(130px,18vw,260px);
  color:rgba(0,0,0,.07);
  letter-spacing:8px; pointer-events:none; white-space:nowrap; user-select:none;
}
.ct-cta-inner { position:relative; z-index:2; }
.ct-cta-ey    { color:rgba(45,50,80,.7); }
.ct-cta-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(56px,8vw,110px);
  letter-spacing:2px; line-height:.95;
  color:var(--navy-dark); margin-bottom:20px;
}
.ct-cta-title span { color:var(--white); }
.ct-cta-sub {
  font-size:17px; color:rgba(45,50,80,.72);
  max-width:480px; margin:0 auto 44px; line-height:1.7;
}
.ct-cta-btns {
  display:flex; align-items:center; justify-content:center;
  gap:16px; flex-wrap:wrap; margin-bottom:32px;
}
.ct-cta-btns .btn-primary {
  background:var(--navy-dark); color:var(--white);
  box-shadow:0 8px 30px rgba(0,0,0,.3);
}
.ct-cta-btns .btn-primary:hover { background:var(--navy-mid); }
.ct-cta-trust {
  display:flex; align-items:center; justify-content:center;
  gap:28px; flex-wrap:wrap;
}
.ct-cta-trust span {
  display:inline-flex; align-items:center; gap:7px;
  font-size:12px; font-weight:700; color:rgba(45,50,80,.6);
}
.ct-cta-trust i { color:rgba(45,50,80,.5); }

/* Floating WhatsApp */
.wa-float {
  position:fixed; bottom:100px; right:24px;
  width:56px; height:56px; background:#25d366;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:26px; color:white; z-index:999;
  box-shadow:0 4px 24px rgba(37,211,102,.45);
  transition:transform var(--t) var(--spring),box-shadow var(--t) var(--ease);
}
.wa-float:hover { transform:scale(1.1); box-shadow:0 8px 36px rgba(37,211,102,.65); }
.wa-pulse {
  position:absolute; inset:0; border-radius:50%; background:#25d366; z-index:-1;
  animation:waPulse 2.5s ease-out infinite;
}
@keyframes waPulse { 0%{transform:scale(1);opacity:.7} 100%{transform:scale(2);opacity:0} }

@media (max-width:640px) {
  .wa-float { bottom:calc(var(--bn-h) + 40px); right:16px; }
}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width:1024px) {
  .ct-main-inner { grid-template-columns:1fr; gap:48px; }
  .ct-info-col { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
  .ct-hours-card,
  .ct-socials-card { grid-column:1/-1; }
  .ct-directions-strip { gap:16px; }
}

@media (max-width:900px) {
  .ct-hero-quick { flex-direction:column; align-items:center; }
  .ct-quick-btn  { width:100%; max-width:360px; }
  .ct-map-wrap   { height:360px; }
  .ct-directions-strip { flex-wrap:wrap; }
  .ct-dir-item   { flex:0 0 calc(50% - 8px); }
  .ct-dir-div    { display:none; }
}

@media (max-width:640px) {
 html, body { padding-bottom:var(--bn-h); }

  .ct-hero { padding:100px 20px 70px;}
  .ct-hero-title { font-size:clamp(68px,18vw,120px); }
  .ct-hero-sub br { display:none; }

  .section-container { padding:0 20px; }

  .ct-main { padding:80px 0; }
  .ct-form { padding:28px 20px; }
  .ct-field-row { grid-template-columns:1fr; }
  .ct-goal-grid { grid-template-columns:repeat(2,1fr); }

  .ct-info-col { grid-template-columns:1fr; }

  .ct-map-section { padding:80px 0 0; }
  .ct-map-wrap { margin:0 20px; height:300px; }
  .ct-map-overlay { flex-direction:column; align-items:flex-start; gap:12px; padding:16px; }
  .ct-directions-strip { flex-direction:column; padding:32px 0 60px; gap:20px; }
  .ct-dir-item { flex:1 1 100%; }

  .ct-cta { padding:80px 20px; }

  .ct-hero-scroll { display:none; }
}

@media (max-width:380px) {
  html, body { padding-bottom:var(--bn-h); }
  .ct-hero-title { font-size:62px; }
  .ct-goal-grid  { grid-template-columns:1fr 1fr; }
}

/* SELECT DROPDOWN FIX */
.ct-select-wrap select {
  background-color: var(--navy-card);
  color: var(--white);
}

/* DROPDOWN OPTIONS */
.ct-select-wrap select option {
  background-color: #2d3250;   /* dark bg */
  color: #ffffff;              /* visible text */
}

/* HOVER (some browsers support) */
.ct-select-wrap select option:hover {
  background-color: #424769;
}

/* SELECTED OPTION */
.ct-select-wrap select option:checked {
  background-color: #f9b17a;
  color: #1a1e3a;
}