/* ====== Mi Tortuga UI – Form look pro ====== */
:root{
  --primary:#16a34a;        /* verde tortuga */
  --primary-700:#15803d;
  --bg:#f7f8fa;
  --text:#1f2937;
  --muted:#6b7280;
  --border:#e5e7eb;
  --card:#ffffff;
  --danger:#ef4444;
  --warning:#f59e0b;
  --success:#10b981;
}

html,body{background:var(--bg);color:var(--text)}
.container{max-width:1100px;margin:auto;padding:24px}

/* Navbar */
.nav{display:flex;gap:16px;align-items:center;padding:14px 20px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}
.nav .brand{font-weight:700;color:var(--text);text-decoration:none}
.nav .link{color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:10px}
.nav .link:hover{background:#f3f4f6;color:var(--text)}

/* Card */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 6px 14px rgba(0,0,0,.04);padding:20px}
.card-form{max-width:720px;margin:18px auto}

/* Forms */
form label{display:block;font-weight:600;margin:6px 0 4px;color:#374151}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:768px){.form-row{grid-template-columns:1fr}}
.form-control, input[type="text"], input[type="email"], input[type="password"], input[type="tel"], select, textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text);
  transition:.15s border-color,.15s box-shadow;
}
.form-control:focus, input:focus, select:focus, textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(22,163,74,.12);
}
.checkbox{display:flex;align-items:center;gap:8px}
.help{font-size:.875rem;color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;border:1px solid var(--border);
     padding:10px 16px;background:#fff;color:var(--text);cursor:pointer;transition:.15s transform,.15s box-shadow}
.btn:hover{box-shadow:0 4px 12px rgba(0,0,0,.06)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-700);border-color:var(--primary-700)}
.btn-muted{background:#f3f4f6;color:#374151}

/* Alerts */
.alert{padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#fff}
.alert-success{border-color:#a7f3d0;background:#ecfdf5}
.alert-warning{border-color:#fde68a;background:#fffbeb}
.alert-danger{border-color:#fecaca;background:#fef2f2}

/* Tables (para admin) */
.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--border)}
.table thead th{background:#f9fafb;text-align:left;font-weight:700}

/* Small utilities */
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}
.text-center{text-align:center}


/* ====== Catálogo ====== */
.grid-products{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:1100px){.grid-products{grid-template-columns:repeat(3,1fr)}}
@media (max-width:800px){.grid-products{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.grid-products{grid-template-columns:1fr}}

.product-card{display:block;text-decoration:none;color:inherit;padding:10px;border:1px solid var(--border);border-radius:14px}
.product-card:hover{box-shadow:0 6px 14px rgba(0,0,0,.06)}
.product-img{width:100%;height:180px;object-fit:cover;border-radius:12px}
.product-info{margin-top:8px}
.product-name{font-weight:700}
.product-price{margin-top:4px}
.product-meta{color:var(--muted);font-size:.9rem;margin-top:2px}

.product-show{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:900px){.product-show{grid-template-columns:1fr}}
.product-img-lg{width:100%;max-height:460px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}
.product-price-lg{font-size:1.6rem;font-weight:800;margin-top:6px}

/* ====== Listado compacto ====== */
.list-products{display:grid;gap:12px}
.product-row{display:grid;grid-template-columns:96px 1fr auto;gap:14px;align-items:center}
@media (max-width:640px){.product-row{grid-template-columns:72px 1fr}}
.product-thumb{width:96px;height:96px;object-fit:cover;border-radius:10px;border:1px solid var(--border)}
.product-txt .product-name-link{font-weight:700;text-decoration:none;color:inherit}
.product-txt .product-name-link:hover{text-decoration:underline}
.product-cta{text-align:right}
.product-cta .product-price{font-weight:800}


/* Estado activo en el navbar */
.nav .link.active{
  background: var(--primary);
  color: #fff;
  border-radius: 10px;
}
.nav .link.active:hover{
  background: var(--primary-700);
  color:#fff;
}


/* ====== Carrito ====== */
.cart-wrap .cart-table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  border:1px solid var(--border);border-radius:12px;overflow:hidden
}
/*.cart-table th,.cart-table td{padding:12px 14px;border-bottom:1px solid var(--border)}
.cart-table thead th{background:#f9fafb;text-align:left;font-weight:700}
.cart-item{display:flex;align-items:center;gap:12px}*/
.cart-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}
.summary-box{border:1px solid var(--border);border-radius:12px;padding:16px;background:#fff}
.summary-grid{display:grid;grid-template-columns:1fr auto;row-gap:8px}
.summary-grid .label{color:var(--muted)}
.summary-grid .total{font-weight:800;font-size:1.2rem}
.cart-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ====== Layout del Carrito (resumen responsivo) ====== */
.cart-layout{
  display:grid;
  grid-template-columns: minmax(0,1fr) 320px; /* contenido + resumen */
  gap:20px;
  align-items:start;
}
@media (max-width:1240px){
  .cart-layout{ grid-template-columns: minmax(0,1fr) 280px; }
}
@media (max-width:980px){
  .cart-layout{ grid-template-columns: 1fr; }
  .cart-layout .summary-box{ order:-1; } /* el resumen arriba en móviles/tablets */
}

/* Asegurar que NINGUNA imagen de la tabla se haga gigante */
.cart-table .cart-item img,
.cart-table img{
  width:72px !important;
  height:72px !important;
  object-fit:cover;
  border-radius:8px;
  border:1px solid var(--border);
}

/* Mejor alineación */
.cart-table th, .cart-table td{ vertical-align: top; }

/* Seguridad global para imágenes: nunca colapsan ni se salen */
img{max-width:100%;height:auto;display:block}

/* En tarjetas, que no tapen bordes redondeados */
.card img{border-radius:12px}

/* Checkout: form más angosto */
.card form { max-width: 860px; }

/* Badges de estado */
.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:.85rem;border:1px solid var(--border);background:#fff;color:var(--text)}
.badge-success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.badge-primary{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}
.badge-danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.badge-muted{background:#f3f4f6;border-color:#e5e7eb;color:#374151}

/* Filtros catálogo */
.filters{
  display:grid;
  grid-template-columns: 1.2fr 1fr .7fr .7fr 1fr auto auto;
  gap:10px;
  align-items:center;
}
@media (max-width:900px){
  .filters{ grid-template-columns: 1fr 1fr 1fr 1fr; }
  .filters input[type="search"]{ grid-column: 1 / -1; }
}

.card .help code { background:#f3f4f6; padding:2px 6px; border-radius:6px; }

.faq .faq-item { border:1px solid var(--border); border-radius:12px; padding:10px 12px; background:#fff; }
.faq .faq-item + .faq-item { margin-top:10px; }
.faq summary { cursor:pointer; font-weight:700; list-style:none; }
.faq summary::-webkit-details-marker { display:none; }
.faq .faq-a { margin-top:6px; color:var(--text); }


/* ====== Responsive global extra ====== */

/* Que todos los cálculos respeten el ancho disponible */
*,*::before,*::after{ box-sizing: border-box; }

/* Contenedor fluido + padding adaptable */
.container{
  width: min(1100px, 100%);
  padding: clamp(12px, 2.5vw, 24px);
}

/* Navbar: permite salto de línea en móviles */
.nav{ flex-wrap: wrap; justify-content: space-between; }
@media (max-width: 640px){
  .nav{ gap: 10px; padding: 12px 14px; }
  /* Coloca la marca arriba en su propia línea */
  .nav .brand{ flex: 1 1 100%; }
  /* Botones del nav más cómodos en táctil */
  .nav .link{ padding: 8px 12px; }
}

/* Forms: nunca sobresalgan en pantallas pequeñas */
@media (max-width: 600px){
  .card form{ max-width: 100%; }
}

/* Catálogo: afina alturas de imagen en móviles muy pequeños */
@media (max-width: 520px){
  .product-img{ height: 160px; }
}

/* Listado compacto: en móviles muy pequeños deja 2 columnas (thumb + texto) */
@media (max-width: 420px){
  .product-row{ grid-template-columns: 64px 1fr; gap: 10px; }
  .product-thumb{ width: 64px; height: 64px; }
}

/* Filtros: más escalones de quiebre para que respiren bien */
@media (max-width: 720px){
  .filters{ grid-template-columns: 1fr 1fr; }
  .filters input[type="search"]{ grid-column: 1 / -1; }
}
@media (max-width: 480px){
  .filters{ grid-template-columns: 1fr; }
}

/* Tablas genéricas: scroll horizontal sólo en pantallas pequeñas */
@media (max-width: 768px){
  .table{ display: block; width: 100%; overflow-x: auto; }
}

/* Evitar cualquier desplazamiento horizontal accidental */
html, body{ overflow-x: hidden; }

/* Checkout: que nada “empuje” de más */
.card .help, .card p, .card div{ min-width: 0; }
