/**
 * THEME: Soft (colores suaves)
 * URL: /assets/themes/soft.css
 */

:root{
  --bg: #fefff0;
  --card: #ffffff;
  --text: #1f2937;
  --muted: #6b7280;

  --border: rgba(17, 24, 39, .10);
  --shadow: 0 10px 30px rgba(17, 24, 39, .06);

  --primary: #4f46e5;     /* indigo suave */
  --primary-2: #6366f1;
  --accent: #10b981;      /* verde suave */
  --danger: #ef4444;

  --radius: 16px;
  --radius-sm: 12px;

  --maxw: 1100px;

  --font: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* ===== base ===== */
html, body{
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  margin: 0;
  padding: 0;
}

main{
  max-width: var(--maxw);
  margin: 28px auto !important;
  padding: 0 16px !important;
}

a{
  color: var(--primary);
  text-decoration: none;
}
a:hover{ text-decoration: underline; }

/* ===== headers ===== */
h1, h2, h3{
  letter-spacing: -.01em;
  margin: 0 0 10px;
}
h1{ font-size: 28px; }
h2{ font-size: 20px; }
p{ color: var(--muted); }

/* ===== cards / panels ===== */
.card, .panel{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.card{
  padding: 14px 16px;
  transition: transform .12s ease, box-shadow .12s ease;
}
.card:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 40px rgba(17,24,39,.08);
}

/* ===== buttons ===== */
.btn,
button{
  background: var(--primary);
  color: #fff;
  border: 1px solid rgba(0,0,0,.05);
  border-radius: 14px;
  padding: 10px 14px;
  font-weight: 600;
  cursor: pointer;
}
.btn:hover,
button:hover{ filter: brightness(1.02); }

.btn--ghost{
  background: transparent;
  color: var(--primary);
  border: 1px solid var(--border);
}

.btn--danger{
  background: var(--danger);
}

h2.ctr
{
	text-align:center;
}

/* ===== forms ===== */
input, select, textarea{
  width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;
  outline: none;
  box-sizing: border-box;
}

input:focus, select:focus, textarea:focus{
  border-color: rgba(79,70,229,.35);
  box-shadow: 0 0 0 4px rgba(79,70,229,.10);
}

label{ font-weight: 600; }
small, .hint{ color: var(--muted); }

p.ctr
{
	text-align:center;
}

/* ===== tables ===== */
table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

thead th{
  background: rgba(79,70,229,.06);
  color: var(--text);
  text-align: left;
  font-size: 13px;
  padding: 12px 10px;
  border-bottom: 1px solid var(--border);
}

tbody td{
  padding: 11px 10px;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}

tbody tr:last-child td{ border-bottom: 0; }
tbody tr:hover td{ background: rgba(17,24,39,.03); }

/* ===== sections on home ===== */
.featured ul{
  list-style: none;
  padding-left: 0;
  margin: 0;
}
.featured li{
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card);
  margin: 10px 0;
  box-shadow: var(--shadow);
}

/* ===== categories grid (home) ===== */
.categories .grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}

.categories .card{
  display: block;
}

/* ===== ticker (news scroll) ===== */
.news-scroll .ticker{
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 0;
  background: var(--card);
  box-shadow: var(--shadow);
}
.news-scroll .ticker__item strong{ color: var(--text); }
.news-scroll .ticker__item em{ color: var(--muted); font-style: normal; }

/* ===== category listing cards (si tu vista usa .company-card) ===== */
.company-card{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 14px;
  padding: 14px;
  margin: 12px 0;
}

.company-thumb{
  width: 150px;
  height: 150px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: rgba(17,24,39,.03);
}
.company-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.company-logo{
  height: 48px;
  display: flex;
  align-items: center;
}
.company-logo img{
  max-height: 48px;
  max-width: 210px;
  object-fit: contain;
}

/* wide logo variant */
.company-logo.is-wide{
  height: 60px;
}
.company-logo.is-wide img{
  max-height: 60px;
  max-width: 320px;
}

/* ===== responsive ===== */
@media (max-width: 820px){
  .company-card{
    grid-template-columns: 1fr;
  }
  .company-thumb{
    width: 100%;
    max-width: 420px;
    height: 200px;
  }
}
