:root {
--bg: #0a0000;                /* Fondo negro profundo */
--sidebar-bg: #1a0a0a;         /* Sidebar negro rojizo */
--accent: #7d1600;             /* Rojo fuego principal */
--accent2: #ff6a00;            /* Naranja intenso */
--highlight: #ffd700;          /* Amarillo infernal */
--text: #f5e6e6;               /* Gris claro casi blanco */
--text-muted: #a85c3a;         /* Marrón rojizo apagado */
--console-bg: #1a0a0a;         /* Consola igual que sidebar */
--radius: 8px;
--transition: 0.3s ease;
--font-ui: 'Poppins', sans-serif;
--font-mono: 'Fira Code', monospace;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
    display: flex;
    font-family: var(--font-ui);
    background: black;
    color: var(--text);
    min-height: 100vh;
    overflow-x: hidden;
    position: relative;
    z-index: 1;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: url('/static/fondo.png') center center / cover no-repeat;
    opacity: 0.10; /* Solo la imagen es transparente */
}

/* Asegura que el contenido esté por encima */
body > * {
    position: relative;
    z-index: 1;
}
/* Scrollbars modernas */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 4px; }
body { scrollbar-width: thin; scrollbar-color: var(--accent) transparent; }

/* Sidebar */
.sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: 255px;
    background: rgba(26, 10, 10, 0.75); /* Fondo traslúcido */
    padding: 1rem;
    overflow-y: auto;
    border-right: 2px solid var(--accent);
    box-shadow: 0 0 20px #7d160055;
    transform: translateX(0);
    transition: transform var(--transition);
    z-index: 1000;
}
.sidebar h3 {
    color: var(--text);
    font-weight: 500;
}
.sidebar.hidden { transform: translateX(-100%); }

.logo {
    font-size: 1.75rem; text-align: center;
    color: #ff2f00; margin-bottom: 1rem;
    text-shadow: 0 0 10px #7d1600, 0 0 20px #ff6a00;
}
.menu-section { margin-bottom: 1rem; }
.menu-section h3 {
    background: #2d0a0a;
    color: var(--highlight);
    padding: 0.6rem; cursor: pointer;
    border-left: 4px solid var(--accent);
    border-radius: var(--radius);
    display: flex; align-items: center; justify-content: space-between;
    transition: background var(--transition);
}
.menu-section h3:hover { background: #272735; }
.gateways {
    display: none; margin-top: 0.5rem;
}
.gateway {
    display: block; width: 100%;
    padding: 0.6rem; margin-bottom: 0.25rem;
    border: none; border-radius: var(--radius);
    background: #1d1d2a; color: var(--text);
    text-align: left; font-size: 0.9rem;
    cursor: pointer; transition: background var(--transition);
}
.gateway.on:hover {
    background: var(--accent2);
    box-shadow: 0 0 10px #ff6a00;
}
.gateway.fix {
    background: #333;
    color: #a85c3a;
}
.gateway.off {
    background: #111;
    color: #a85c3a;
}

.user-info {
    margin-top: 2rem; text-align: center; font-size: 0.9rem;
}
.sidebar button {
    width: 100%; padding: 0.6rem; margin-top: 0.5rem;
    border: none; border-radius: var(--radius);
    background: var(--accent); color: #ffffff;
    cursor: pointer; font-weight: 500;
    transition: background var(--transition);
}
.sidebar button:hover { background: var(--accent2); }

/* Main */
.main {
    margin-left: 240px;
    padding: 1rem;
    display: grid;
    grid-template-columns: 70% 30%; /* ← Cambia aquí */
    gap: 1rem;
    transition: margin-left var(--transition);
    align-items: start;
    width: calc(100% - 240px);
    box-sizing: border-box;
}

.gen-area {
    margin-right: 1rem; /* ← Agrega espacio a la derecha */
}

@media (max-width: 800px) {
    .sidebar { transform: translateX(-100%); }
    .sidebar.open { transform: translateX(0); }
    /* muestra el botón hamburguesa en móvil */
    .setting-btn { display: flex; }
    .main {
        margin-left: 0;
        width: 100%;
        grid-template-columns: 1fr;
        padding: 1rem 0.5rem;
    }
    .gen-area {
        margin-right: 0; /* ← Elimina el margen en móvil */
    }
}

/* Section titles */
.form-area h2,
.gen-area h2 {
    text-align: center;
    color: var(--accent2);
    margin-bottom: 1rem;
    font-size: 1.4rem;
}

/* Cards & forms */
.form-area, .gen-area {
    background: rgba(26, 10, 10, 0.75); /* Fondo traslúcido */
    box-shadow: 0 0 25px #7d160033;
    border: 2px solid #7d1600;
    padding: 1rem;
    border-radius: var(--radius);
    box-shadow: 0 0 15px rgba(0,0,0,0.5);
}
.formulario + .formulario { margin-top: 1rem; }
.formulario input,
.formulario textarea,
.gen-area input {
    width: 100%;
    padding: 0.6rem;
    margin-bottom: 0.5rem;  
    margin-top: 0.5rem;
    border: 1px solid #ff6a00;
    border-radius: var(--radius);
    background: #2d0a0a;
    color: var(--text);
    font-family: var(--font-mono);
    resize: vertical;
}
/* Botones siempre centrados */
.formulario button,
.formulario button:hover,
.gen-area button:hover {
    color: #fff;
}

/* Consolas con borde rainbow animado */
.consola-borde {
    position: relative;
    border-radius: var(--radius);
    padding: 8px; /* Espacio delgado para el borde */
    margin-top: 1rem;
    margin-bottom: 1rem;
    background: #1a0a0a;
    box-shadow: 0 0 25px #7d160033;
    overflow: hidden; /* ← Limita el borde animado */
}

/* Solo el borde rainbow animado en el espacio verde */
.consola-borde::before {
    content: "";
    position: absolute;
    top: 50px;    /* Más delgado arriba */
    bottom: 50px; /* Más delgado abajo */
    left: -100px;  /* Más ancho en los lados */
    right: -100px;
    border-radius: calc(var(--radius) + 12px);
    pointer-events: none;
    z-index: 1;
    background: linear-gradient(90deg, #ff0000, #7d1600, #ff6a00, #ffd700);
    /* Mascara para mostrar solo el borde exterior */
    -webkit-mask-image: 
        linear-gradient(#fff 0 0) content-box, 
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-image: 
        linear-gradient(#fff 0 0) content-box, 
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    box-sizing: border-box;
    animation: rainbow-spin 3.5s linear infinite;
}

@keyframes rainbow-spin {
    to { transform: rotate(360deg); }
}

/* Consola normal, sin borde rainbow */
.consola {
    position: relative;
    background: var(--console-bg);
    color: var(--accent2);
    box-shadow: 0 0 20px #7d160033, 0 0 40px #ff6a0011;
    padding: 1rem;
    min-height: 200px;
    max-height: 300px;
    overflow-y: auto;
    font-family: var(--font-mono);
    border-radius: var(--radius);
    word-break: break-word;
    font-size: 0.8rem;
    margin: 0;
    border: none;
    z-index: 2;
    /* Fondo negro, separado del borde rainbow */
}

.consola > * {
    position: relative;
    z-index: 2; /* El contenido va encima del borde */
}

@media (max-width: 1200px) {
    .consola {
    font-size: 0.8rem;
    }
}
@media (max-width: 800px) {
.consola {
    font-size: 0.7rem; /* más pequeño en móvil */
}
.form-area h2,
.gen-area h2 {
    font-size: 1.1rem;
}
.formulario input,
.formulario textarea,
.gen-area input {
    font-size: 0.9rem;
}
}

.gen-area .button-group {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    }
    .gen-area .button-group button {
    margin: 0; /* anula el margin:auto de botones */
    }

/* Fuente infernal */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@700&display=swap');

.button-inferno {
  font-family: 'Cinzel', Georgia, serif;
  font-size: 0.9rem !important;
  letter-spacing: 1px !important;
  color: #ffffff !important;
  background: linear-gradient(180deg, #2d0a0a 90%, #1a0a0a 100%) !important;
  border: 2px solid var(--accent) !important;
  border-radius: 0.75em !important;
  padding: 0.75em 1.5em !important;
  box-shadow: 0 0 8px #7d160055 !important;
  transition: transform 0.1s, box-shadow 0.2s !important;
  cursor: pointer;
  display: inline-block;
}
.button-inferno:hover {
  transform: translateY(-0.15em);
  box-shadow: 0 0 16px #7d1600cc !important;
  background: linear-gradient(180deg, #3a0a0a 90%, #1a0a0a 100%) !important;
}
.button-inferno:active {
  transform: translateY(0.05em);
  box-shadow: 0 0 4px #7d1600aa !important;
}

/* Inputs estilo Inferno */
.input-inferno {
  width: 100%;
  padding: 0.6rem;
  margin: 0.5rem 0;
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  background: var(--console-bg);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.9rem;
}

/* Mensaje de error bajo el input */
.error-msg {
  margin-bottom: 1rem;
  font-weight: bold;
  text-align: center;
}

/* texto normal de la consola */
.consola .log-entry {
  color: #f03a17;
}

/* cuando el estado sea approved */
.consola .estado-approved {
  color: #16c60c;
  font-weight: bold;
}

/* cuando el estado sea error */
.consola .estado-error {
  color: #fce100;
}

/* cuando el estado sea antispam */
.consola .estado-antispam {
  color: #fce100;
}

/* Agregar al archivo style.css */
.consola .estado-retry {
  color: #ffcc00;
}

html, body {
  height: 100%;
}

/* Flex container que centra vertical y horizontal */
.login-page .main,
.support-page .main {
  margin: 0;               /* quita margin-left del sidebar */
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}

/* Login: caja estándar */
.login-page .form-area {
  max-width: 360px;        /* ancho fijo para login */
  width: 90%;
}

/* Soporte: caja más ancha */
.support-page .form-area {
  max-width: 600px;        /* o 80% si prefieres fluid */
  width: 90%;
  padding: 2rem;           /* más espacio interior */
}

/* Puedes ajustar alturas mínimas si quieres */
.support-page .form-area {
  min-height: 400px;
}

/* badge de notificaciones */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5em;
  height: 1.5em;
  padding: 0 .3em;
  font-size: 0.9em;
  font-weight: bold;
  color: #fff;
  background: var(--accent);
  border-radius: 999px;
  margin-left: .5em;
  animation: pulse 1s ease infinite alternate;
}
@keyframes pulse {
  from { box-shadow: 0 0 0px var(--accent2); }
  to   { box-shadow: 0 0 10px var(--accent2); }
}

/* oculta badge si el contador es 0 */
.badge[data-count="0"] {
  display: none;
}

/* audio invisible */
#audio-notify {
  display: none;
}

/* contenedor de cada mensaje */
.consola .message {
  display: flex;
  margin: 0.5rem 0;
}

/* quién envía (received = otros) */
.consola .message.received {
  justify-content: flex-start;
}

/* tus envíos (sent) */
.consola .message.sent {
  justify-content: flex-end;
}

/* la “burbuja” */
.consola .bubble {
  max-width: 70%;
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius);
  word-break: break-word;
  font-size: 0.9rem;
}

/* estilo para los mensajes entrantes */
.consola .message.received .bubble {
  background: var(--console-bg);
  border: 1px solid var(--accent2);
  color: white;
}

/* estilo para tus mensajes salientes */
.consola .message.sent .bubble {
  background: var(--accent2);
  color: var(--text);
}

.setting-btn {
  width: 45px;
  height: 45px;
  display: none;            /* visible solo en móvil */
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: linear-gradient(180deg, #3a0a0a 90%, #1a0a0a 100%) !important;
  border-radius: 10px;
  cursor: pointer;
  border: none;
  box-shadow: 0px 0px 0px 2px rgb(212, 209, 255);
  position: fixed;
  top: 1rem;
  left: 1rem;
  z-index: 1100;
  transition: background var(--transition);
}
.setting-btn:hover {
  background: linear-gradient(180deg, #3a0a0a 90%, #1a0a0a 100%) !important
}

/* barras */
.bar {
  width: 50%;
  height: 2px;
  background-color: rgb(229, 229, 229);
  position: relative;
  border-radius: 2px;
}

/* centra el círculo verticalmente */
.bar::before {
  content: "";
  position: absolute;
  top: 50%;       /* ↓ nuevo */
  left: 50%;      /* ↓ opcional: centra horizontalmente como punto de partida */
  width: 2px;
  height: 2px;
  border-radius: 50%;
  border: 2px solid white;
  box-shadow: 0 0 5px white;
  transition: all 0.3s;
}

/* desplaza lateralmente desde el centro, y sube 50%*/
.bar1::before {
  transform: translateX(-4px) translateY(-50%);
}
.bar2::before {
  transform: translateX( 4px) translateY(-50%);
}

/* mismo efecto invertido al hacer hover */
.setting-btn:hover .bar1::before {
  transform: translateX( 4px) translateY(-50%);
}
.setting-btn:hover .bar2::before {
  transform: translateX(-4px) translateY(-50%);
}

/* mostrar .setting-btn solo en móvil */
@media (max-width: 800px) {
  .setting-btn {
    display: flex;
  }
}
.setting-btn:active,
.setting-btn:focus {
  background-color: var(--accent2) !important;
  outline: none;
}
.setting-btn { touch-action: manipulation; }

/* ─────────────────────────────────────────────
   Ajustes extra para móviles muy pequeños
   ───────────────────────────────────────────── */
@media (max-width: 800px) {
  /* 1) Que el contenedor .main no empuje nada  
     (ya estás en single-column, así que quita paddings extra) */
  .main {
    padding: 0.5rem;
  }

  /* 2) Login & Soporte: tarjetas full-width */
  .login-page .form-area,
  .support-page .form-area {
    max-width: none;    /* anula el límite fijo */
    width: 100%;        /* ocupa todo el ancho usable */
    margin: 1rem 0;     /* un poco de separación arriba/abajo */
    padding: 1rem;      /* más espacio interno para no pegarlo al borde */
  }

  /* 3) Inputs y botones más grandes para tocar con el pulgar */
  .login-page .input-inferno,
  .support-page .input-inferno,
  .login-page .button-inferno,
  .support-page .button-inferno {
    font-size: 1rem;
    padding: 0.75rem 1rem;
  }

  /* 4) Consola también full-width */
  .support-page .consola {
    width: 100%;
    min-height: 200px;
  }
}

.plans-group,
.dates-group,
.credits-group {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}


.profile-section {
  text-align: center;
  font-size: 0.9rem;
  margin-top: 1rem;
}
.decor-line {
  color: var(--accent2);
}
.profile-title {
  font-family: 'Cinzel', serif;
  font-size: 1.2rem;
  color: var(--highlight);
}
.profile-field {
  margin: 0.3rem 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.edit-icon {
  margin-left: 0.5rem;
  cursor: pointer;
  transition: transform var(--transition);
}
.edit-icon:hover {
  transform: scale(1.2);
}

.credenciales-creadas {
  border: 1px solid var(--text);
  padding: 1rem;
  background: #1c1c1c;
  border-radius: 8px;
  color: var(--text);
}
.credenciales-creadas code {
  color: #faa300;
  font-family: 'Fira Code', monospace;
}

body.login-page .main {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 1rem;
  box-sizing: border-box;
}

/* Contenedor de la info del gateway */
.gw-card {
  background: rgba(26, 10, 10, 0.85);
  border: 1px solid var(--accent2);
  border-radius: var(--radius);
  padding: 0.4rem 0.75rem;
  margin-bottom: 0.75rem;
  box-shadow: 0 0 10px rgba(255, 106, 0, 0.4);
  text-align: center;
}

/* Texto centrado en una sola línea */
.gw-grid {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
}

/* Texto normal, sin fondo tipo botón */
.gw-tag {
  display: inline-block;
  white-space: nowrap;
  padding: 0;
  margin: 0;
  border: none;
  background: none;
  box-shadow: none;
}

/* Ajuste responsive */
@media (max-width: 800px) {
  .gw-grid {
    font-size: 0.8rem;
    gap: 0.25rem;
  }
  .gw-tag {
    padding: 0.25rem 0.5rem;
  }
}

/* ===== Scrapper layout (aislado) ===== */
.scrapper-view{
  --scr-card-min: 300px;    /* ancho mínimo de cada tarjeta */
  --scr-gap: 16px;
  --scr-max-cols: 5;        /* tope de columnas */
  --scr-bg: rgba(20,8,8,.85);
  --scr-bg-chip:#2a0a0a;
  --scr-border: var(--accent2, #ff6a00);
  --scr-border-soft: var(--accent, #ff6a00);
  --scr-text: var(--text, #f5f5f5);
  --scr-text-muted: var(--text-muted, #bbb);
  --scr-highlight: var(--highlight, #ffa14d);
  --scr-shadow: 0 8px 26px rgba(255,102,0,.12), inset 0 0 0 1px rgba(255,102,0,.06);
  --scr-radius: 16px;
}

.scrapper-view.scrapper-container{
  /* ancho máximo = 5 columnas (o lo que pongas en --scr-max-cols) */
  width: min(100%, calc(var(--scr-card-min) * var(--scr-max-cols) + var(--scr-gap) * (var(--scr-max-cols) - 1)));
  margin: 0 auto;
  padding: 1.2rem 1rem;
}

.scrapper-view > h1{ text-align:center; margin:0 0 1rem; color: var(--accent2,#ff6a00); }

/* Grid sin breakpoints, hasta 5 columnas por el max-width del contenedor */
.scrapper-view .scrapper-entries{
  display:grid;
  gap: var(--scr-gap);
  grid-template-columns: repeat(auto-fit, minmax(var(--scr-card-min), 1fr));
  align-items:start;
}

/* Tarjeta */
.scrapper-view .scrapper-entry{
  position:relative;
  display:flex; flex-direction:column; gap:8px;
  padding:12px 14px;
  background: var(--scr-bg);
  border:1px solid var(--scr-border);
  border-radius: var(--scr-radius);
  box-shadow: var(--scr-shadow);
  color: var(--scr-text);
  overflow:hidden;
  min-height: 190px; /* más llenitas */
}

/* “cola” de globo */
.scrapper-view .scrapper-entry::after{
  content:"";
  position:absolute;
  right:18px; bottom:-10px;
  width:16px; height:16px; transform:rotate(45deg);
  background: var(--scr-bg);
  border-right:1px solid var(--scr-border);
  border-bottom:1px solid var(--scr-border);
  box-shadow:6px 6px 14px rgba(255,102,0,.18);
}

/* Hover sutil */
.scrapper-view .scrapper-entry:hover{
  transform: translateY(-2px);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  box-shadow: 0 10px 30px rgba(255,120,30,.18), inset 0 0 0 1px rgba(255,120,30,.08);
  border-color: var(--scr-border-soft);
}
@media (prefers-reduced-motion: reduce){ .scrapper-view .scrapper-entry{ transition:none !important; } }

/* Cabecera en UNA sola línea (con los DOS divisores) */
.scrapper-view .title-line{
  white-space: nowrap;        /* no permitir salto */
  overflow: hidden;
  text-overflow: ellipsis;    /* si no cabe, elipsis */
  line-height: 1.15;
  margin: 2px 0;
  font-size: .95rem;
}

/* Chips copyables */
.scrapper-view .mask-full,
.scrapper-view .mask{
  display:block;
  background: var(--scr-bg-chip);
  border:1px solid var(--scr-border-soft);
  border-radius:10px;
  padding:8px 34px 8px 10px;
  font-family: var(--font-mono, ui-monospace, Menlo, Consolas, monospace);
  letter-spacing:.2px;
  position:relative;
  color: var(--scr-text);
  user-select:none; cursor:pointer;
}
.scrapper-view .mask-full.copyable::after,
.scrapper-view .mask.copyable::after{
  content:"📋";
  position:absolute; right:8px; top:50%;
  transform: translateY(-50%);
  opacity:.65; transition:opacity .15s ease;
}
.scrapper-view .mask-full.copyable:hover::after,
.scrapper-view .mask.copyable:hover::after{ opacity:1; }

/* Info */
.scrapper-view .scrap-line{ line-height:1.25; }

/* Footer */
.scrapper-view .scrapper-meta{
  margin-top:auto;
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; font-size:.82rem; color: var(--scr-text-muted);
  padding-top:6px; border-top:1px dashed rgba(255,255,255,.08);
}
.scrapper-view .scrapper-meta .meta-time{ display:inline-flex; align-items:center; gap:6px; }
.scrapper-view .scrapper-meta .meta-id{
  border:1px solid var(--scr-border-soft);
  padding:2px 8px; border-radius:999px;
  color: var(--scr-highlight); font-weight:600;
}

/* Botón Home */
.scrapper-view .scrapper-home{
  position: sticky;   /* se queda arriba al hacer scroll dentro del container */
  top: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  margin-bottom: 6px;
  border-radius: 10px;
  border: 1px solid var(--accent2, #ff6a00);
  background: rgba(20,8,8,.85);
  color: var(--text, #f5f5f5);
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(255,120,30,.18), inset 0 0 0 1px rgba(255,120,30,.06);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.scrapper-view .scrapper-home:hover{
  transform: translateY(-1px);
  border-color: var(--accent, #ff6a00);
  box-shadow: 0 8px 20px rgba(255,120,30,.24), inset 0 0 0 1px rgba(255,120,30,.08);
}

/* Badge "Copiado!" dentro de la caja */
.scrapper-view .copied-badge{
  margin-left: .5rem;
  font-size: .8rem;
  color: #0f0;
}

body.tools-page .main {
  grid-template-columns: 1fr 1fr !important;
}

#contenedor-formularios.tools-grid{
  display:grid;
  grid-template-columns:1fr 1fr !important;
  gap:20px;
  box-sizing:border-box;
  align-items:start;
}

@media (max-width:800px){
  #contenedor-formularios.tools-grid{
    grid-template-columns:1fr;
  }
}
