/* ════════════════════════════════════════════════════════════
   ALEBID — Contact Form Modal CSS
   Pixel-perfect 1:1 alebid-contact-form.html
   WPForms: id=103 | form class=alebid_form | btn class=Btn_form
   Fields: Name_form · Social_form · Busines_form · Chanel_form
           Budget_form (radio) · Task_form · Policy_form (checkbox)
════════════════════════════════════════════════════════════ */

:root {
  --f-border-hover: rgba(212,255,70,0.25);
  --f-red: #FF4646;
}

/* ── GLOBAL OVERFLOW FIX — prevents horizontal scroll on mobile ── */
html, body {
  overflow-x: hidden !important;
  max-width: 100% !important;
}

/* intl-tel-input (WPForms phone) — dropdown не виходить за viewport */
.iti { width: 100% !important; }
.iti__country-list {
  max-width: 100vw !important;
  overflow-x: hidden !important;
  left: 0 !important;
  right: auto !important;
}
.overlay {
  position: fixed; inset: 0; z-index: 9200;
  background: rgba(10,10,10,0);
  backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  display: flex; align-items: flex-end; justify-content: center;
  pointer-events: none;
  overflow-y: auto;          /* scroll lives here */
  overflow-x: hidden;        /* ← блокуємо горизонтальний скрол */
  transition: background .55s, backdrop-filter .55s;
}
.overlay.open {
  background: rgba(10,10,10,.85);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  pointer-events: all;
}
.overlay.closing {
  background: rgba(10,10,10,0);
  backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  pointer-events: none;
}

/* ── PANEL — no internal scroll ─────────────────────────── */
.form-panel {
  position: relative;
  width: 100%; max-width: 760px;
  background: var(--gray);
  border-top: 2px solid var(--accent);
  transform: translateY(100%);
  transition: transform .65s cubic-bezier(.16,1,.3,1);
  margin: 0 24px;
  overflow: hidden;   /* ← було visible, тепер hidden — ріжемо glow */
  flex-shrink: 0;
}
.overlay.open    .form-panel { transform: translateY(0); }
.overlay.closing .form-panel { transform: translateY(100%); }

/* noise */
.form-panel::before {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' 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)'/%3E%3C/svg%3E");
  opacity: .03; pointer-events: none; z-index: 0;
}
/* corner glow */
.form-panel::after {
  content: ''; position: absolute;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(212,255,70,.08) 0%, transparent 70%);
  border-radius: 50%; bottom: -100px; right: -100px;
  pointer-events: none; z-index: 0;
}
/* scanline */
.scanline {
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity: 0; pointer-events: none; z-index: 5;
}
.overlay.open .scanline { animation: scanAnim 3s ease-in-out infinite 1s; }
@keyframes scanAnim {
  0%   { top:0;    opacity:0; }
  10%  { opacity:1; }
  90%  { opacity:1; }
  100% { top:100%; opacity:0; }
}
@keyframes fUp {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── HEADER ─────────────────────────────────────────────── */
.form-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 36px 48px 28px;
  border-bottom: 1px solid var(--border);
  position: relative; z-index: 1;
}
.overlay.open .form-header { animation: fUp .5s cubic-bezier(.16,1,.3,1) .2s both; }

.form-eyebrow {
  display: flex; align-items: center; gap: 12px;
  font-size: 9px; font-weight: 600; letter-spacing: .22em;
  color: var(--accent); text-transform: uppercase; margin-bottom: 10px;
}
.form-eyebrow::before { content:''; display:block; width:24px; height:1px; background:var(--accent); }

.form-title {
  font-size: clamp(20px,3vw,30px); font-weight: 900;
  letter-spacing: -.04em; text-transform: uppercase; line-height: .92; color: var(--white);
}
.form-title span { color: var(--accent); }

.form-sub {
  font-size: 10px; font-weight: 300; letter-spacing: .02em;
  color: rgba(245,245,240,.45); line-height: 1.8; margin-top: 10px;
}

.close-btn {
  width: 40px; height: 40px; border: 1px solid var(--border);
  background: transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all .3s; margin-top: 4px;
  position: relative; overflow: hidden;
}
.close-btn::before {
  content: ''; position: absolute; inset: 0;
  background: var(--accent); transform: scaleY(0); transform-origin: bottom;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.close-btn:hover::before { transform: scaleY(1); }
.close-btn svg { position:relative; z-index:1; stroke:var(--white); transition:stroke .3s; }
.close-btn:hover svg { stroke: var(--black); }

/* ── BODY ────────────────────────────────────────────────── */
.form-body { padding: 36px 48px 40px; position: relative; z-index: 1; }

/* WPForms container reset */
.form-body .wpforms-container,
.form-body .wpforms-container-full { margin: 0 !important; padding: 0 !important; }
.form-body .wpforms-form { font-family: 'Unbounded', sans-serif !important; }

/* 2-column grid */
.form-body .wpforms-field-container {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 2px !important;
}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; }
.form-group { position: relative; }
.form-group.full { grid-column: span 2; }

/* Per-field column spans */
.form-body .Name_form,
.form-body .Social_form,
.form-body .Busines_form,
.form-body .Chanel_form  { grid-column: span 1 !important; }
.form-body .Budget_form,
.form-body .Task_form,
.form-body .Policy_form  { grid-column: 1 / -1 !important; }

/* ── LABELS ─────────────────────────────────────────────── */
.form-label,
.form-body .wpforms-field-label {
  display: block !important;
  font-family: 'Unbounded', sans-serif !important;
  font-size: 8px !important; font-weight: 600 !important;
  letter-spacing: .2em !important; color: var(--muted) !important;
  text-transform: uppercase !important; margin-bottom: 8px !important;
  transition: color .3s;
}
.form-group:focus-within .form-label,
.form-body .wpforms-field:focus-within .wpforms-field-label {
  color: var(--accent) !important;
}

/* ── INPUTS / SELECT / TEXTAREA ─────────────────────────── */
.form-input,
.form-textarea,
.form-select,
.form-body .wpforms-field input[type="text"],
.form-body .wpforms-field input[type="email"],
.form-body .wpforms-field input[type="tel"],
.form-body .wpforms-field input[type="url"],
.form-body .wpforms-field input[type="number"],
.form-body .wpforms-field select,
.form-body .wpforms-field textarea {
  font-family: 'Unbounded', sans-serif !important;
  width: 100% !important; background: var(--gray2) !important;
  border: 1px solid transparent !important; border-radius: 0 !important;
  color: var(--white) !important; font-size: 11px !important;
  font-weight: 400 !important; letter-spacing: .02em !important;
  outline: none !important; box-shadow: none !important;
  transition: border-color .3s, background .3s !important;
  padding: 16px 18px !important;
  -webkit-appearance: none !important; appearance: none !important;
}
.form-input::placeholder,
.form-textarea::placeholder,
.form-body .wpforms-field input::placeholder,
.form-body .wpforms-field textarea::placeholder {
  color: var(--muted) !important; font-weight: 300 !important;
}
.form-input:focus, .form-select:focus, .form-textarea:focus,
.form-body .wpforms-field input:focus,
.form-body .wpforms-field select:focus,
.form-body .wpforms-field textarea:focus {
  border-color: var(--f-border-hover) !important;
  background: var(--gray3) !important;
  box-shadow: inset 0 0 0 1px rgba(212,255,70,.06) !important;
}
.form-textarea,
.form-body .wpforms-field textarea {
  resize: none !important; height: 96px !important; line-height: 1.7 !important;
}

/* floating accent line */
.form-line {
  position: absolute; bottom: 0; left: 0;
  height: 2px; width: 0; background: var(--accent);
  transition: width .4s cubic-bezier(.16,1,.3,1);
}
.form-group:focus-within .form-line { width: 100%; }

/* select arrow */
.select-wrap { position: relative; }
.select-arrow {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  pointer-events: none; color: var(--accent);
}
.form-select,
.form-body .wpforms-field select { padding-right: 44px !important; cursor: pointer !important; }
.form-body .wpforms-field-select { position: relative; }
.form-body .wpforms-field-select::after {
  content: ''; position: absolute; right: 18px; bottom: 20px;
  width: 0; height: 0;
  border-left: 5px solid transparent; border-right: 5px solid transparent;
  border-top: 5px solid var(--accent); pointer-events: none;
}

/* ══════════════════════════════════════════════════════════
   RADIO GROUP (Budget_form)
   Нативна radio-кнопка — невидима.
   Label стає кастомною пілюлею як у design-файлі.
══════════════════════════════════════════════════════════ */

/* --- Fallback (HTML без WPForms) --- */
.radio-group { display: flex; gap: 2px; flex-wrap: wrap; }
.radio-label { position: relative; cursor: pointer; }
.radio-label input[type="radio"] {
  position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;
}
.radio-label span {
  display: block; padding: 10px 16px;
  font-family: 'Unbounded', sans-serif;
  font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  background: var(--gray2); border: 1px solid transparent;
  color: var(--muted); transition: all .25s; user-select: none;
}
.radio-label:hover span { border-color: var(--border); color: var(--white); }
.radio-label input:checked + span {
  background: rgba(212,255,70,.1);
  border-color: var(--f-border-hover);
  color: var(--accent);
}

/* --- WPForms radio (Budget_form) --- */
/* Список */
.form-body .Budget_form .wpforms-field-radio ul {
  display: flex !important; gap: 2px !important;
  flex-wrap: wrap !important;
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
.form-body .Budget_form .wpforms-field-radio li {
  position: relative !important; margin: 0 !important;
}
/* Приховуємо нативний input ПОВНІСТЮ */
.form-body .Budget_form .wpforms-field-radio li input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important; height: 0 !important;
  pointer-events: none !important;
  margin: 0 !important; padding: 0 !important;
}
/* Label = кастомна пілюля */
.form-body .Budget_form .wpforms-field-radio li label {
  display: block !important;
  padding: 10px 16px !important;
  font-family: 'Unbounded', sans-serif !important;
  font-size: 9px !important; font-weight: 600 !important;
  letter-spacing: .12em !important; text-transform: uppercase !important;
  background: var(--gray2) !important; border: 1px solid transparent !important;
  color: var(--muted) !important;
  cursor: pointer !important; user-select: none !important;
  transition: background .25s, border-color .25s, color .25s !important;
  line-height: 1 !important;
  /* Прибрати будь-які WPForms default відступи */
  margin: 0 !important;
}
.form-body .Budget_form .wpforms-field-radio li label:hover {
  border-color: var(--border) !important; color: var(--white) !important;
}
/* :checked → label після input (CSS adjacent sibling) */
.form-body .Budget_form .wpforms-field-radio li input[type="radio"]:checked + label {
  background: rgba(212,255,70,.1) !important;
  border-color: var(--f-border-hover) !important;
  color: var(--accent) !important;
}

/* ══════════════════════════════════════════════════════════
   CHECKBOX (Policy_form)
   Нативний чекбокс — невидимий.
   Псевдоелемент ::before на label = кастомний квадрат.
══════════════════════════════════════════════════════════ */

/* --- Fallback (HTML без WPForms) --- */
.checkbox-wrap { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; margin-top: 4px; }
.checkbox-wrap input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; }
.checkbox-box {
  width: 18px; height: 18px; flex-shrink: 0;
  border: 1px solid var(--border); background: var(--gray2);
  display: flex; align-items: center; justify-content: center;
  transition: all .25s; margin-top: 2px;
}
.checkbox-wrap:hover .checkbox-box { border-color: var(--f-border-hover); }
.checkbox-wrap input:checked ~ .checkbox-box { background: var(--accent); border-color: var(--accent); }
.checkbox-tick { opacity:0; transform:scale(0); transition:all .2s cubic-bezier(.16,1,.3,1); color:var(--black); }
.checkbox-wrap input:checked ~ .checkbox-box .checkbox-tick { opacity:1; transform:scale(1); }
.checkbox-text {
  font-size: 9px; font-weight: 300; letter-spacing: .04em;
  color: rgba(245,245,240,.4); line-height: 1.7;
}
.checkbox-text a { color: var(--accent); text-decoration: none; }

/* --- WPForms checkbox (Policy_form) --- */
/* Скидаємо обгортку */
.form-body .Policy_form ul,
.form-body .Policy_form .wpforms-field-checkbox ul {
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
.form-body .Policy_form li,
.form-body .Policy_form .wpforms-field-checkbox li {
  margin: 0 !important; padding: 0 !important; position: relative !important;
}

/* ── Ховаємо нативний checkbox максимально агресивно ── */
.form-body .Policy_form input[type="checkbox"],
.form-body .Policy_form .wpforms-field-checkbox input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 1px !important; height: 1px !important;
  margin: 0 !important; padding: 0 !important;
  pointer-events: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  border: none !important;
  background: none !important;
  outline: none !important;
  clip: rect(0,0,0,0) !important;
  overflow: hidden !important;
}

/* ── Label = рядок з кастомним квадратом ── */
.form-body .Policy_form label:not(.wpforms-field-label),
.form-body .Policy_form .wpforms-field-checkbox li label {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  cursor: pointer !important;
  font-family: 'Unbounded', sans-serif !important;
  font-size: 9px !important; font-weight: 300 !important;
  letter-spacing: .04em !important;
  color: rgba(245,245,240,.4) !important;
  line-height: 1.7 !important;
  text-transform: none !important;
  margin: 0 !important;
  user-select: none !important;
}

/* ── Кастомний квадрат — псевдоелемент ::before ── */
.form-body .Policy_form label:not(.wpforms-field-label)::before,
.form-body .Policy_form .wpforms-field-checkbox li label::before {
  content: '' !important;
  display: block !important;
  flex-shrink: 0 !important;
  width: 18px !important; height: 18px !important;
  min-width: 18px !important; min-height: 18px !important;
  border: 1px solid var(--border) !important;
  background: var(--gray2) !important;
  background-image: none !important;
  margin-top: 2px !important;
  transition: background .25s, border-color .25s !important;
  box-sizing: border-box !important;
  border-radius: 0 !important;
}

/* hover */
.form-body .Policy_form label:not(.wpforms-field-label):hover::before,
.form-body .Policy_form .wpforms-field-checkbox li label:hover::before {
  border-color: var(--f-border-hover) !important;
}

/* ── Checked стан через CSS (суміжний селектор) ── */
.form-body .Policy_form input[type="checkbox"]:checked + label::before,
.form-body .Policy_form .wpforms-field-checkbox li input[type="checkbox"]:checked + label::before {
  background-color: var(--accent) !important;
  border-color: var(--accent) !important;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='7' viewBox='0 0 10 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3.5L3.8 6.3L9 1' stroke='%230A0A0A' stroke-width='1.5' stroke-linecap='square'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 10px 7px !important;
}

/* ── JS-клас .is-checked — fallback якщо input не поруч з label ── */
.form-body .Policy_form label.is-checked::before,
.form-body .Policy_form .wpforms-field-checkbox li label.is-checked::before {
  background-color: var(--accent) !important;
  border-color: var(--accent) !important;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='7' viewBox='0 0 10 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3.5L3.8 6.3L9 1' stroke='%230A0A0A' stroke-width='1.5' stroke-linecap='square'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 10px 7px !important;
}

/* посилання у тексті */
.form-body .Policy_form label a,
.form-body .Policy_form .wpforms-field-checkbox li label a {
  color: var(--accent) !important;
  text-decoration: none !important;
}
.form-body .Policy_form label a:hover,
.form-body .Policy_form .wpforms-field-checkbox li label a:hover {
  text-decoration: underline !important;
}

/* ── FORM FOOTER (promise + submit) ─────────────────────── */
.form-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 24px; border-top: 1px solid var(--border);
  margin-top: 24px; gap: 20px;
}
.form-promise {
  display: flex; align-items: center; gap: 10px;
  font-size: 8px; font-weight: 500; letter-spacing: .14em;
  color: var(--muted); text-transform: uppercase;
}
.promise-dot { width:5px; height:5px; background:var(--accent); border-radius:50%; flex-shrink:0; }

/* WPForms submit container */
.form-body .wpforms-submit-container {
  display: flex !important; align-items: center !important;
  justify-content: space-between !important; gap: 20px !important;
  flex-wrap: wrap !important;
  padding-top: 24px !important; border-top: 1px solid var(--border) !important;
  margin-top: 24px !important;
}
.form-body .wpforms-submit-container::before {
  content: '● Відповідаю за 3 години';
  font-family: 'Unbounded', sans-serif;
  font-size: 8px; font-weight: 500; letter-spacing: .14em;
  color: var(--muted); text-transform: uppercase; flex: 1;
}

/* ── SUBMIT BUTTON ───────────────────────────────────────── */
.btn-submit,
.form-body .Btn_form,
.form-body .wpforms-submit {
  font-family: 'Unbounded', sans-serif !important;
  font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .1em !important;
  color: var(--black) !important; background: var(--accent) !important;
  border: none !important; border-radius: 0 !important;
  padding: 18px 40px !important; text-transform: uppercase !important;
  cursor: pointer !important; transition: all .3s !important;
  display: inline-flex !important; align-items: center !important;
  justify-content: center !important; gap: 12px !important;
  position: relative !important; overflow: hidden !important;
  min-width: 200px !important; flex-shrink: 0 !important;
}
.btn-submit::after,
.form-body .Btn_form::after,
.form-body .wpforms-submit::after {
  content: '' !important; position: absolute !important;
  top: 0 !important; left: -100% !important;
  width: 100% !important; height: 100% !important;
  background: rgba(255,255,255,.2) !important;
  transform: skewX(-20deg) !important; transition: left .4s !important;
}
.btn-submit:not(.loading):hover::after,
.form-body .wpforms-submit:hover::after { left: 100% !important; }
.btn-submit:not(.loading):hover,
.form-body .wpforms-submit:hover { box-shadow: 0 0 40px rgba(212,255,70,.4) !important; }
.btn-submit.loading { pointer-events: none !important; }

.btn-spinner {
  position: absolute; width: 18px; height: 18px;
  border: 2px solid rgba(10,10,10,.3); border-top-color: var(--black);
  border-radius: 50%; animation: fSpin .7s linear infinite;
  opacity: 0; transition: opacity .2s;
}
.btn-submit.loading .btn-spinner { opacity: 1; }
.btn-text { transition: opacity .2s, transform .2s; }
.btn-submit.loading .btn-text { opacity: 0; transform: scale(.8); }
.btn-arrow { transition: transform .3s; font-size: 14px; }
.btn-submit:hover .btn-arrow { transform: translate(3px,-3px); }
@keyframes fSpin  { to { transform: rotate(360deg); } }
@keyframes fShake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }

/* ── VALIDATION ──────────────────────────────────────────── */
.form-body label.wpforms-error,
.form-body .wpforms-error {
  font-family: 'Unbounded', sans-serif !important;
  font-size: 8px !important; font-weight: 500 !important;
  letter-spacing: .12em !important; color: var(--f-red) !important;
  text-transform: uppercase !important; margin-top: 6px !important;
  background: none !important; border: none !important; padding: 0 !important;
}
.form-body .wpforms-field.wpforms-has-error input,
.form-body .wpforms-field.wpforms-has-error select,
.form-body .wpforms-field.wpforms-has-error textarea {
  border-color: rgba(255,70,70,.4) !important;
}
.form-body .wpforms-field-hp { display: none !important; }
.form-body .wpforms-confirmation-container-full,
.form-body .wpforms-confirmation-container {
  background: transparent !important; border: none !important;
  padding: 32px 0 !important; text-align: center !important;
  font-family: 'Unbounded', sans-serif !important;
  font-size: 13px !important; color: var(--white) !important;
}

/* ── SUCCESS STATE ───────────────────────────────────────── */
.success-panel {
  position: absolute; inset: 0; background: var(--gray);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 60px 48px;
  opacity: 0; pointer-events: none; transition: opacity .5s; z-index: 10; text-align: center;
}
.success-panel.visible { opacity: 1; pointer-events: all; }
.success-icon-wrap {
  width: 72px; height: 72px; border: 2px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 28px; position: relative;
  transform: scale(0); transition: transform .5s cubic-bezier(.16,1,.3,1) .1s;
}
.success-panel.visible .success-icon-wrap { transform: scale(1); }
.success-icon-ring { position:absolute; inset:-8px; border:1px solid rgba(212,255,70,.2); animation:pRing 2s ease-out infinite; }
@keyframes pRing { 0%{transform:scale(1);opacity:.6} 100%{transform:scale(1.5);opacity:0} }
.checkmark { stroke-dasharray:36; stroke-dashoffset:36; transition:stroke-dashoffset .6s cubic-bezier(.16,1,.3,1) .5s; }
.success-panel.visible .checkmark { stroke-dashoffset: 0; }
.success-eyebrow { font-size:9px; font-weight:600; letter-spacing:.22em; color:var(--accent); text-transform:uppercase; margin-bottom:12px; }
.success-title { font-size:clamp(20px,3vw,32px); font-weight:900; letter-spacing:-.04em; text-transform:uppercase; line-height:.92; margin-bottom:14px; }
.success-title span { color: var(--accent); }
.success-text { font-size:10px; font-weight:300; letter-spacing:.02em; color:rgba(245,245,240,.45); line-height:1.9; max-width:380px; margin-bottom:36px; }
.success-cards { display:flex; gap:2px; margin-bottom:36px; }
.success-card { background:var(--gray2); padding:16px 24px; text-align:center; transform:translateY(16px); opacity:0; transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s; }
.success-panel.visible .success-card:nth-child(1) { transform:translateY(0); opacity:1; transition-delay:.6s; }
.success-panel.visible .success-card:nth-child(2) { transform:translateY(0); opacity:1; transition-delay:.72s; }
.success-panel.visible .success-card:nth-child(3) { transform:translateY(0); opacity:1; transition-delay:.84s; }
.sc-val { font-size:18px; font-weight:900; letter-spacing:-.04em; color:var(--accent); }
.sc-label { font-size:8px; font-weight:500; letter-spacing:.16em; color:var(--muted); text-transform:uppercase; margin-top:4px; }
.btn-close-success { font-family:'Unbounded',sans-serif; font-size:10px; font-weight:600; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; background:transparent; border:1px solid var(--border); padding:14px 32px; cursor:pointer; transition:all .3s; }
.btn-close-success:hover { border-color:var(--f-border-hover); color:var(--accent); }

/* ── STAGGER ANIMATIONS ──────────────────────────────────── */
.overlay.open .form-header               { animation: fUp .5s cubic-bezier(.16,1,.3,1) .20s both; }
.overlay.open .form-body .wpforms-field:nth-child(1) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .35s both; }
.overlay.open .form-body .wpforms-field:nth-child(2) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .42s both; }
.overlay.open .form-body .wpforms-field:nth-child(3) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .49s both; }
.overlay.open .form-body .wpforms-field:nth-child(4) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .56s both; }
.overlay.open .form-body .wpforms-field:nth-child(5) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .63s both; }
.overlay.open .form-body .wpforms-field:nth-child(6) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .70s both; }
.overlay.open .form-body .wpforms-field:nth-child(7) { animation: fUp .5s cubic-bezier(.16,1,.3,1) .77s both; }
.overlay.open .form-body .wpforms-submit-container   { animation: fUp .5s cubic-bezier(.16,1,.3,1) .84s both; }
.overlay.open .form-footer               { animation: fUp .5s cubic-bezier(.16,1,.3,1) .77s both; }


/* ── MOBILE ──────────────────────────────────────────────── */
@media (max-width: 700px) {

  /* Панель — точно на всю ширину, без зазорів */
  .overlay { align-items: flex-end !important; }
  .form-panel {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    left: 0 !important;
    right: 0 !important;
    max-height: 92dvh;
    overflow-y: auto;
    overflow-x: hidden;
    box-sizing: border-box !important;
  }
  /* Ріжемо будь-який вихід за межі панелі */
  .form-panel, .form-panel * {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  /* WPForms phone field — не дозволяємо виходити */
  .form-body .wpforms-field-phone,
  .form-body .wpforms-field-phone .iti,
  .form-body .wpforms-field-phone .iti__tel-input,
  .form-body .wpforms-field-phone input[type="tel"] {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* Компактний header */
  .form-header { padding: 16px 18px 14px; }
  .form-title  { font-size: 18px !important; line-height: .95; }
  .form-sub    { font-size: 9px !important; margin-top: 6px !important; }
  .close-btn   { width: 32px !important; height: 32px !important; }

  /* Компактний body */
  .form-body { padding: 12px 18px 16px; }

  /* ── 2 колонки залишаються на мобільному ── */
  .form-grid,
  .form-body .wpforms-field-container {
    grid-template-columns: 1fr 1fr !important;
    gap: 2px !important;
  }

  /* Ці поля — на всю ширину */
  .form-group.full,
  .form-body .Budget_form,
  .form-body .Task_form,
  .form-body .Policy_form { grid-column: 1 / -1 !important; }

  /* Ці поля — по 2 в рядок (span 1) */
  .form-body .Name_form,
  .form-body .Social_form,
  .form-body .Busines_form,
  .form-body .Chanel_form  { grid-column: span 1 !important; }

  /* Менші відступи у полях */
  .form-body .wpforms-field,
  .form-group { padding: 0 !important; margin: 0 !important; }

  .form-body .wpforms-field input[type="text"],
  .form-body .wpforms-field input[type="email"],
  .form-body .wpforms-field input[type="tel"],
  .form-body .wpforms-field select,
  .form-body .wpforms-field textarea {
    padding: 11px 12px !important;
    font-size: 10px !important;
  }

  /* Label менший */
  .form-body .wpforms-field-label,
  .form-label {
    font-size: 7px !important;
    margin-bottom: 5px !important;
    letter-spacing: .14em !important;
  }

  /* Textarea менша */
  .form-body .wpforms-field textarea { height: 72px !important; }

  /* Budget radio — компактні пілюлі */
  .form-body .Budget_form .wpforms-field-radio ul { flex-wrap: wrap !important; gap: 2px !important; }
  .form-body .Budget_form .wpforms-field-radio li label {
    padding: 8px 10px !important;
    font-size: 8px !important;
  }

  /* Footer форми */
  .form-footer  { flex-direction: column; align-items: flex-start; gap: 10px; }
  .wpforms-submit-container,
  .form-body .wpforms-submit-container { flex-direction: column !important; gap: 10px !important; }
  .btn-submit,
  .form-body .wpforms-submit { width: 100% !important; padding: 14px 20px !important; }

  .success-cards { flex-direction: column; }
}
