/* =============================================================
   Unik CTA Block – Frontend Styles
   ============================================================= */

/* ---------- Design Tokens ----------------------------------- */
:root {
  --unik-primary:      #0F1F3D;
  --unik-accent:       #FF6B35;
  --unik-accent-hover: #e85a24;
  --unik-text:         #0F1F3D;
  --unik-muted:        #6B7280;
  --unik-border:       #E5E7EB;
  --unik-surface:      #FFFFFF;
  --unik-bg-subtle:    #F8F9FC;
  --unik-radius:       14px;
  --unik-shadow:       0 20px 60px rgba(15, 31, 61, .18);
  --unik-transition:   220ms cubic-bezier(.4, 0, .2, 1);
  --unik-font:         'Sora', 'Segoe UI', system-ui, sans-serif;
}

/* ---------- CTA Section ------------------------------------- */
.unik-cta {
  position:      relative;
  overflow:      hidden;
  background:    linear-gradient(135deg, #0F1F3D 0%, #1a3464 50%, #0d2a5e 100%);
  border-radius: var(--unik-radius);
  padding:       64px 40px;
  text-align:    center;
  font-family:   var(--unik-font);
  color:         #fff;
}

/* Decorative circles */
.unik-cta__bg-circle {
  position:         absolute;
  border-radius:    50%;
  pointer-events:   none;
}
.unik-cta__bg-circle--1 {
  width:      380px;
  height:     380px;
  top:        -120px;
  right:      -80px;
  background: radial-gradient(circle, rgba(255,107,53,.20) 0%, transparent 70%);
}
.unik-cta__bg-circle--2 {
  width:      260px;
  height:     260px;
  bottom:     -100px;
  left:       -40px;
  background: radial-gradient(circle, rgba(255,255,255,.07) 0%, transparent 70%);
}

.unik-cta__inner {
  position:   relative;
  z-index:    1;
  max-width:  640px;
  margin:     0 auto;
  display:    flex;
  flex-direction: column;
  align-items: center;
  gap:        20px;
}

.unik-cta__icon {
  color:         rgba(255,255,255,.9);
  margin-bottom: 4px;
}

.unik-cta__title {
  font-size:   clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -.02em;
  margin:      0;
  color:       #fff;
}

/* ---------- CTA Button -------------------------------------- */
.unik-cta__btn {
  display:        inline-flex;
  align-items:    center;
  gap:            10px;
  background:     var(--unik-accent);
  color:          #fff;
  font-family:    inherit;
  font-size:      1rem;
  font-weight:    600;
  letter-spacing: .01em;
  padding:        14px 32px;
  border:         none;
  border-radius:  50px;
  cursor:         pointer;
  transition:     background var(--unik-transition),
                  transform  var(--unik-transition),
                  box-shadow var(--unik-transition);
  box-shadow:     0 4px 20px rgba(255,107,53,.45);
}
.unik-cta__btn:hover,
.unik-cta__btn:focus-visible {
  background:  var(--unik-accent-hover);
  transform:   translateY(-2px);
  box-shadow:  0 8px 28px rgba(255,107,53,.55);
  outline:     2px solid #fff;
  outline-offset: 3px;
}
.unik-cta__btn--sm {
  font-size:  .9rem;
  padding:    10px 24px;
  margin-top: 8px;
}

/* ---------- Modal – Overlay --------------------------------- */
.unik-cta-modal {
  position:   fixed;
  inset:      0;
  z-index:    99999;
  display:    flex;
  align-items: center;
  justify-content: center;
  padding:    16px;
}
.unik-cta-modal[hidden] { display: none; }

.unik-cta-modal__backdrop {
  position:   absolute;
  inset:      0;
  background: rgba(10, 18, 40, .68);
  backdrop-filter: blur(4px);
  animation:  unik-backdrop-in var(--unik-transition) both;
}

.unik-cta-modal__panel {
  position:        relative;
  background:      var(--unik-surface);
  border-radius:   20px;
  box-shadow:      var(--unik-shadow);
  width:           100%;
  max-width:       480px;
  max-height:      90dvh;
  overflow-y:      auto;
  padding:         48px 40px 40px;
  animation:       unik-panel-in 300ms cubic-bezier(.34,1.56,.64,1) both;
}

@media (max-width: 480px) {
  .unik-cta-modal__panel { padding: 40px 24px 32px; }
  .unik-cta { padding: 48px 24px; }
}

/* ---------- Modal – Header ---------------------------------- */
.unik-cta-modal__close {
  position:   absolute;
  top:        16px;
  right:      16px;
  width:      36px;
  height:     36px;
  border:     1px solid var(--unik-border);
  border-radius: 50%;
  background: transparent;
  cursor:     pointer;
  display:    flex;
  align-items: center;
  justify-content: center;
  color:      var(--unik-muted);
  transition: all var(--unik-transition);
}
.unik-cta-modal__close:hover { background: var(--unik-bg-subtle); color: var(--unik-text); }

.unik-cta-modal__header { text-align: center; margin-bottom: 32px; }

.unik-cta-modal__icon {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  width:  60px;
  height: 60px;
  border-radius: 16px;
  background: linear-gradient(135deg, #0F1F3D, #1a3464);
  color:      #fff;
  margin-bottom: 20px;
}

.unik-cta-modal__title {
  font-size:   1.45rem;
  font-weight: 700;
  color:       var(--unik-text);
  margin:      0 0 8px;
  letter-spacing: -.02em;
}

.unik-cta-modal__subtitle {
  color:      var(--unik-muted);
  font-size:  .95rem;
  margin:     0;
  line-height: 1.5;
}

/* ---------- Form -------------------------------------------- */
.unik-cta-form { display: flex; flex-direction: column; gap: 20px; }

.unik-cta-form__honeypot {
  position: absolute;
  left:     -9999px;
  opacity:  0;
  pointer-events: none;
}

.unik-cta-form__group { display: flex; flex-direction: column; gap: 6px; }

.unik-cta-form__label {
  font-size:   .875rem;
  font-weight: 600;
  color:       var(--unik-text);
}
.unik-cta-form__label span { color: var(--unik-accent); margin-left: 2px; }
.unik-cta-form__optional { font-weight: 400; color: var(--unik-muted); font-size: .8rem; }

.unik-cta-form__input {
  width:          100%;
  padding:        12px 16px;
  font-family:    inherit;
  font-size:      .95rem;
  color:          var(--unik-text);
  background:     var(--unik-bg-subtle);
  border:         1.5px solid var(--unik-border);
  border-radius:  10px;
  transition:     border-color var(--unik-transition), box-shadow var(--unik-transition);
  outline:        none;
  box-sizing:     border-box;
}
.unik-cta-form__input::placeholder { color: #b0b8c8; }
.unik-cta-form__input:focus {
  border-color: var(--unik-primary);
  box-shadow:   0 0 0 3px rgba(15,31,61,.12);
  background:   #fff;
}
.unik-cta-form__input[aria-invalid="true"] {
  border-color: #ef4444;
  box-shadow:   0 0 0 3px rgba(239,68,68,.12);
}

.unik-cta-form__error {
  font-size: .8rem;
  color:     #ef4444;
  min-height: 1rem;
}

.unik-cta-form__feedback {
  border-radius: 10px;
  padding:       12px 16px;
  font-size:     .9rem;
  font-weight:   500;
  line-height:   1.5;
}
.unik-cta-form__feedback--error {
  background: #fef2f2;
  color:      #b91c1c;
  border:     1px solid #fecaca;
}

.unik-cta-form__submit {
  display:      flex;
  align-items:  center;
  justify-content: center;
  gap:          10px;
  background:   var(--unik-accent);
  color:        #fff;
  font-family:  inherit;
  font-size:    1rem;
  font-weight:  600;
  padding:      15px;
  border:       none;
  border-radius: 10px;
  cursor:       pointer;
  transition:   background var(--unik-transition), transform var(--unik-transition), box-shadow var(--unik-transition);
  box-shadow:   0 4px 16px rgba(255,107,53,.35);
  margin-top:   4px;
}
.unik-cta-form__submit:hover:not(:disabled) {
  background:   var(--unik-accent-hover);
  transform:    translateY(-1px);
  box-shadow:   0 6px 20px rgba(255,107,53,.45);
}
.unik-cta-form__submit:disabled { opacity: .7; cursor: not-allowed; }

.unik-cta-form__submit-loading { display: flex; align-items: center; gap: 8px; }

.unik-cta-form__privacy {
  text-align: center;
  font-size:  .78rem;
  color:      var(--unik-muted);
  margin:     0;
}
.unik-cta-form__privacy a { color: var(--unik-primary); }

/* ---------- Success state ----------------------------------- */
.unik-cta-modal__success {
  text-align: center;
  padding:    8px 0;
  animation:  unik-panel-in 300ms cubic-bezier(.34,1.56,.64,1) both;
}
.unik-cta-modal__success[hidden] { display: none; }
.unik-cta-modal__success-icon { color: #16a34a; margin-bottom: 20px; }
.unik-cta-modal__success h4 {
  font-size:  1.4rem;
  font-weight: 700;
  color:      var(--unik-text);
  margin:     0 0 12px;
}
.unik-cta-modal__success p {
  color:      var(--unik-muted);
  line-height: 1.6;
  margin:     0;
}
.unik-cta-modal__success-close { margin-top: 24px; }

/* ---------- Spinner ----------------------------------------- */
@keyframes unik-spin  { to { transform: rotate(360deg); } }
.unik-spin { animation: unik-spin 600ms linear infinite; }

/* ---------- Animations -------------------------------------- */
@keyframes unik-backdrop-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes unik-panel-in {
  from { opacity: 0; transform: translateY(24px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}

/* ---------- Reduced motion ---------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .unik-cta-modal__backdrop,
  .unik-cta-modal__panel,
  .unik-cta-modal__success { animation: none; }
}
