/* clientes/assets/app.css */
:root{
  --bg:#f4f8f6;
  --card:#ffffff;
  --text:#0e2430;
  --muted:#58707e;

  /* Branding */
  --primary:#2e7d63;      /* principal */
  --primary-2:#174B67;    /* secundario */
  --border:#e3ece8;

  /* Extras para que TODO cambie */
  --bg-grad1:#e8f3ee;
  --bg-grad2:#e8f0f7;
  --primary-grad2:#58b07c;
  --brand-dot2:#7ccf6b;

  --danger:#e11d48;

  --shadow: 0 10px 30px rgba(14,36,48,.08);
  --radius: 16px;
  --radius2: 22px;
  --ring-color: rgba(46,125,99,.18);
}

/* mejoras si el navegador soporta color-mix (para que el “ghost”, hover, ring, etc. sigan el tema) */
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  :root{
    --ring-color: color-mix(in srgb, var(--primary) 18%, transparent);
  }
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 600px at 20% 0%, var(--bg-grad1) 0%, transparent 70%),
              radial-gradient(1200px 600px at 80% 0%, var(--bg-grad2) 0%, transparent 70%),
              var(--bg);
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.app{min-height:100%; display:flex; flex-direction:column}
.main{flex:1; padding:20px 0}
.container{width:min(1100px, 92vw); margin:0 auto}

.topbar{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0;
}
.topbar__left,.topbar__right{display:flex; align-items:center; gap:10px}

.brand{display:flex; align-items:baseline; gap:10px; padding:8px 10px; border-radius:999px}
.brand:hover{background:rgba(23,75,103,.06)}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .brand:hover{ background: color-mix(in srgb, var(--primary-2) 7%, transparent); }
}
.brand__dot{width:10px;height:10px;border-radius:50%; background:linear-gradient(135deg, var(--primary), var(--brand-dot2))}
.brand__name{font-weight:800; letter-spacing:.2px}
.brand__sub{font-size:12px; color:var(--muted)}

.footer{
  border-top:1px solid var(--border);
  padding:16px 0;
  background: rgba(255,255,255,.6);
}
.footer__inner{display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:18px;
  margin:14px 0;
}
.card--auth{width:min(520px, 92vw)}
.grid{display:grid; gap:14px}
.grid--center{place-items:center}
.grid--2{grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px}
@media (max-width: 740px){ .grid--2{grid-template-columns:1fr} }

.page-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:12px; flex-wrap:wrap;
  margin-top:6px;
}
.page-actions{display:flex; gap:10px; flex-wrap:wrap}

.h2{font-size:28px; margin:0}
.h3{font-size:18px; margin:0 0 10px}
.muted{color:var(--muted)}
.small{font-size:12px}
.strong{font-weight:700}
.text-right{text-align:right}
.hide-sm{display:inline}
@media (max-width: 740px){ .hide-sm{display:none} }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  font-weight:650;
  transition:.18s ease;
  user-select:none;
}
.btn--sm{padding:7px 12px; font-size:13px}
.btn--block{width:100%}
.btn--primary{
  background:linear-gradient(135deg, var(--primary), var(--primary-grad2));
  color:#fff;
}
.btn--primary:hover{filter:brightness(.98); transform:translateY(-1px)}
.btn--ghost{
  background:rgba(23,75,103,.06);
  border-color:rgba(23,75,103,.10);
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .btn--ghost{
    background: color-mix(in srgb, var(--primary-2) 7%, transparent);
    border-color: color-mix(in srgb, var(--primary-2) 14%, transparent);
  }
}
.btn--ghost:hover{background:rgba(23,75,103,.10)}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .btn--ghost:hover{ background: color-mix(in srgb, var(--primary-2) 12%, transparent); }
}
.btn:focus{outline:none; box-shadow: 0 0 0 4px var(--ring-color)}

.alert{
  border-radius:14px;
  padding:12px 14px;
  border:1px solid var(--border);
  background:#fff;
  margin:10px 0;
}
.alert--success{border-color:rgba(46,125,99,.25); background:rgba(46,125,99,.07)}
.alert--danger{border-color:rgba(204,61,61,.25); background:rgba(204,61,61,.06)}

.form{display:grid; gap:12px}
.form--two{grid-template-columns:repeat(2,minmax(0,1fr))}
.form--two .field--full{grid-column:1/-1}
@media (max-width: 740px){ .form--two{grid-template-columns:1fr} }

.field label, .field>span{display:block; font-weight:650; margin-bottom:6px}
.field input, .field select, .field textarea, .input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.9);
  font:inherit;
}
.field textarea{resize:vertical}
.field input:focus, .field select:focus, .field textarea:focus, .input:focus{
  outline:none;
  box-shadow: 0 0 0 4px var(--ring-color);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
}
.hint{color:var(--muted); font-size:12px; margin-top:6px}
.note{margin-top:12px; padding:10px 12px; border-radius:14px; background:rgba(23,75,103,.05); border:1px solid rgba(23,75,103,.08); font-size:13px}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .note{
    background: color-mix(in srgb, var(--primary-2) 7%, transparent);
    border-color: color-mix(in srgb, var(--primary-2) 12%, transparent);
  }
}

.table-wrap{overflow:auto; border-radius:16px; border:1px solid var(--border)}
.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:760px;
}
.table th, .table td{
  padding:12px 12px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
.table thead th{
  position:sticky; top:0;
  background:linear-gradient(180deg, rgba(244,248,246,.98), rgba(244,248,246,.85));
  backdrop-filter: blur(6px);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--muted);
}
.table tbody tr:hover{background:rgba(46,125,99,.04)}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .table tbody tr:hover{ background: color-mix(in srgb, var(--primary) 6%, transparent); }
}
.table tbody tr:last-child td{border-bottom:none}

.toolbar{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.toolbar .input{flex:1; min-width:260px}

.subnav{
  display:flex; gap:10px; flex-wrap:wrap;
  margin:10px 0 0;
}
.subnav__link{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(23,75,103,.10);
  background:rgba(23,75,103,.06);
  font-weight:650;
  font-size:13px;
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .subnav__link{
    background: color-mix(in srgb, var(--primary-2) 7%, transparent);
    border-color: color-mix(in srgb, var(--primary-2) 14%, transparent);
  }
}
.subnav__link.is-active{
  background:rgba(46,125,99,.12);
  border-color:rgba(46,125,99,.25);
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .subnav__link.is-active{
    background: color-mix(in srgb, var(--primary) 14%, transparent);
    border-color: color-mix(in srgb, var(--primary) 22%, transparent);
  }
}

.avatar{
  width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(23,75,103,.10);
  background:rgba(23,75,103,.06);
  display:inline-flex; align-items:center; justify-content:center;
  overflow:hidden;
  flex:0 0 auto;
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .avatar{
    border-color: color-mix(in srgb, var(--primary-2) 14%, transparent);
    background: color-mix(in srgb, var(--primary-2) 7%, transparent);
  }
}
.avatar--sm{width:34px;height:34px}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar__fallback{font-weight:800; color:var(--primary-2)}

.row-user{display:flex; gap:10px; align-items:center}

.pill{
  display:inline-flex; align-items:center; justify-content:center;
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(14,36,48,.10);
  background:rgba(14,36,48,.04);
}
.pill--ok{background:rgba(46,125,99,.10); border-color:rgba(46,125,99,.22)}
.pill--warn{background:rgba(218,165,32,.12); border-color:rgba(218,165,32,.22)}
.pill--info{background:rgba(23,75,103,.10); border-color:rgba(23,75,103,.18)}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .pill--ok{background: color-mix(in srgb, var(--primary) 12%, transparent); border-color: color-mix(in srgb, var(--primary) 22%, transparent);}
  .pill--info{background: color-mix(in srgb, var(--primary-2) 12%, transparent); border-color: color-mix(in srgb, var(--primary-2) 20%, transparent);}
}

.switch{display:flex; align-items:center; gap:10px}
.switch input{display:none}
.switch__ui{
  width:46px;height:26px;border-radius:999px;
  background:rgba(14,36,48,.12);
  position:relative;
  border:1px solid rgba(14,36,48,.10);
}
.switch__ui:after{
  content:"";
  position:absolute; top:3px; left:3px;
  width:20px; height:20px; border-radius:50%;
  background:#fff; box-shadow:0 6px 14px rgba(0,0,0,.12);
  transition:.18s ease;
}
.switch input:checked + .switch__ui{
  background:rgba(46,125,99,.28);
  border-color:rgba(46,125,99,.30);
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .switch input:checked + .switch__ui{
    background: color-mix(in srgb, var(--primary) 28%, transparent);
    border-color: color-mix(in srgb, var(--primary) 30%, transparent);
  }
}
.switch input:checked + .switch__ui:after{ transform: translateX(20px); }

.thumb{
  margin-top:10px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border);
  background:rgba(0,0,0,.02);
}
.thumb img{width:100%; height:180px; object-fit:cover}
@media (max-width: 740px){ .thumb img{height:160px} }

.media-card{
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.media-card img{width:100%; height:260px; object-fit:cover}
@media (max-width: 740px){ .media-card img{height:210px} }
.media-card figcaption{padding:10px 12px}

.prose{line-height:1.6}
.comments{display:grid; gap:12px; margin-top:12px}
.comment{
  border:1px solid var(--border);
  border-radius:16px;
  padding:12px;
  background:rgba(255,255,255,.9);
}
.comment__meta{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.comment__body{margin-top:8px; line-height:1.55}

.list{display:grid; gap:12px}
.list-item{
  display:flex; gap:12px; align-items:center; justify-content:space-between;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.9);
  transition:.18s ease;
}
.list-item:hover{transform:translateY(-1px); box-shadow: var(--shadow)}
.list-item__left{display:grid; gap:6px}
.list-item__right{color:var(--muted); font-weight:800}
.chip{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(23,75,103,.06);
  border:1px solid rgba(23,75,103,.10);
  font-size:12px;
  color:var(--muted);
  width:fit-content;
}
@supports (background: color-mix(in srgb, red 10%, transparent)) {
  .chip{
    background: color-mix(in srgb, var(--primary-2) 7%, transparent);
    border-color: color-mix(in srgb, var(--primary-2) 14%, transparent);
  }
}

details.inline-edit summary{list-style:none}
details.inline-edit summary::-webkit-details-marker{display:none}
.inline-edit__panel{
  margin-top:10px;
  border-top:1px dashed var(--border);
  padding-top:10px;
}

/* ======= Galería / miniaturas ======= */
.thumb-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));
  gap:12px;
  margin-top:10px;
}
.thumb-item{display:block}
.thumb-item img{
  width:100%;
  height:120px;
  object-fit:cover;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
}
.thumb-actions{display:flex; align-items:center; gap:8px; margin-top:8px; color:var(--muted); font-size:12px}

.thumb-stack{display:flex; gap:8px; align-items:center; justify-content:flex-end}
.thumb-mini{
  width:46px; height:46px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
  position:relative;
  flex:0 0 auto;
}
.thumb-mini img{width:100%; height:100%; object-fit:cover; display:block}
.thumb-mini.is-more::after{
  content:"";
  position:absolute; inset:0;
  background:rgba(0,0,0,.35);
}
.thumb-more{
  position:absolute; inset:0;
  display:grid; place-items:center;
  color:#fff; font-weight:900;
  font-size:14px;
  z-index:2;
}

.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  gap:12px;
  margin-top:12px;
}
.galimg{
  display:block;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
}
.galimg img{width:100%; height:180px; object-fit:cover; display:block}
/* ===== Theme editor (preview de colores) ===== */
.theme-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}
@media (max-width: 740px){ .theme-grid{ grid-template-columns:1fr; } }

.theme-item{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(255,255,255,.9);
}

.theme-swatch{
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  flex:0 0 auto;
  background:#fff;
}

.theme-fields{ display:grid; gap:8px; flex:1; min-width:0; }

.theme-row{ display:flex; gap:10px; align-items:center; }
.theme-row input[type="color"]{
  width:46px; height:46px;
  padding:0;
  border:none;
  background:transparent;
  cursor:pointer;
}
.theme-row .input{ flex:1; min-width:160px; }
.theme-help{ font-size:12px; color:var(--muted); margin-top:2px; }
