/* Dark clean + pink/purple accents */
:root{
  --bg-0:#0d0d10;
  --bg-1:#12121a;
  --bg-2:#181a25;
  --fg-1:#e7e7ee;
  --fg-2:#b8b9c7;
  --purple:#7a2bf6;
  --pink:#ff4ecd;
  --purple-2:#431a69;
  --border:#2a2d3a;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  background: radial-gradient(1000px 600px at 50% 110%, rgba(255,78,205,.07), transparent 60%) , var(--bg-0);
  color:var(--fg-1);
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Navbar */
.bg-gradient-dark{
  background: linear-gradient(90deg, #111018 0%, #140f20 50%, #0f0e16 100%);
}
.border-purple{ border-color: rgba(122,43,246,.45)!important; }

/* Cards */
.card{
  background:linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  overflow: hidden; /* <-- ADICIONE ESTA LINHA */
}
.card-header{
  background: linear-gradient(90deg, rgba(122,43,246,.25), rgba(255,78,205,.18));
  border-bottom:1px solid var(--border);
  color:#fff;
  font-weight:600;
  transition: border-radius 0.2s ease-in-out, border-color 0.2s ease-in-out;
}

.card-header.collapsible {
    cursor: pointer;
}

/* Summary tiles */
.kpi{
  display:flex; flex-direction:column; align-items:center; gap:.2rem;
  padding:.75rem 0;
}
.kpi .lbl{ color:var(--fg-2); font-size:.85rem; }
.kpi .val{ font-size:1.6rem; font-weight:700; letter-spacing:.3px; }

/* Forms */
.form-control, .form-select{
  background: #0f1320; border:1px solid #3b2a53; color:#fff;
}
.form-control:focus, .form-select:focus{
  border-color: var(--pink); box-shadow:0 0 0 .2rem rgba(255,78,205,.18);
}

/* Buttons */
.btn-primary{
  background: linear-gradient(90deg, var(--purple), var(--pink)); border:0;
}
.btn-primary:hover{ filter:brightness(.95); }
.btn-close-trade{
  background: linear-gradient(90deg, var(--pink), var(--purple));
  border:0;
}

/* Table */
.table{
  --bs-table-bg: transparent;
  color:var(--fg-1);
  border-color:var(--border);
}
.table thead th{
  position:sticky; top:0;
  /* background: #141725; */
  padding-bottom: 1rem;
  border-bottom:1px solid var(--border);
  z-index:1;
}
.table tbody tr:hover { background: rgba(122,43,246,.06); }
.table .status-open{ background:rgba(255,78,205,.18); color:#ffd6f1; }
.table .status-closed{ background:rgba(122,43,246,.25); color:#e9dcff; }

#portfolioTable {
  min-width: 950px;
}

/* --- Estilos para Telas Pequenas (Mobile) --- */
@media (max-width: 950px) {
  body {
    font-size: 0.9rem; /* Adicionado para diminuir a fonte geral */
  }

  .kpi .val {
    font-size: 1.3rem; 
  }

  .table th, .table td {
    font-size: 0.75rem; /* Diminui a fonte */
    padding: 0.2rem 0.2rem; /* Diminui o espaçamento interno */
  }

  .badge {
    font-size: 0.6rem; /* Diminui a fonte do badge */
    padding: .2rem .4rem;
  }
} 

.table thead th{
  position:sticky; top:0;
  padding-bottom: 1rem;
  border-bottom:1px solid var(--border);
  z-index:1;
  /* text-align: center; */
}

/* Badges */
.badge{ border-radius:999px; padding:.4rem .65rem; font-weight:600; }

/* Subtle separators */
.hr-soft{ border-color: var(--border); opacity:.6; }

/* Utility */
.text-muted-2{ color:var(--fg-2)!important; }

/* Botão discreto para editar */
.btn-ghost{
  background: transparent;
  border: 1px solid rgba(255,78,205,.35);
  color: #ffd6f1;
}
.btn-ghost:hover{
  background: rgba(255,78,205,.08);
}

/* Modal escuro */
.modal-dark{
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border:1px solid var(--border);
}
.modal-dark .modal-header{
  border-bottom:1px solid var(--border);
  background: linear-gradient(90deg, rgba(122,43,246,.18), rgba(255,78,205,.12));
}
.modal-dark .modal-footer{
  border-top:1px solid var(--border);
}

/* menor que <small> padrão (0.875em) */
.fs-7 { font-size: .78em; }




/* Exact visual for the 'closed' chip */
.badge.status-closed{
  /* same pill look everywhere */
  border-radius: 999px;
  padding: .4rem .65rem;
  font-weight: 600;

  /* explicit colors so it's deterministic */
  background: rgba(122,43,246,.25);   /* purple glass */
  color: #e9dcff;
  border: 1px solid rgba(122,43,246,.55);
}

.badge.status-open{
  /* same pill look everywhere */
  border-radius: 999px;
  padding: .4rem .65rem;
  font-weight: 600;

  /* explicit colors so it's deterministic */
  background: rgba(255,78,205,.25);   /* purple glass */
  color: #e9dcff;
  border: 1px solid rgba(255,78,205,.55);
}

/* Optional: identical hover for both Closed and Edit */
.badge.status-closed:hover{
  filter: brightness(.96);
}

/* Turn a <button> into a pure badge without changing visuals */
.badge-button{
  -webkit-appearance: none;
  appearance: none;
  border: none;          /* remove native button border */
  margin: 0;             /* reset */
  cursor: pointer;       /* keep pointer */
  background: none;      /* IMPORTANT: if this overrides your bg, delete this line */
  /* DO NOT set padding/background here — .badge/.status-closed control that */
}
.badge-button:focus-visible{
  outline: 2px solid rgba(255,78,205,.6);
  outline-offset: 2px;
}

/* If 'Closed' is a <button disabled>, keep same look */
button.badge.status-closed:disabled{
  opacity: 1;
  cursor: default;
}

/* Destaca Buy Date antiga (>8 dias) */
.cell-stale{
  background: rgba(255,78,205,.14);              /* pink translúcido */
  border: 1px solid rgba(255,78,205,.35);
  color: #ffd6f1;                                 /* texto rosado */
  border-radius: 8px;
  padding: .2rem .4rem;                           /* espaço interno */
}


/* --- ÍCONE DE COLAPSO --- */
.card-header.collapsible::after {
    float: right;
    font-family: 'Arial', sans-serif;
    font-size: 1rem;
    font-weight: bold;
    transition: transform 0.2s ease-in-out;
}

/* Estado quando minimizado: mostra seta para a direita */
.card-header.collapsible[aria-expanded="false"]::after {
  opacity: 0.6;
  content: '▾';
  transform: rotate(-90deg); /* Estado inicial */
}

/* Estado quando expandido: mostra seta para baixo */
.card-header.collapsible[aria-expanded="true"]::after {
  opacity: 0.1;
  content: '▾';
  transform: rotate(0deg); /* Estado inicial */
}

/* Ajusta o card-header quando o card está minimizado */
.card-header.collapsible[aria-expanded="false"] {
    border-bottom-color: transparent;
}

/* --- Animated Gradient Background --- */
.gradient-bg {
  position: fixed; /* Stays in place during scroll */
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden; /* Hides parts of blobs that go off-screen */
  z-index: -1; /* CRITICAL: Puts it behind all other content */
}

.gradient-blob {
  position: absolute;
  width: 50vmax; /* Responsive size based on viewport */
  height: 50vmax;
  border-radius: 9999px; /* Makes it a perfect circle */
  filter: blur(10vmax); /* Creates the soft, blurry edge */
  opacity: 0.1; /* Makes it subtle */
}

/* Define positions and colors for each blob */
.gradient-blob:nth-child(1) {
  top: -20%;
  left: -10%;
  background: var(--purple);
  animation: float 4s infinite alternate;
}

.gradient-blob:nth-child(2) {
  bottom: 5%;
  right: -5%;
  background: var(--pink);
  animation: float 5s infinite alternate;
  animation-delay: -1s; /* Staggers the animation */
}

.gradient-blob:nth-child(3) {
  bottom: 20%;
  left: 10%;
  background: var(--blue); /* A contrasting blue for variety */
  animation: float 10s infinite alternate;
  animation-delay: -8s;
}

/* The animation that moves and transforms the blobs */
@keyframes float {
  0% {
    transform: translateY(0px) rotate(0deg) scale(1);
  }
  100% {
    transform: translateY(-100px) rotate(180deg) scale(1.2);
  }
}

/* --- Currency Toggle Buttons --- */

/* Estilo Base */
.btn-currency {
  color: var(--fg-2);
  background-color: var(--bg-2);
  border: 1px solid var(--border);
  padding: 0.25rem 0.5rem;
  transition: 0.2s ease-in-out;
}

/* Estado Selecionado (Checked) */
.btn-check:checked + .btn-currency {
  color: #fff;
  background: var(--purple);
  border-color: var(--purple);
  box-shadow:  0 0 0.2rem 0.05rem var(--purple);
}