/* ================================
   Variables y base
================================== */
:root{
  --bg:#f9f3f3;
  --card:#ffffff;
  --accent:#e9b3b7;
  --accent-2:#f4dfe2;
  --text:#1f2937;
  --muted:#6b7280;
  --radius:16px;

  /* Clientes (estilo tarjeta compacta) */
  --client-border:#e9edf2;
  --client-muted:#6b7280;
  --client-body:#334155;
  --tool-bg:#f2f4f8;
  --tool-border:#e6eaf0;
  --tool-fg:#6b7280;
  --tool-fg-hover:#111827;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;
}

/* ================================
   Layout
================================== */
.container{
  width:min(1100px,92%);
  margin:0 auto;
}

.topbar{
  background:#fff;
  border-bottom:1px solid #eee;
}

.nav{
  display:flex;
  gap:14px;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
}

.nav a{
  padding:8px 10px;
  border-radius:10px;
  text-decoration:none;
  color:#444;
  background:#f7f7f7;
}

.brand{ font-weight:600; letter-spacing:.8px; }

/* ================================
   Tipografía
================================== */
h1{ font-size:28px; margin:24px 0 18px; }
h2,h3{ margin:0 0 10px; }
.muted{ color:#6b7280; }

/* ================================
   Tarjetas y grid
================================== */
.card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:0 10px 25px rgba(0,0,0,.06);
  padding:22px;
  margin-top:20px;
}

.grid{ display:grid; gap:16px; }
.grid-2{ grid-template-columns:1fr 1fr; margin-bottom: 20px; }

/* ================================
   Formularios y botones
================================== */
.input, select, textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #e5e7eb;
  border-radius:10px;
  background:#fff;
}

textarea{ min-height:100px; resize:vertical; }

.btn{
  border:0;
  border-radius:10px;
  padding:10px 14px;
  background:var(--accent);
  color:#fff;
  font-weight:600;
  cursor:pointer;
}
.btn:disabled{ opacity:.6; cursor:not-allowed; }

.badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:var(--accent-2);
}

/* ================================
   Tabs
================================== */
.tabs{
  display:flex;
  gap:8px;
  margin:10px 0 16px;
  flex-wrap:wrap;
}
.tab{
  padding:7px 11px;
  border-radius:999px;
  background:#f0f0f0;
  color:#444;
  text-decoration:none;
}
.tab.active{ background:var(--accent); color:#fff; }

/* ================================
   Tablas (responsive)
================================== */
.table{
  width:100%;
  min-width: 720px;              /* <- fuerza scroll horizontal en móvil */
  border-collapse:separate;
  border-spacing:0 10px;
}

.table th,
.table td{
  padding:10px 12px;
  background:#fff;
  vertical-align:top;
  white-space:nowrap;            /* por defecto, una línea */
}

/* HEADER 1ª columna: que NO se rompa */
.table th:first-child{
  white-space:nowrap;
  word-break:normal;
}

/* CELDA 1ª columna: puede envolver (nombre + dirección) sin romper letra por letra */
.table td:first-child{
  white-space:normal;
  word-break:normal;             /* nada de “una letra por línea” */
  overflow-wrap:anywhere;        /* romper solo cuando sea necesario */
}

/* Contenedor de scroll recomendado */
.table-scroll{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch; /* scroll suave iOS */
}

/* Fallback: si falta .table-scroll, en móviles la tabla se hace desplazable */
@media (max-width: 600px){
  .table{ display:block; overflow-x:auto; }
}

/* ================================
   Filas & acciones
================================== */
.row{ display:flex; gap:12px; align-items:center; }
.actions{ display:flex; gap:8px; }
.actions .btn{ padding:8px 10px; font-size:14px; }

/* ================================
   Autocomplete
================================== */
.autocomplete{ position:relative; }
.ac-list{
  position:absolute;
  top:100%; left:0; right:0;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:10px;
  max-height:220px;
  overflow:auto;
  z-index:30;
}
.ac-item{ padding:8px 10px; cursor:pointer; }
.ac-item:hover{ background:#f4f4f4; }

.export{ margin-left:auto; }

/* ================================
   Responsive base
================================== */
@media (max-width: 768px){
  .grid-2{ grid-template-columns:1fr; }
}

@media (max-width: 480px){
  .card{ padding:16px; }

  .badge{ font-size:12px; padding:6px 10px; }
  .tab{ padding:6px 10px; }

  .actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    align-items:stretch;
  }
  .actions .btn{ width:100%; }

  .nav a{ padding:6px 6px; }
  h1{ font-size:22px; }
}

@media (max-width: 380px){
  .actions .btn{ font-size:13px; padding:7px 8px; }
}

/* =========================================================
   CLIENTES – estilo compacto (como las capturas)
   * No toca tu HTML/JS, solo apariencia
========================================================= */

/* Tarjeta */
.client-card{
  background:#fff;
  border-radius:12px;                  /* más compacto */
  border:1px solid var(--client-border);
  box-shadow:none;                     /* sin sombra para look “limpio” */
  padding:14px;                        /* compacto */
}

/* Cabecera: nombre + iconos a la derecha */
.client-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:4px;
}
.client-name{
  font-weight:700;
  font-size:16px;                      /* coincide con tu captura */
  color:#0f172a;
  margin:0;
}

/* Botones editar / eliminar (planos y pequeños) */
.client-tools{ display:flex; gap:8px; }
.client-tool{
  width:32px; height:32px;             /* tamaño del screenshot */
  display:flex; align-items:center; justify-content:center;
  border-radius:10px;
  background:var(--tool-bg);
  border:1px solid var(--tool-border);
  color:var(--tool-fg);
  text-decoration:none;
  cursor:pointer;
  transition:background .15s ease, color .15s ease, transform .06s ease, box-shadow .15s;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.7);
}
.client-tool:hover{
  background:#eaeef5;
  color:var(--tool-fg-hover);
}
.client-tool:active{ transform:translateY(1px); }

/* Cuerpo de texto: dirección / tel / mail */
.client-body{
  color:var(--client-body);
  margin-top:2px;
  line-height:1.35;
  font-size:14px;
}
.client-body small{ color:#94a3b8; }

/* Separador fino */
.client-card hr{
  border:0;
  border-top:1px solid var(--client-border);
  margin:10px 0 8px;
}

/* Acciones inferiores: tres botones de color */
.client-actions{
  display:flex;
  gap:10px;
  justify-content:flex-start;          /* los dejas a la izq como en tu captura */
  align-items:center;
  margin-top:6px;
}

/* Botones inferiores (planos) */
.btn-icon{
  width:40px; height:32px;             /* mismo tamaño que screenshot */
  border-radius:10px;
  border:0; color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; font-weight:600;
  box-shadow:none;
}
.btn-icon svg{ width:18px; height:18px; }
.btn-icon.orange{ background:#f97316; }   /* vCard */
.btn-icon.green{  background:#22c55e; }   /* WhatsApp */
.btn-icon.blue{   background:#3b82f6; }   /* Copiar */

.btn-icon:hover{ filter:brightness(1.04); }
.btn-icon:active{ transform:translateY(1px); }

/* Responsive de tarjetas (ajustes suaves) */
.client-list{ display:grid; gap:12px; }

@media (min-width: 700px){
  .client-card{ padding:16px; }
  .client-name{ font-size:16px; }
}

@media (max-width: 640px){
  .client-card{ padding:14px; }
  .client-actions{
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-start;
  }
  .client-tool{ width:30px; height:30px; }
  .btn-icon{ width:38px; height:32px; }
}

/* ====== Apartados: línea de estado y badges ====== */
.apartado-card{
  background:#fff;
  border-radius: var(--radius);
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
  padding: 16px;
  border:1px solid #eef1f4;
  position: relative;
  overflow: hidden;
}

/* Línea a la izquierda (3 estados) */
.apartado-card::before{
  content:"";
  position:absolute; left:10px; top:16px; bottom:16px;
  width:6px; border-radius:6px;
  background:#e5e7eb; /* fallback */
}
.line-green::before{  background:#22c55e; }  /* 0-3 días (vigente)  */
.line-orange::before{ background:#f59e0b; }  /* 4-6 días            */
.line-red::before{    background:#ef4444; }  /* 7+ días (vencido)   */

.apartado-head{ display:flex; justify-content:space-between; align-items:center; gap:12px; }
.apartado-name{ font-weight:700; font-size:18px; margin:0; }
.badge-soft{ padding:6px 12px; border-radius:999px; font-weight:600; }
.badge-yellow{ background:#fef3c7; color:#92400e; }
.badge-green{  background:#dcfce7; color:#065f46; }
.badge-red{    background:#fee2e2; color:#991b1b; }

.apartado-actions{ display:flex; gap:10px; justify-content:flex-end; align-items:center; margin-top:12px; }
.btn-wa{ background:#22c55e; color:#fff; border:0; border-radius:10px; padding:9px 12px; cursor:pointer; text-decoration:none; }

/* ====== Home en móvil: apilar Accesos Rápidos ====== */
@media (max-width: 640px){
  /* Toma el primer .card del home (donde están los accesos) y solo ahí
     fuerza su .grid a una sola columna */
  .container > .card:first-of-type .grid{
    grid-template-columns: 1fr !important;
  }
  .container > .card:first-of-type .grid > *{
    width: 100%;
  }
