:root{--rii-primary:#111111;--rii-secondary:#6b7280;--rii-radius:14px;--rii-maxw:980px;--rii-bg:#ffffff;--rii-border:#e5e7eb;--rii-muted:var(--rii-secondary)}
.rii-wrap{
  /* Safe fallback first (some builders can cause invalid var() values) */
  max-width: 920px;
  max-width: var(--rii-maxw);
  margin: 28px auto;
  padding: 0 14px;
  font-size: var(--rii-base-font-size,16px);
}

/* Header alignment (controlled from Settings → UI) */
.rii-title,.rii-subtitle{text-align:var(--rii-header-align,left)}
.rii-card{background:var(--rii-bg);border:1px solid var(--rii-border);border-radius:18px;box-shadow:0 1px 2px rgba(0,0,0,.05)}

/* Slightly richer desktop look */
@media(min-width:1200px){
  :root{--rii-maxw:1180px}
  .rii-wrap{margin:34px auto}
  .rii-card{box-shadow:0 10px 30px rgba(17,24,39,.08)}
}
.rii-card-head{padding:18px 18px 0}
.rii-card-head h3{margin:0;font-size:22px;letter-spacing:-.01em}
.rii-card-head p{margin:8px 0 0}
.rii-card .rii-grid{padding:16px 18px 18px}
.rii-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.rii-span-2{grid-column:span 2}
@media(max-width:760px){.rii-grid{grid-template-columns:1fr}.rii-span-2{grid-column:span 1}}
.rii-field label{display:block;font-weight:650;margin:0 0 6px}
.rii-field input,.rii-field select,.rii-field textarea{width:100%;padding:12px 12px;border:1px solid var(--rii-border);border-radius:12px;outline:none;background:#fff}
.rii-field input:focus,.rii-field select:focus,.rii-field textarea:focus{border-color:rgba(17,17,17,.35);box-shadow:0 0 0 4px rgba(17,17,17,.06)}
.rii-help{display:block;margin-top:6px;color:var(--rii-muted);font-size:12px}
.rii-muted{color:var(--rii-muted);font-size:13px}

.rii-progress{margin:0 0 14px}
.rii-progress-bar{height:10px;border-radius:999px;background:rgba(17,17,17,.08);overflow:hidden;position:relative}
.rii-progress-bar::after{content:"";position:absolute;inset:0;transform-origin:left;transform:scaleX(var(--rii-progress,0.25));background:var(--rii-primary)}
.rii-progress-steps{display:flex;justify-content:space-between;margin-top:10px}
.rii-step-dot{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--rii-border);background:#fff;font-weight:700;color:#111}
.rii-step-dot.is-active,.rii-step-dot.is-done{border-color:var(--rii-primary);background:var(--rii-primary);color:#fff}

.rii-steps{margin-top:10px}
.rii-step{display:none}
.rii-step.is-active{display:block}


/* Consent block */
.rii-consent{display:flex;gap:12px;align-items:center;padding:14px 16px;border:1px solid var(--rii-border);border-radius:16px;background:#fafafa}
.rii-consent input{width:18px;height:18px;accent-color:var(--rii-primary)}
.rii-consent label{font-weight:650}

.rii-locations-cards{display:grid;grid-template-columns:1fr;gap:12px;padding:16px 18px 18px}
.rii-emirate-block{border:1px solid var(--rii-border);border-radius:18px;background:#fff;overflow:hidden}
.rii-emirate-title{padding:14px 16px;font-weight:900;font-size:14px;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(90deg, rgba(17,17,17,.06), rgba(17,17,17,0));border-bottom:1px solid var(--rii-border)}
.rii-emirate-block .rii-location-card{border:0;border-radius:0;border-bottom:1px solid var(--rii-border)}
.rii-emirate-block .rii-location-card:last-child{border-bottom:0}
.rii-location-card{border:1px solid var(--rii-border);border-radius:18px;background:#fff;overflow:hidden}
.rii-location-head{display:flex;align-items:flex-start;gap:12px;padding:16px}
.rii-location-check{display:flex;align-items:flex-start;padding-top:4px}
.rii-location-check input{width:18px;height:18px;accent-color:var(--rii-primary);cursor:pointer}
.rii-location-info{flex:1;min-width:0}
.rii-location-title{font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rii-location-sub{margin-top:6px;color:var(--rii-muted);font-size:12px;line-height:1.3}
.rii-location-meta{margin-top:6px;font-size:12px}
.rii-location-meta a{color:var(--rii-primary);text-decoration:none}
.rii-location-meta a:hover{text-decoration:underline}
.rii-badge{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;border-radius:999px;border:1px solid var(--rii-border);background:#f9fafb;font-size:12px;font-weight:650}

.rii-dates{padding:0 16px 16px}
.rii-date-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.rii-date-chip{display:inline-flex;gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--rii-border);border-radius:999px;background:#fff;cursor:pointer;font-weight:650}
.rii-date-chip input{margin:0;display:none}
.rii-date-chip__label{font-size:13px}
.rii-date-chip.is-selected{border-color:var(--rii-primary);background:rgba(17,17,17,.03);box-shadow:0 0 0 3px rgba(17,17,17,.06)}

.rii-actions{display:flex;justify-content:flex-end;gap:10px;margin:12px 0 0}
.rii-actions .rii-btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:120px;box-sizing:border-box}

@media (max-width:520px){
  .rii-actions{justify-content:space-between}
  .rii-actions .rii-btn{min-width:0;flex:1 1 0}
  .rii-actions .rii-btn{white-space:normal;line-height:1.2;font-size:14px;padding:12px 14px}
}
.rii-btn{
  padding:12px 16px;
  border-radius:var(--rii-radius);
  border:1px solid var(--rii-border);
  background:#fff;
  color:#111;
  cursor:pointer;
  font-weight:700;
  line-height:1;
  white-space:nowrap;
  user-select:none;
  /* Keep transitions in sync with variables emitted by the front-end (class-rii-front.php). */
  transition: background var(--rii-transition, 160ms) ease, border-color var(--rii-transition, 160ms) ease, transform var(--rii-transition, 160ms) ease;
}
.rii-btn-primary{
  background:var(--rii-primary) !important;
  border-color:var(--rii-primary) !important;
  color:var(--rii-primary-text, #fff) !important;
}
.rii-btn-primary:hover{
  /* Use the correct hover var name + strong fallback to avoid “invisible” buttons when settings are blank. */
  background:var(--rii-primary-hover, var(--rii-primary)) !important;
  border-color:var(--rii-primary-hover, var(--rii-primary)) !important;
  color:var(--rii-primary-hover-text, var(--rii-primary-text, #fff)) !important;
  transform:translateY(-1px)
}
.rii-btn-primary:focus-visible{
  outline: 3px solid rgba(0,0,0,.12);
  outline-offset: 2px;
}
.rii-btn-ghost{background:#fff !important;color:#111 !important}
.rii-btn-ghost:hover{background:rgba(0,0,0,.03) !important;transform:translateY(-1px)}

/* Loading state / double-submit prevention */
.rii-btn.rii-btn--loading,.rii-btn:disabled{opacity:.75;cursor:not-allowed}


/* Review */
.rii-review{padding:16px 18px 18px}
.rii-review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(max-width:760px){.rii-review-grid{grid-template-columns:1fr}}
.rii-review-card{border:1px solid var(--rii-border);border-radius:18px;padding:14px 16px;background:#fff}
.rii-review-title{font-weight:900;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--rii-muted);margin-bottom:8px}
.rii-review-line{display:flex;justify-content:space-between;gap:16px;padding:8px 0;border-bottom:1px dashed var(--rii-border);flex-wrap:wrap}
.rii-review-line:last-child{border-bottom:0}
.rii-review-line .k{color:var(--rii-muted);font-size:12px;font-weight:800;flex:0 0 auto}
.rii-review-line .v{font-weight:650;text-align:right;overflow-wrap:anywhere;word-break:break-word;min-width:0;flex:1 1 auto}
@media(max-width:520px){
  .rii-review-line{flex-direction:column;align-items:flex-start;gap:6px}
  .rii-review-line .v{text-align:left;width:100%}
}
.rii-review-events{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.rii-review-event .name{font-weight:800}
.rii-review-event .code{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;border-radius:999px;border:1px solid var(--rii-border);background:#f9fafb;font-size:12px;font-weight:650}
.rii-review-event .dates{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.rii-review-event .chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--rii-border);background:#fff;font-size:12px;font-weight:650}

.rii-alert{padding:12px 14px;border-radius:14px;margin:0 0 14px;border:1px solid var(--rii-border);background:#fff}
.rii-success{background:#ecfdf5;border-color:#a7f3d0}
.rii-error{background:#fff1f2;border-color:#fecdd3}

/* Note: we intentionally avoid “full-bleed/breakout” layout.
   Some themes/builders already manage page width; full-bleed can cause
   horizontal scrolling and odd centering issues on certain devices. */

.rii-form.is-hidden{display:none;}

/* Success overlay */
.rii-success-overlay{max-width:920px;max-width:var(--rii-maxw);margin:22px auto;}
@media (max-width:520px){
  .rii-success-overlay{padding-bottom:90px;}
}
.rii-success-card{border:1px solid var(--rii-border);border-radius:24px;padding:26px 22px;background:#fff;box-shadow:0 24px 60px rgba(0,0,0,.06);text-align:center;position:relative;overflow:hidden}
.rii-success-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;background:#f3f4f6;border:1px solid var(--rii-border);font-weight:800;font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.rii-success-title{margin:10px 0 6px;font-size:34px;font-weight:900}
.rii-success-text{color:var(--rii-muted);margin:0 auto 10px;max-width:520px}
.rii-success-vn{margin:10px 0 16px;font-size:16px}
.rii-success-vn code{font-weight:900;font-size:16px;padding:4px 10px;border:1px solid var(--rii-border);border-radius:999px;background:#f9fafb}
.rii-success-actions{display:flex;justify-content:center;margin-top:14px}
.rii-success-loader{width:54px;height:54px;border-radius:999px;border:5px solid rgba(0,0,0,.08);border-top-color:var(--rii-primary);margin:0 auto 14px;animation:riiSpin 1s linear infinite}
.rii-success-check{display:none;width:56px;height:56px;border-radius:999px;margin:0 auto 14px;background:rgba(17,17,17,.06);color:var(--rii-primary);font-size:34px;line-height:56px;font-weight:900}
.rii-success-card.is-done .rii-success-loader{display:none}
.rii-success-card.is-done .rii-success-check{display:block;animation:riiPop .28s ease-out}

@keyframes riiSpin{to{transform:rotate(360deg)}}
@keyframes riiPop{0%{transform:scale(.75);opacity:.2}100%{transform:scale(1);opacity:1}}

/* Hover effects (customizable via Settings) */
.rii-btn{
  transition: background var(--rii-transition,150ms) ease, color var(--rii-transition,150ms) ease, border-color var(--rii-transition,150ms) ease, transform var(--rii-transition,150ms) ease, box-shadow var(--rii-transition,150ms) ease;
}
.rii-btn-primary:hover{
  background: var(--rii-primary-hover, var(--rii-primary));
  color: var(--rii-primary-hover-text, var(--rii-primary-text, #fff));
  transform: translateY(-1px);
}
.rii-btn-secondary:hover{
  filter: brightness(0.96);
  transform: translateY(-1px);
}

/* Desktop polish */
@media (min-width: 1200px){
  :root{--rii-maxw:1180px}
  .rii-card{box-shadow:0 12px 30px rgba(17,24,39,.08)}
  .rii-stepper{margin-bottom:18px}
}
