/* =========================
   SMUI (Sportmoto UI) — Toasts + Modals
   ========================= */

:root{
  --smui-z: 999999;
  --smui-bg: #121316;
  --smui-bg2:#0f1013;
  --smui-txt:#f3f4f6;
  --smui-sub:#c9cbd1;
  --smui-border: rgba(255,255,255,.08);
  --smui-shadow: 0 12px 40px rgba(0,0,0,.55);
  --smui-radius: 14px;
  --smui-pad: 14px;
  --smui-gap: 10px;

  --smui-green:#22c55e;
  --smui-red:#ef4444;
  --smui-yellow:#f59e0b;
  --smui-blue:#3b82f6;
}

/* ---------- Toast container ---------- */
.smui-toasts{
  position: fixed;
  z-index: var(--smui-z);
  display:flex;
  flex-direction:column;
  gap: 10px;
  padding: 14px;
  pointer-events:none; /* deixa clique passar, mas o toast em si aceita clique */
}

.smui-pos-tr{ top: 10px; right: 10px; align-items:flex-end; }
.smui-pos-tl{ top: 10px; left: 10px; align-items:flex-start; }
.smui-pos-br{ bottom: 10px; right: 10px; align-items:flex-end; }
.smui-pos-bl{ bottom: 10px; left: 10px; align-items:flex-start; }

/* ---------- Toast ---------- */
.smui-toast{
  pointer-events:auto;
  width: min(520px, calc(100vw - 28px));
  background: linear-gradient(180deg, var(--smui-bg), var(--smui-bg2));
  color: var(--smui-txt);
  border: 1px solid var(--smui-border);
  border-radius: var(--smui-radius);
  box-shadow: var(--smui-shadow);
  overflow:hidden;
  transform: translateY(6px);
  opacity: 0;
  animation: smui_in .18s ease-out forwards;
}

@keyframes smui_in{
  to { transform: translateY(0); opacity: 1; }
}
@keyframes smui_out{
  to { transform: translateY(10px); opacity: 0; }
}

.smui-toast__row{
  display:flex;
  gap: 12px;
  padding: var(--smui-pad);
  align-items:flex-start;
}

.smui-toast__icon{
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top: 2px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.smui-toast__icon svg{ width: 16px; height: 16px; display:block; }

.smui-toast__body{ flex:1; min-width: 0; }
.smui-toast__title{
  font-weight: 700;
  font-size: 15px;
  line-height: 1.2;
  margin: 0 0 4px 0;
}
.smui-toast__msg{
  font-size: 13px;
  line-height: 1.35;
  color: var(--smui-sub);
  margin: 0;
}

.smui-toast__actions{
  display:flex;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.smui-toast__btn{
  appearance:none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--smui-txt);
  border-radius: 10px;
  padding: 7px 10px;
  font-size: 12px;
  cursor:pointer;
}
.smui-toast__btn:hover{ background: rgba(255,255,255,.10); }

.smui-toast__close{
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}
.smui-toast__close:hover{ background: rgba(255,255,255,.10); }
.smui-toast__close svg{ width: 16px; height: 16px; opacity: .9; }

/* progress bar (padrão print) */
.smui-toast__bar{
  height: 3px;
  background: rgba(255,255,255,.10);
}
.smui-toast__bar > i{
  display:block;
  height:100%;
  width:100%;
  transform-origin: left;
  transform: scaleX(1);
  animation: smui_progress linear forwards;
  animation-duration: var(--smui-duration, 5000ms);
  background: var(--smui-accent, var(--smui-green));
}
@keyframes smui_progress{
  to { transform: scaleX(0); }
}

/* Types */
.smui-success{ --smui-accent: var(--smui-green); }
.smui-error  { --smui-accent: var(--smui-red); }
.smui-warn   { --smui-accent: var(--smui-yellow); }
.smui-info   { --smui-accent: var(--smui-blue); }

.smui-success .smui-toast__icon{ border-color: rgba(34,197,94,.35); background: rgba(34,197,94,.10); }
.smui-error   .smui-toast__icon{ border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.10); }
.smui-warn    .smui-toast__icon{ border-color: rgba(245,158,11,.35); background: rgba(245,158,11,.10); }
.smui-info    .smui-toast__icon{ border-color: rgba(59,130,246,.35); background: rgba(59,130,246,.10); }

/* ---------- Modal overlay ---------- */
.smui-modal{
  position: fixed;
  inset: 0;
  z-index: calc(var(--smui-z) + 10);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  opacity:0;
  animation: smui_modal_in .16s ease-out forwards;
}
@keyframes smui_modal_in{ to { opacity:1; } }

.smui-modal__card{
  width: min(520px, 100%);
  background: linear-gradient(180deg, var(--smui-bg), var(--smui-bg2));
  border: 1px solid var(--smui-border);
  border-radius: 16px;
  box-shadow: var(--smui-shadow);
  overflow:hidden;
}
.smui-modal__head{
  padding: 14px 14px 0 14px;
}
.smui-modal__title{
  margin:0;
  font-size: 16px;
  font-weight: 800;
  color: var(--smui-txt);
}
.smui-modal__body{
  padding: 10px 14px 14px 14px;
  color: var(--smui-sub);
  font-size: 13px;
  line-height: 1.45;
}
.smui-modal__field{
  margin-top: 12px;
}
.smui-modal__input{
  width:100%;
  padding: 10px 12px;
  border-radius: 12px; 
  outline: none;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: var(--smui-txt);
  font-size: 13px;
}
.smui-modal__hint{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
}
.smui-modal__footer{
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  padding: 12px 14px 14px 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.smui-btn{
  appearance:none;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--smui-txt);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  cursor:pointer;
}
.smui-btn:hover{ background: rgba(255,255,255,.10); }
.smui-btn--primary{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.12);
}
.smui-btn--primary:hover{ background: rgba(34,197,94,.18); }

.smui-shake{
  animation: smui_shake .26s ease-in-out;
}
@keyframes smui_shake{
  0%,100%{ transform: translateX(0); }
  25%{ transform: translateX(-6px); }
  75%{ transform: translateX(6px); }
}

/* =========================
   SMUI — Positions (center + mid edges)
   ========================= */

.smui-pos-top{ top: 10px; left: 50%; transform: translateX(-50%); align-items:center; }
.smui-pos-bottom{ bottom: 10px; left: 50%; transform: translateX(-50%); align-items:center; }
.smui-pos-left{ left: 10px; top: 50%; transform: translateY(-50%); align-items:flex-start; }
.smui-pos-right{ right: 10px; top: 50%; transform: translateY(-50%); align-items:flex-end; }

.smui-pos-center{
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  align-items:center;
}

/* Quando o container usa transform, evita herdar transform duplicado no toast */
.smui-toasts.smui-pos-top,
.smui-toasts.smui-pos-bottom,
.smui-toasts.smui-pos-left,
.smui-toasts.smui-pos-right,
.smui-toasts.smui-pos-center{
  pointer-events:none;
}

/* =========================
   SMUI — Loading Overlay/Card
   ========================= */

.smui-loading{
  position: fixed;
  inset: 0;
  z-index: calc(var(--smui-z) + 20);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  opacity:0;
  animation: smui_modal_in .16s ease-out forwards;
}

.smui-loading__card{
  width: min(520px, 100%);
  background: linear-gradient(180deg, var(--smui-bg), var(--smui-bg2));
  border: 1px solid var(--smui-border);
  border-radius: 16px;
  box-shadow: var(--smui-shadow);
  overflow:hidden;
}

.smui-loading__row{
  display:flex;
  gap: 12px;
  padding: 14px;
  align-items:flex-start;
}

.smui-loading__icon{
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top: 2px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--smui-accent, var(--smui-blue));
}

.smui-loading__body{ flex:1; min-width: 0; }
.smui-loading__title{
  font-weight: 800;
  font-size: 15px;
  line-height: 1.2;
  margin: 0 0 4px 0;
  color: var(--smui-txt);
}
.smui-loading__msg{
  font-size: 13px;
  line-height: 1.35;
  color: var(--smui-sub);
  margin: 0;
}

/* Spinner */
.smui-spinner{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.18);
  border-top-color: var(--smui-accent, var(--smui-blue));
  animation: smui_spin .8s linear infinite;
}
@keyframes smui_spin { to { transform: rotate(360deg); } }

/* Progress bar (opcional, mesmo visual dos toasts) */
.smui-loading__bar{
  height: 3px;
  background: rgba(255,255,255,.10);
}
.smui-loading__bar > i{
  display:block;
  height:100%;
  width:100%;
  transform-origin:left;
  transform: scaleX(1);
  background: var(--smui-accent, var(--smui-blue));
  animation: smui_progress linear forwards;
  animation-duration: var(--smui-duration, 5000ms);
}
