/* =========================================================
   PLATAFORMA — Chats temporales + Herramientas online
   Sistema de diseño compartido (Módulo A + Módulo B)
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600&family=IBM+Plex+Mono:wght@500;600&display=swap');

:root{
  /* ---- Modo claro (por defecto) ---- */
  --bg: #FFFCF7;
  --surface: #FFFFFF;
  --surface-2: #FFF7EC;
  --ink: #17181C;
  --ink-soft: #55575E;
  --border: #EAE6DC;

  --coral: #FF4F64;
  --coral-ink: #7A0F1E;
  --indigo: #4B3AFF;
  --indigo-ink: #1B0F8C;
  --yellow: #FFC93D;
  --yellow-ink: #7A5400;
  --mint: #17C3A2;
  --mint-ink: #0A5C4C;

  --radius: 16px;
  --radius-sm: 10px;
  --shadow-offset: 4px 4px 0px;
  --shadow-offset-sm: 2px 2px 0px;

  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
}

html[data-theme="dark"]{
  --bg: #121017;
  --surface: #1B1926;
  --surface-2: #221F30;
  --ink: #F4F2FF;
  --ink-soft: #B8B4CC;
  --border: #2E2B3D;

  --coral: #FF6B7E;
  --coral-ink: #FFD9DD;
  --indigo: #8C7DFF;
  --indigo-ink: #E4E0FF;
  --yellow: #FFD666;
  --yellow-ink: #4A3900;
  --mint: #33D9B8;
  --mint-ink: #DFFFF7;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  line-height:1.5;
  transition: background .2s ease, color .2s ease;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

h1,h2,h3,.display{
  font-family: var(--font-display);
  font-weight:700;
  letter-spacing:-0.01em;
  margin:0 0 .4em;
}

.container{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:0 20px;
}

/* ---------------- Botones ---------------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family: var(--font-display);
  font-weight:600;
  font-size:.95rem;
  padding:.65em 1.3em;
  border-radius: var(--radius-sm);
  border:2px solid var(--ink);
  background: var(--surface);
  color: var(--ink);
  cursor:pointer;
  box-shadow: var(--shadow-offset) var(--ink);
  transition: transform .12s ease, box-shadow .12s ease;
}
.btn:hover{ transform: translate(-2px,-2px); box-shadow: 6px 6px 0px var(--ink); }
.btn:active{ transform: translate(0,0); box-shadow: 0px 0px 0px var(--ink); }
.btn-primary{ background: var(--coral); color:#fff; border-color: var(--ink); }
.btn-indigo{ background: var(--indigo); color:#fff; }
.btn-ghost{ background:transparent; box-shadow:none; border-color: var(--border); }
.btn-ghost:hover{ box-shadow:none; background: var(--surface-2); }
.btn-sm{ padding:.45em 1em; font-size:.85rem; }

/* ---------------- Header / navegación ---------------- */
.site-header{
  position: sticky; top:0; z-index:60;
  background: var(--bg);
  border-bottom: 2px solid var(--ink);
}
.site-header .bar{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 20px;
}
.logo-wrap{ position:relative; }
.logo-btn{
  display:flex; align-items:center; gap:10px;
  background:none; border:none; cursor:pointer;
  font-family: var(--font-display); font-weight:700; font-size:1.15rem;
  color: var(--ink);
}
.logo-mark{
  width:34px; height:34px; border-radius:9px;
  background: linear-gradient(135deg, var(--coral), var(--indigo));
  border:2px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-family:var(--font-display); font-weight:700;
  box-shadow: var(--shadow-offset-sm) var(--ink);
}
.logo-caret{ transition: transform .15s ease; }
.logo-btn[aria-expanded="true"] .logo-caret{ transform: rotate(180deg); }

.logo-menu{
  position:absolute; top:calc(100% + 10px); left:0;
  min-width:280px;
  background: var(--surface);
  border:2px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: var(--shadow-offset) var(--ink);
  padding:10px;
  display:none;
  z-index:70;
}
.logo-menu.open{ display:block; }
.logo-menu a{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 12px; border-radius: var(--radius-sm);
}
.logo-menu a:hover{ background: var(--surface-2); }
.logo-menu .em{ font-size:1.3rem; line-height:1; }
.logo-menu strong{ display:block; font-family:var(--font-display); font-size:.95rem; }
.logo-menu span{ display:block; font-size:.8rem; color:var(--ink-soft); }
.logo-menu hr{ border:none; border-top:1px solid var(--border); margin:6px 4px; }

.nav-right{ display:flex; align-items:center; gap:10px; }

.theme-toggle{
  width:42px; height:42px; border-radius:50%;
  border:2px solid var(--ink); background: var(--surface);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
  box-shadow: var(--shadow-offset-sm) var(--ink);
}

/* ---------------- Hero (home) ---------------- */
.hero{ padding:64px 0 40px; }
.hero .eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--indigo-ink);
  background: var(--surface-2); border:1px solid var(--border);
  padding:4px 10px; border-radius:999px; margin-bottom:16px;
}
.hero h1{ font-size:clamp(2.1rem, 5vw, 3.6rem); max-width:16ch; }
.hero p.lead{ font-size:1.1rem; color:var(--ink-soft); max-width:46ch; }
.hero-actions{ display:flex; gap:12px; margin-top:26px; flex-wrap:wrap; }

/* Live split-flap clock — elemento firma de la home */
.flapclock{
  display:inline-flex; gap:6px; margin-top:34px; flex-wrap:wrap;
}
.flap{
  font-family:var(--font-mono); font-weight:600; font-size:1.6rem;
  background: var(--ink); color:var(--bg);
  padding:10px 14px; border-radius:10px;
  min-width:1.2em; text-align:center;
  box-shadow: var(--shadow-offset-sm) var(--indigo);
}
.flap.sep{ background:transparent; color:var(--ink-soft); box-shadow:none; padding:10px 2px; }
.flapclock small{ display:block; margin-top:8px; color:var(--ink-soft); font-family:var(--font-mono); font-size:.72rem; letter-spacing:.05em; }

.modules-grid{
  display:grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap:18px; margin:44px 0;
}
.module-card{
  border:2px solid var(--ink); border-radius: var(--radius);
  padding:26px; background:var(--surface);
  box-shadow: var(--shadow-offset) var(--ink);
}
.module-card.coral{ background: color-mix(in srgb, var(--coral) 10%, var(--surface)); }
.module-card.indigo{ background: color-mix(in srgb, var(--indigo) 10%, var(--surface)); }
.module-card h3{ font-size:1.35rem; }
.module-card p{ color:var(--ink-soft); }

/* ---------------- Catálogo de herramientas ---------------- */
.tools-toolbar{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
  margin: 26px 0 20px;
}
.search-input{
  flex:1; min-width:220px;
  padding:.75em 1em; border:2px solid var(--ink); border-radius: var(--radius-sm);
  background: var(--surface); color:var(--ink); font-family:var(--font-body); font-size:.95rem;
}
.chip-row{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }
.chip{
  font-family: var(--font-mono); font-size:.78rem; letter-spacing:.02em;
  padding:6px 14px; border-radius:999px; border:2px solid var(--ink);
  background: var(--surface); cursor:pointer; color:var(--ink);
}
.chip.active{ background: var(--ink); color: var(--bg); }

.tools-grid{
  display:grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr));
  gap:16px; margin-bottom:60px;
}
.tool-card{
  position:relative;
  border:2px solid var(--ink); border-radius: var(--radius);
  background: var(--surface); padding:20px;
  box-shadow: var(--shadow-offset-sm) var(--ink);
  transition: transform .12s ease, box-shadow .12s ease;
}
.tool-card:hover{ transform: rotate(-0.6deg) translateY(-2px); box-shadow: var(--shadow-offset) var(--ink); }
.tool-card .cat-tag{
  display:inline-block; font-family:var(--font-mono); font-size:.68rem;
  text-transform:uppercase; letter-spacing:.05em;
  padding:3px 9px; border-radius:999px; margin-bottom:10px;
  color:#fff;
}
.tool-card .icon{ font-size:1.8rem; margin-bottom:6px; display:block; }
.tool-card h3{ font-size:1.05rem; margin-bottom:4px; }
.tool-card p{ font-size:.85rem; color:var(--ink-soft); margin:0; }
.tool-card.soon{ opacity:.55; }
.tool-card.soon::after{
  content:"Próximamente"; position:absolute; top:14px; right:14px;
  font-family:var(--font-mono); font-size:.65rem; background:var(--yellow); color:var(--yellow-ink);
  padding:2px 8px; border-radius:999px;
}

/* Etiquetas de categoría por color */
.cat-Cálculo{ background: var(--coral); }
.cat-Salud{ background: var(--mint); }
.cat-Fecha-y-tiempo{ background: var(--indigo); }
.cat-Conversores{ background:#0EA5E9; }
.cat-Productividad{ background:#F97316; }
.cat-Utilidades{ background:#A855F7; }
.cat-Texto{ background:#22C55E; }
.cat-Música{ background:#EC4899; }
.cat-Imagen{ background:#64748B; }
.cat-Finanzas{ background:#EAB308; }

.empty-state{
  text-align:center; padding:60px 20px; color:var(--ink-soft);
  border:2px dashed var(--border); border-radius: var(--radius);
}

/* ---------------- Página de herramienta ---------------- */
.tool-header{ padding:36px 0 10px; }
.tool-header .cat-tag{ color:#fff; }
.tool-shell{
  border:2px solid var(--ink); border-radius: var(--radius);
  background: var(--surface); padding:28px;
  box-shadow: var(--shadow-offset) var(--ink);
  margin-bottom:40px;
}
.tool-shell label{ display:block; font-family:var(--font-mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-soft); margin:14px 0 6px; }
.tool-shell input, .tool-shell select, .tool-shell textarea{
  width:100%; padding:.7em .9em; border:2px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg); color: var(--ink); font-family: var(--font-body); font-size:1rem;
}
.tool-shell input:focus, .tool-shell select:focus, .tool-shell textarea:focus{
  outline:none; border-color: var(--indigo);
}
.result-display{
  font-family: var(--font-mono); font-size:2rem; font-weight:600;
  background: var(--ink); color: var(--bg);
  border-radius: var(--radius-sm); padding:18px 22px; margin-top:18px;
  word-break: break-all;
}
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:560px){ .grid-2{ grid-template-columns:1fr; } }

.info-note{
  font-size:.85rem; color: var(--ink-soft); background: var(--surface-2);
  border:1px solid var(--border); border-radius: var(--radius-sm);
  padding:12px 14px; margin-top:16px;
}

/* ---------------- Scroll to top ---------------- */
.scroll-top{
  position:fixed; right:20px; bottom:20px; z-index:80;
  width:48px; height:48px; border-radius:50%;
  background: var(--coral); color:#fff; border:2px solid var(--ink);
  font-size:1.2rem; cursor:pointer;
  box-shadow: var(--shadow-offset) var(--ink);
  display:none; align-items:center; justify-content:center;
}
.scroll-top.show{ display:flex; }

/* ---------------- Footer ---------------- */
.site-footer{
  border-top:2px solid var(--ink); background: var(--surface-2); margin-top:60px;
}
.footer-grid{
  display:grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr));
  gap:24px; padding:44px 0 24px;
}
.footer-grid h4{ font-family:var(--font-display); font-size:.9rem; margin-bottom:10px; }
.footer-grid a{ display:block; font-size:.88rem; color: var(--ink-soft); padding:4px 0; }
.footer-grid a:hover{ color: var(--ink); }
.footer-bottom{
  border-top:1px solid var(--border); padding:16px 0 30px;
  font-size:.8rem; color: var(--ink-soft); display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px;
}

@media (max-width:640px){
  .hero{ padding:40px 0 20px; }
  .flap{ font-size:1.2rem; padding:8px 10px; }
}
