
:root{
  --bg1:#060612; --bg2:#070815; --bg3:#05050f;
  --glass: rgba(255,255,255,.06);
  --stroke: rgba(255,255,255,.14);
  --gold: #d9b86c;
  --blue: #7ddcff;
  --text: #fff;
  --muted: rgba(255,255,255,.72);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden;font-family:Arial,system-ui}
body{background:var(--bg2);color:var(--text)}
.bg{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(circle at 20% 10%, rgba(217,184,108,.16), transparent 35%),
    radial-gradient(circle at 80% 20%, rgba(125,220,255,.12), transparent 40%),
    radial-gradient(circle at 50% 90%, rgba(155,120,255,.10), transparent 45%),
    linear-gradient(180deg, var(--bg1), var(--bg2) 55%, var(--bg3));
}
.stars{
  position:fixed;inset:0;z-index:-1;opacity:.35;
  background-image:
    radial-gradient(2px 2px at 20px 30px, #fff, transparent),
    radial-gradient(1px 1px at 120px 80px, #fff, transparent),
    radial-gradient(1px 1px at 220px 160px, #fff, transparent),
    radial-gradient(2px 2px at 340px 60px, #fff, transparent),
    radial-gradient(1px 1px at 420px 220px, #fff, transparent);
  background-size:520px 260px;
  animation: drift 18s linear infinite;
}
@keyframes drift{from{transform:translateY(0)}to{transform:translateY(-260px)}}

.wrap{max-width:1100px;margin:0 auto;padding:16px}
.top{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between;margin-bottom:12px}
h1{margin:0;font-size:22px;letter-spacing:.5px}
.sub{color:var(--muted);font-size:12px;margin-top:6px}
.right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.link{color:var(--blue);text-decoration:none;font-weight:800}

.card{border:1px solid var(--stroke);background:var(--glass);border-radius:18px;padding:12px;max-width:100%;overflow:hidden}
.flash{border-color: rgba(217,184,108,.45);background: rgba(217,184,108,.10)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.badge{display:inline-flex;gap:8px;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid var(--stroke);background:rgba(0,0,0,.18);font-size:12px}
.muted{color:var(--muted);font-size:12px}
.gold{color:var(--gold)}
.big{font-size:18px;font-weight:800}

input,select{
  padding:10px 12px;border-radius:14px;border:1px solid var(--stroke);
  background:rgba(0,0,0,.22);color:#fff;min-width:240px;max-width:100%;
}
button{
  padding:10px 12px;border-radius:14px;border:1px solid rgba(217,184,108,.35);
  background:rgba(217,184,108,.12);color:#fff;cursor:pointer;font-weight:900;
}
button.secondary{border-color:rgba(125,220,255,.35);background:rgba(125,220,255,.10)}
button.danger{border-color:rgba(255,120,120,.35);background:rgba(255,120,120,.10)}
.small{font-size:12px;padding:8px 10px}

.grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:980px){.grid{grid-template-columns:.9fr 1.1fr}}

table{width:100%;border-collapse:collapse;font-size:13px}
th,td{border-bottom:1px solid rgba(255,255,255,.12);padding:10px;vertical-align:top}
th{text-align:left;color:var(--muted);font-weight:900}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(0,0,0,.18);font-size:12px}
.highlight{border:1px solid rgba(217,184,108,.35);background:rgba(217,184,108,.10)}

.footer{margin-top:16px}
.auth-box{max-width:520px;margin:0 auto}
.auth-title{font-size:18px;font-weight:900;margin:0 0 6px}
.auth-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px}
.kpi{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.kpi .card{padding:10px}
@media(max-width:520px){.kpi{grid-template-columns:1fr}}

/* 24h cards mobile */
.hp24-cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
.hp24-card{border-radius:16px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.20);padding:12px;overflow:hidden}
.hp24-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.hp24-num{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-weight:900}
.hp24-time{font-size:12px;color:rgba(255,255,255,.75);margin-top:2px}
.hp24-planet{display:flex;gap:10px;align-items:center;margin-top:10px;min-width:0}
.hp24-icon{width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.20);display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 44px}
.hp24-tags{margin-top:10px;display:grid;gap:8px}
.hp24-box{border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.16);padding:10px}
.hp24-box .t{font-size:12px;font-weight:900;color:rgba(255,255,255,.85);margin-bottom:4px}
.hp24-box .v{font-size:12px;color:rgba(255,255,255,.74);word-break:break-word;overflow-wrap:anywhere}
.hp24-forca{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);font-size:12px;font-weight:900;white-space:nowrap}
.hp24-card.is-now{border-color: rgba(217,184,108,.55);box-shadow:0 0 0 1px rgba(217,184,108,.25) inset}
.hp24-card.is-now .hp24-icon{border-color: rgba(217,184,108,.55);background: rgba(217,184,108,.14)}
.hp24-table-wrap{display:none;overflow:auto}
@media(min-width:980px){.hp24-table-wrap{display:block}.hp24-cards{display:none}}



/* ===== Modal dias no MESMO padrão do card 24h ===== */
.hp-day-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  padding:14px;
  box-shadow: 0 10px 25px rgba(0,0,0,.28);
  overflow:hidden;
}

.hp-day-card.is-today{
  border-color: rgba(217,184,108,.55);
  box-shadow: 0 0 0 1px rgba(217,184,108,.18) inset, 0 10px 28px rgba(0,0,0,.35);
}

.hp-day-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
}

.hp-day-name{
  font-weight:900;
  font-size:16px;
}

.hp-day-badge{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  font-size:12px;
  color: rgba(255,255,255,.86);
  white-space:nowrap;
}

.hp-day-badge.gold{
  border-color: rgba(217,184,108,.55);
  background: rgba(217,184,108,.14);
  color:#f3e3b2;
}

/* bloco planeta igual ao card 24h */
.hp24-planet-like{
  margin-top:12px;
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
}

.hp24-icon-like{
  width:54px;
  height:54px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  font-size:24px;
}

.hp24-icon-like.gold{
  border-color: rgba(217,184,108,.60);
  background: rgba(217,184,108,.14);
  box-shadow: 0 0 18px rgba(217,184,108,.18);
}

.hp24-meta-like{min-width:0; flex:1 1 0;}
.hp24-meta-like b{font-size:18px;}
.hp24-meta-like .muted{font-size:12px;}

/* caixas iguais Favorece/Evitar do card 24h */
.hp24-tags-like{
  margin-top:12px;
  display:grid;
  gap:10px;
}

.hp24-box-like{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding:12px;
}

.hp24-box-like .t{
  font-weight:900;
  font-size:14px;
  margin-bottom:6px;
}

.hp24-box-like .v{
  font-size:12.5px;
  color: rgba(255,255,255,.78);
  line-height:1.35em;
  word-break: break-word;
  overflow-wrap:anywhere;
}

/* Tema do dia também vira uma box igual */
.hp24-box-like.tema .t{
  display:flex;
  align-items:center;
  gap:8px;
}

/* em telas maiores, Favorece/Evitar lado a lado (igual padrão) */
@media (min-width:720px){
  .hp24-tags-like{
    grid-template-columns: 1fr 1fr;
  }
  .hp24-box-like.tema{
    grid-column: 1 / -1;
  }
}





/* =========================
   MODAL (Planeta dos Dias)
   ========================= */
.hp-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;               /* fica acima de tudo */
  display: none;               /* escondido por padrão */
  align-items: center;
  justify-content: center;
  padding: 16px;

  background: rgba(0,0,0,.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.hp-modal.show{
  display: flex;               /* aparece por cima quando abre */
}

.hp-modal__card{
  width: min(980px, 100%);
  max-height: calc(100vh - 32px);
  overflow: auto;

  border: 1px solid var(--stroke);
  background: var(--glass);
  border-radius: 18px;
  padding: 14px;

  box-shadow: 0 18px 50px rgba(0,0,0,.55);
}

/* header do modal */
.hp-modal__header{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.hp-modal__title{
  font-size: 16px;
  font-weight: 900;
}

.hp-modal__subtitle{
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
}

/* chips */
.hp-modal__chips{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
}

.hp-chip{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background:rgba(0,0,0,.18);
  font-size:12px;
}

/* loading */
.hp-loading{
  padding: 10px;
  color: var(--muted);
}

/* tabela dentro do modal */
.hp-days-table-wrap{
  margin-top: 12px;
  overflow: auto;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.12);
}

.hp-days-table th, .hp-days-table td{
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.hp-days-table tr.is-today{
  background: rgba(217,184,108,.10);
}



/* FORÇA MODAL POR CIMA DE TUDO (não deixa ninguém sobrescrever) */
#modalDias{
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;

  z-index: 2147483647 !important; /* máximo prático */
  display: none !important;

  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;

  background: rgba(0,0,0,.62) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
}

#modalDias.show{
  display: flex !important;
}


@media (max-width: 720px){
  #modalDias{ padding-top: max(22px, env(safe-area-inset-top)) !important; }
}

/* Tipografia do modal igual ao card 24h */
#modalDias{
  font-size: 14px;
  line-height: 1.45em;
}

#modalDias b{
  font-weight: 900;
}

#modalDias .muted{
  font-size: 12.5px;
}

/* Caixas do modal com mesmo peso visual do 24h */
#modalDias .hp-day-box{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding:14px;
}

#modalDias .hp-day-box .t{
  font-size:14px;
  font-weight:900;
  margin-bottom:6px;
}

#modalDias .hp-day-box .v{
  font-size:13px;
  line-height:1.45em;
}

/* Planeta do dia com presença igual ao 24h */
#modalDias .hp-planet-icon{
  width:54px;
  height:54px;
  font-size:24px;
}

#modalDias .hp-planet-meta b{
  font-size:18px;
}


/* Modal no mobile: descer um pouco e respeitar barra do navegador/notch */
@media (max-width: 720px){
  #modalDias.show{
    align-items: flex-start !important;
  }

  #modalDias{
    padding-top: calc(16px + env(safe-area-inset-top)) !important;
    padding-bottom: calc(16px + env(safe-area-inset-bottom)) !important;
  }

  /* garante um “respiro” extra no topo do card */
  #modalDias .hp-modal__card{
    margin-top: 14px !important;
  }
}






/* Modal: header sempre visível (mobile e desktop) */
#modalDias .hp-modal__card{
  position: relative;
  padding-top: 70px; /* espaço pro header fixo */
}

#modalDias .hp-modal__header{
  position: sticky;
  top: 0;
  z-index: 5;

  margin: -14px -14px 12px;     /* gruda no topo do card */
  padding: 14px;

  border-bottom: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
}

/* Botão fechar sempre aparecendo e alinhado */
#modalDias .hp-modal__header button{
  position: sticky;
  top: 10px;
}

/* Sempre mostrar CARDS e esconder a tabela, mesmo no desktop */
#modalDias .hp-days-table-wrap{ display:none !important; }
#modalDias #diasCards{ display:grid !important; }

#modalDias{
  padding-top: calc(18px + env(safe-area-inset-top)) !important;
}


/* ===== FIX DEFINITIVO: header não cortar no Chrome mobile desktop-mode ===== */

/* o card vira referência */
#modalDias .hp-modal__card{
  position: relative !important;
  max-height: calc(100vh - 32px) !important;
  overflow: auto !important;
  padding-top: 76px !important; /* espaço reservado pro header fixo */
}

/* header FIXO dentro do card (não depende de sticky) */
#modalDias .hp-modal__header{
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  z-index: 999999 !important;

  padding: 14px !important;
  margin: 0 !important;

  border-bottom: 1px solid rgba(255,255,255,.10) !important;
  background: rgba(0,0,0,.45) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;

  border-top-left-radius: 18px !important;
  border-top-right-radius: 18px !important;
}

/* botão fechar sempre visível e alinhado */
#modalDias .hp-modal__header button{
  margin-top: 2px !important;
}
