/* Public UI - minimal but premium */
.far-root { direction: rtl; font-family: inherit; color: var(--far-text, #0b2d50); }
.far-root *, .far-root *::before, .far-root *::after { box-sizing: border-box; }
.far-shell { max-width: var(--far-maxw, 820px); margin: 24px auto; padding: 16px; }
.far-card {
  background: var(--far-card-bg, var(--far-bg));
  border: 1px solid var(--far-border, rgba(11,45,80,.10));
  border-radius: var(--far-radius, 20px);
  box-shadow: 0 16px 40px rgba(11,45,80, calc(.10 * var(--far-shadow-on, 1)));
  overflow: hidden;
  position: relative;
}
.far-hidden { display: none; }
.far-anim-in { animation: farPop .5s cubic-bezier(.2,.9,.2,1) both; }
@keyframes farPop { from {opacity:0; transform: translateY(14px) scale(.985);} to {opacity:1; transform:none;} }

.far-top { padding: 18px 18px 0; display:flex; justify-content:center; }
.far-logo { max-height: 58px; width:auto; }
.far-logo-placeholder { height: 44px; min-width: 140px; border-radius: 14px; background: rgba(11,45,80,.06); display:flex; align-items:center; justify-content:center; color: rgba(11,45,80,.7); font-weight:700; letter-spacing:.3px; }

.far-hero { margin: 14px 18px 0; border-radius: 18px; overflow:hidden; border:1px solid rgba(11,45,80,.08); background: rgba(11,45,80,.04); }
.far-hero img { width:100%; height:auto; display:block; }
.far-hero-placeholder { height: 220px; position:relative; }
.far-hero-shape { position:absolute; inset: -40px -20px auto auto; width: 240px; height: 240px; border-radius: 40px; background: radial-gradient(circle at 30% 30%, rgba(246,169,8,.35), rgba(246,169,8,0)); transform: rotate(20deg); }
.far-hero-shape.two { inset: auto auto -60px -60px; width: 280px; height: 280px; background: radial-gradient(circle at 30% 30%, rgba(11,45,80,.18), rgba(11,45,80,0)); transform: rotate(-12deg); }

.far-intro { padding: 18px 20px 8px; }
.far-title { margin: 0 0 8px; font-size: 22px; color: var(--far-ghost-text, var(--far-primary)) !important; }
.far-body { margin: 0; color: rgba(11,45,80,.78); line-height: 1.85; font-size: 15px; }

.far-actions-row { padding: 10px 20px 18px; display:flex; justify-content:center; }
.far-root .far-btn {
  border: 0;
  border-radius: 14px;
  padding: 12px 18px;
  cursor: pointer;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 700;
  transition: transform .16s ease, box-shadow .22s ease, background .22s ease, color .22s ease, opacity .2s ease;
  user-select:none;
  text-decoration:none;
  position: relative;
  min-height: 44px;
  line-height: 1;
  letter-spacing: .2px;
}
.far-root .far-btn:focus-visible { outline: none; box-shadow: 0 0 0 4px rgba(246,169,8,.22), 0 14px 24px rgba(11,45,80,.16); }
.far-root .far-btn:active { transform: translateY(1px) scale(.99); }
.far-root .far-btn-primary {
  /* fallback */
  background: var(--far-primary) !important;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--far-primary) 92%, #000 8%),
    color-mix(in srgb, var(--far-primary) 72%, #000 28%)
  );
  color: var(--far-primary-text, #fff) !important;
  box-shadow: 0 14px 24px rgba(11,45,80,.18);
}
.far-root .far-btn-primary::before {
  content:"";
  position:absolute;
  inset: 1px;
  border-radius: 13px;
  background: radial-gradient(circle at 20% 20%, rgba(246,169,8,.28), rgba(246,169,8,0) 55%);
  opacity: .9;
  pointer-events:none;
  mix-blend-mode: screen;
}
.far-root .far-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 18px 32px rgba(11,45,80,.22); }
.far-root .far-btn-ghost {
  background: var(--far-ghost-bg, rgba(11,45,80,.05)) !important;
  color: var(--far-ghost-text, var(--far-primary)) !important;
  border: 1px solid var(--far-input-border, rgba(11,45,80,.12));
  box-shadow: 0 10px 16px rgba(11,45,80,.08);
}
.far-btn-ghost:hover { transform: translateY(-1px); background: rgba(11,45,80,.07); box-shadow: 0 14px 22px rgba(11,45,80,.10); }
.far-btn-arrow { opacity:.9; font-weight:900; }

/* (حذف شد) نمایش لینک مستقیم در فرانت */

.far-header-mini {
  padding: 14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom: 1px solid rgba(11,45,80,.08);
  background: linear-gradient(180deg, rgba(11,45,80,.03), transparent);
}
.far-mini-brand { display:flex; align-items:center; gap:10px; }
.far-logo-mini { max-height: 34px; width:auto; }
.far-dot { width: 10px; height: 10px; background: var(--far-accent); border-radius: 50%; box-shadow: 0 0 0 6px rgba(246,169,8,.18); }
.far-mini-title { font-weight: 800; color: var(--far-ghost-text, var(--far-primary)) !important; }
.far-close { width: 38px; height: 38px; border-radius: 12px; border: 1px solid rgba(11,45,80,.10); background: rgba(255,255,255,.7); cursor:pointer; font-size: 20px; line-height: 1; transition: transform .15s ease, background .2s ease; }
.far-close:hover { background: var(--far-input-bg, #fff); }
.far-close:active { transform: scale(.98); }

.far-loading { padding: 26px 18px 30px; display:flex; flex-direction:column; align-items:center; gap:10px; }
.far-spinner {
  width: 34px; height: 34px; border-radius: 50%;
  border: 3px solid rgba(11,45,80,.12);
  border-top-color: var(--far-accent);
  animation: farSpin 1s linear infinite;
}
@keyframes farSpin { to { transform: rotate(360deg);} }
.far-loading-text { color: rgba(11,45,80,.65); }

.far-form { padding: 18px 18px 22px; }
.far-form-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.far-field { display:flex; flex-direction:column; gap: 8px; }
.far-field.wide { grid-column: 1 / -1; }
.far-field label { font-size: 13px; color: rgba(11,45,80,.82); font-weight: 700; }
.far-req { color: #c62828; margin-right: 6px; }
.far-field input, .far-field textarea, .far-field select {
  border: 1px solid var(--far-input-border, #d1d5db);
  background: var(--far-input-bg, #ffffff) !important;
  color: var(--far-text, #0b2d50) !important;
  border-radius: 14px;
  padding: 12px 14px;
  outline: none;
  transition: box-shadow .2s ease, border-color .2s ease;
  font-size: 14px;
  -webkit-text-fill-color: var(--far-text, #0b2d50);
  caret-color: var(--far-text, #0b2d50);
}
/* Override any theme that forces white text or transparent bg on inputs */
.far-root input,
.far-root textarea,
.far-root select {
  color: var(--far-text, #0b2d50) !important;
  background-color: var(--far-input-bg, #ffffff) !important;
  -webkit-text-fill-color: var(--far-text, #0b2d50) !important;
}
/* Placeholder contrast */
.far-field input::placeholder,
.far-field textarea::placeholder {
  color: rgba(11,45,80,.42) !important;
  opacity: 1;
}
.far-root input::placeholder,
.far-root textarea::placeholder {
  color: rgba(11,45,80,.42) !important;
  opacity: 1;
}
/* Select option text */
.far-field select option {
  background: #ffffff;
  color: #0b2d50;
}
.far-field textarea { min-height: 96px; resize: vertical; }
.far-field input:focus, .far-field textarea:focus, .far-field select:focus {
  border-color: var(--far-accent, #f6a908);
  box-shadow: 0 0 0 4px rgba(246,169,8,.20);
  background: var(--far-input-bg, #ffffff) !important;
  color: var(--far-text, #0b2d50) !important;
}
/* Autofill override - prevent browsers from overriding bg/text colors */
.far-root input:-webkit-autofill,
.far-root input:-webkit-autofill:hover,
.far-root input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--far-text, #0b2d50) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--far-input-bg, #ffffff) inset !important;
  transition: background-color 5000s ease-in-out 0s;
}
.far-err { min-height: 18px; font-size: 12px; color: #b71c1c; }

.far-form-actions { margin-top: 12px; display:flex; gap: 10px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.far-form-note { margin-top: 12px; color: rgba(11,45,80,.60); font-size: 12.5px; line-height: 1.8; padding: 10px 12px; background: rgba(11,45,80,.04); border-radius: 14px; border: 1px dashed rgba(11,45,80,.14); }

.far-slide-in { animation: farSlideIn .35s cubic-bezier(.2,.9,.2,1) both; }
@keyframes farSlideIn { from { opacity:0; transform: translateX(-14px);} to { opacity:1; transform:none;} }
.far-slide-out { animation: farSlideOut .25s ease both; }
@keyframes farSlideOut { to { opacity:0; transform: translateX(14px);} }

.far-modal { position: fixed; inset: 0; z-index: 99999; }
.far-modal-backdrop { position:absolute; inset:0; background: rgba(8,18,28,.55); backdrop-filter: blur(6px); opacity:0; animation: farFade .25s ease both; }
@keyframes farFade { to {opacity:1;} }
.far-modal-panel {
  position:absolute; left:50%; top:50%;
  transform: translate(-50%,-50%) scale(.985);
  width: min(520px, calc(100% - 24px));
  background: var(--far-input-bg, #fff);
  border-radius: 22px;
  border: 1px solid rgba(11,45,80,.10);
  box-shadow: 0 24px 70px rgba(0,0,0,.28);
  padding: 20px 18px 18px;
  animation: farModalPop .35s cubic-bezier(.2,.9,.2,1) both;
  overflow:hidden;
}
@keyframes farModalPop { from {opacity:0; transform: translate(-50%,-50%) scale(.97);} to {opacity:1; transform: translate(-50%,-50%) scale(1);} }
.far-modal-icon { width: 64px; height: 64px; border-radius: var(--far-radius, 20px); margin: 2px auto 10px; display:flex; align-items:center; justify-content:center; font-size: 28px; }
.far-modal-title { margin: 0; text-align:center; color: var(--far-ghost-text, var(--far-primary)) !important; font-size: 20px; }
.far-modal-body { margin: 10px 0 0; text-align:center; color: rgba(11,45,80,.75); line-height: 1.85; }
.far-modal-actions { margin-top: 16px; display:flex; gap: 10px; justify-content:center; flex-wrap:wrap; }

.far-confetti {
  position:absolute; inset: -40px -40px auto auto; width: 260px; height: 260px; border-radius: 40px;
  background: radial-gradient(circle at 30% 30%, rgba(246,169,8,.35), rgba(246,169,8,0));
  transform: rotate(18deg);
  pointer-events:none;
}

@media (max-width: 640px) {
  .far-shell { padding: 10px; margin: 10px auto; }
  .far-form-grid { grid-template-columns: 1fr; }
  .far-actions-row { padding-bottom: 14px; }
}


/* Link shortcode (styled as a button) */
.far-root .far-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 18px;
  border-radius: 14px;
  font-weight: 800;
  text-decoration:none;
  cursor:pointer;
  background: var(--far-primary) !important;
  color: var(--far-primary-text, #fff) !important;
  border: 1px solid color-mix(in srgb, var(--far-primary) 82%, #000 18%);
  box-shadow: 0 14px 24px rgba(11,45,80, calc(.18 * var(--far-shadow-on, 1)));
  transition: transform .16s ease, box-shadow .22s ease, filter .22s ease;
}
.far-root .far-link:hover{ transform: translateY(-1px); filter: brightness(1.02); box-shadow: 0 18px 32px rgba(11,45,80, calc(.22 * var(--far-shadow-on, 1))); }
.far-root .far-link:active{ transform: translateY(1px) scale(.99); }
.far-root .far-link:focus-visible{ outline: none; box-shadow: 0 0 0 4px rgba(246,169,8,.22), 0 14px 24px rgba(11,45,80, calc(.16 * var(--far-shadow-on, 1))); }


/* Density presets */
.far-root[data-density="compact"] .far-shell{ padding: 10px; }
.far-root[data-density="compact"] .far-card{ }
.far-root[data-density="compact"] .far-form-grid{ gap: 10px; }
.far-root[data-density="compact"] .far-btn{ padding: 10px 14px; min-height: 40px; }

.far-root[data-density="comfortable"] .far-form-grid{ gap: 16px; }
.far-root[data-density="comfortable"] .far-btn{ padding: 14px 20px; min-height: 48px; }
