/* ░░░ La Reserva de Vendors — Admin panel (reserva design system) ░░░ */

.admin-body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  min-height:100vh;
}

/* topbar */
.adm-top{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem clamp(1rem,4vw,2.5rem);
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.adm-brand{display:flex;align-items:center;gap:.65rem;color:var(--green)}
.adm-brand svg{width:34px;height:34px}
.adm-brand b{font-family:var(--f-display);font-weight:700;font-size:1rem;line-height:1}
.adm-brand span{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-soft);display:block}
.adm-top-right{display:flex;align-items:center;gap:1rem}
.adm-user{font-family:var(--f-mono);font-size:.74rem;color:var(--green-soft)}
.adm-ghost{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--green);border:1px solid var(--green);border-radius:999px;padding:.45em 1em;cursor:pointer;background:none;text-decoration:none}
.adm-ghost:hover{background:var(--green);color:var(--paper-3)}

/* views */
.adm-view{display:none}
.adm-view.is-active{display:block}

/* login / denied */
.adm-center{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:2rem}
.adm-login{
  background:var(--paper-3);border:1.5px solid var(--line-2);border-radius:16px;
  padding:clamp(1.8rem,5vw,3rem);max-width:430px;width:100%;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.adm-login .eyebrow{justify-content:center}
.adm-login h1{font-family:var(--f-display);color:var(--green);font-size:2rem;margin:.2rem 0 .4rem}
.adm-login p.sub{color:var(--green-soft);font-size:.98rem;margin-bottom:1.6rem}
.adm-login input[type=email]{
  width:100%;font-family:var(--f-body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.85em .9em;margin-bottom:.9rem;
}
.adm-login input:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(32,64,46,.12)}
.adm-note{font-family:var(--f-mono);font-size:.8rem;margin-top:1rem;min-height:1.2em;line-height:1.5}
.adm-note.ok{color:var(--green)}.adm-note.err{color:var(--red)}

/* dashboard */
.adm-wrap{max-width:1100px;margin:0 auto;padding:clamp(1.4rem,4vw,2.6rem) clamp(1rem,4vw,2.5rem)}
.adm-tabs{display:flex;gap:.4rem;border-bottom:1px solid var(--line);margin-bottom:1.8rem;flex-wrap:wrap}
.adm-tab{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;background:none;border:0;border-bottom:2px solid transparent;color:var(--green-soft);padding:.7em 1.1em;cursor:pointer;margin-bottom:-1px}
.adm-tab.active{color:var(--green);border-bottom-color:var(--red)}
.adm-panel{display:none}.adm-panel.is-active{display:block;animation:fadeIn .35s ease}

.adm-panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.adm-panel-head h2{font-family:var(--f-display);color:var(--green);font-size:1.7rem}
.adm-count{font-family:var(--f-mono);font-size:.72rem;color:var(--green-soft)}

.adm-btn{font-family:var(--f-mono);font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;padding:.6em 1.2em;cursor:pointer;border:1.5px solid var(--green);background:var(--green);color:var(--paper-3);transition:.2s}
.adm-btn:hover{background:var(--green-2);transform:translateY(-1px)}
.adm-btn.ghost{background:none;color:var(--green)}
.adm-btn.ghost:hover{background:var(--green);color:var(--paper-3)}
.adm-btn.danger{border-color:var(--red);background:none;color:var(--red)}
.adm-btn.danger:hover{background:var(--red);color:var(--paper-3)}
.adm-btn.sm{padding:.4em .8em;font-size:.68rem}

/* cards / list */
.adm-list{display:flex;flex-direction:column;gap:1rem}
.adm-item{background:var(--paper-3);border:1px solid var(--line);border-radius:10px;padding:1.2rem 1.3rem;display:flex;gap:1.2rem;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}
.adm-item-main{flex:1;min-width:240px}
.adm-item h3{font-family:var(--f-display);color:var(--green);font-size:1.25rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.adm-item .meta{font-family:var(--f-mono);font-size:.72rem;color:var(--green-soft);margin:.35rem 0 .5rem;display:flex;gap:1rem;flex-wrap:wrap}
.adm-item p{font-size:.95rem;color:var(--ink);margin:0}
.adm-item-actions{display:flex;flex-direction:column;gap:.5rem;min-width:130px}
.adm-item-actions .row{display:flex;gap:.4rem;flex-wrap:wrap}

.badge{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;padding:.3em .7em;border-radius:999px;font-weight:600}
.badge.published{background:#d9ead9;color:#1f5130}
.badge.draft{background:#efe6cd;color:#7a6a3a}
.badge.review{background:#fde7cf;color:#9a5a17}
.badge.archived{background:#e7e2d6;color:#5b5446}
.badge.new{background:#fde7cf;color:#9a5a17}
.badge.reviewing{background:#e6e0f0;color:#5b4a86}
.badge.approved{background:#d9ead9;color:#1f5130}
.badge.rejected{background:#f7ddd6;color:#a23a26}
.badge.converted{background:#d9ead9;color:#1f5130}
.badge.type{background:var(--green);color:var(--paper-3)}

.adm-empty{text-align:center;color:var(--green-soft);font-family:var(--f-mono);font-size:.85rem;padding:3rem 1rem}

/* modal editor */
.adm-modal{position:fixed;inset:0;z-index:100;background:rgba(21,40,28,.5);display:none;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}
.adm-modal.is-open{display:flex}
.adm-modal-card{background:var(--paper);border-radius:16px;max-width:760px;width:100%;box-shadow:var(--shadow);border:1px solid var(--line-2)}
.adm-modal-head{position:sticky;top:0;background:var(--paper);display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--line);border-radius:16px 16px 0 0;z-index:2}
.adm-modal-head h2{font-family:var(--f-display);color:var(--green);font-size:1.5rem}
.adm-x{background:none;border:0;font-size:1.6rem;line-height:1;color:var(--green-soft);cursor:pointer}
.adm-modal-body{padding:1.5rem}
.adm-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.adm-field{margin-bottom:.2rem;display:flex;flex-direction:column}
.adm-field.full{grid-column:1/-1}
.adm-field label{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--green-soft);margin-bottom:.35rem}
.adm-field input,.adm-field textarea,.adm-field select{
  font-family:var(--f-body);font-size:.96rem;color:var(--ink);background:var(--paper-3);
  border:1px solid var(--line);border-radius:8px;padding:.7em .8em;width:100%;resize:vertical;
}
.adm-field input:focus,.adm-field textarea:focus,.adm-field select:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(32,64,46,.1)}

.adm-sub{margin-top:1.6rem;border-top:1px dashed var(--line-2);padding-top:1.2rem}
.adm-sub h3{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:.8rem}
.adm-rows{display:flex;flex-direction:column;gap:.6rem}
.adm-rowitem{display:grid;grid-template-columns:1fr 1.4fr auto;gap:.5rem;align-items:center}
.adm-rowitem input{font-family:var(--f-body);font-size:.9rem;background:var(--paper-3);border:1px solid var(--line);border-radius:7px;padding:.55em .7em}
.adm-rowdel{background:none;border:1px solid var(--line);border-radius:7px;color:var(--red);cursor:pointer;padding:.45em .7em;font-size:.8rem}
.adm-modal-foot{position:sticky;bottom:0;background:var(--paper);display:flex;justify-content:flex-end;gap:.7rem;padding:1.1rem 1.5rem;border-top:1px solid var(--line);border-radius:0 0 16px 16px}

@media (max-width: 680px) {
  .adm-top {
    flex-direction: column;
    align-items: stretch;
    padding: 1rem;
    gap: 0.8rem;
  }
  .adm-brand {
    justify-content: center;
  }
  .adm-top-right {
    justify-content: center;
    width: 100%;
    flex-wrap: wrap;
    gap: 0.6rem;
  }
  .adm-user {
    width: 100%;
    text-align: center;
    margin-bottom: 0.2rem;
  }
  
  .adm-wrap {
    padding: 1.2rem 0.8rem;
  }
  
  .adm-tabs {
    justify-content: stretch;
  }
  .adm-tab {
    flex: 1;
    text-align: center;
    padding: 0.6rem 0.4rem;
    font-size: 0.72rem;
  }

  .adm-panel-head {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    gap: 0.8rem;
  }
  .adm-panel-head .adm-btn {
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  .adm-item {
    flex-direction: column;
    align-items: stretch;
    padding: 1rem;
    gap: 1rem;
  }
  .adm-item-main {
    min-width: 0;
  }
  .adm-item-actions {
    width: 100%;
    border-top: 1px dashed var(--line);
    padding-top: 0.8rem;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .adm-item-actions button,
  .adm-item-actions .row {
    flex: 1 1 calc(50% - 0.4rem);
    width: 100%;
  }
  .adm-item-actions .row button {
    flex: 1;
  }

  /* Modal responsiveness */
  .adm-modal {
    padding: 0.5rem;
  }
  .adm-modal-card {
    border-radius: 12px;
  }
  .adm-modal-head {
    padding: 1rem;
    border-radius: 12px 12px 0 0;
  }
  .adm-modal-body {
    padding: 1rem 0.8rem;
  }
  .adm-modal-foot {
    padding: 1rem;
    border-radius: 0 0 12px 12px;
  }
  
  .adm-form-grid {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
  
  /* Row items inside modal (Products, Photos, Links) */
  .adm-rowitem {
    flex-direction: column;
    align-items: stretch !important;
    background: color-mix(in srgb, var(--paper-3) 94%, var(--ink));
    padding: 0.8rem;
    border-radius: 8px;
    border: 1px solid var(--line);
    gap: 0.6rem !important;
  }
  .adm-rowitem input {
    width: 100% !important;
    flex: 1 1 100% !important;
  }
  .adm-rowdel {
    width: 100%;
    text-align: center;
    padding: 0.6rem;
    margin-top: 0.2rem;
  }
}

