/* ============================================
   B-Events.pro — Admin Panel Styles
   ============================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
[hidden]{display:none !important}

:root{
  --bg:#f0ebe4;
  --bg2:#e8e1d8;
  --white:#fff;
  --card:#fff;
  --brown:#6b4c3b;
  --brown-dark:#4a3228;
  --brown-light:#a0806c;
  --accent:#8b5e3c;
  --accent-warm:#c4956a;
  --taupe:#b8a99a;
  --taupe-light:#d4c8bc;
  --text:#3a2d24;
  --text-muted:#7a6b5e;
  --red:#c0392b;
  --red-light:#f8e6e4;
  --green:#27ae60;
  --green-light:#e6f5ec;
  --radius:16px;
  --radius-lg:24px;
  --sidebar-w:240px;
}

html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
}

/* --- LOGIN SCREEN --- */
.login-screen{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);padding:1.5rem;
}
.login-card{
  background:var(--card);
  border-radius:var(--radius-lg);
  padding:2.5rem;
  width:100%;max-width:380px;
  text-align:center;
  box-shadow:0 8px 40px rgba(107,76,59,.08);
}
.login-logo,.sidebar-logo{
  font-family:'DM Serif Display',serif;
  font-size:1.5rem;color:var(--brown-dark);
  margin-bottom:1.5rem;
}
.login-logo span,.sidebar-logo span{color:var(--accent-warm)}
.login-card h2{
  font-family:'DM Serif Display',serif;
  font-size:1.3rem;margin-bottom:.4rem;
}
.login-card>p{
  color:var(--text-muted);font-size:.85rem;
  margin-bottom:1.5rem;
}
.login-card input{
  width:100%;padding:.75rem 1rem;
  background:var(--bg);border:1px solid var(--taupe-light);
  border-radius:12px;font-family:inherit;font-size:1rem;
  text-align:center;letter-spacing:4px;
  outline:none;transition:border-color .2s;
  margin-bottom:.5rem;
}
.login-card input:focus{border-color:var(--accent-warm)}
.login-error{color:var(--red);font-size:.8rem;margin-bottom:.5rem}
.login-card .btn{width:100%;margin-top:.5rem}

/* --- BUTTONS --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.6rem 1.3rem;border-radius:50px;
  font-family:inherit;font-size:.82rem;font-weight:600;
  border:none;cursor:pointer;transition:all .2s;
  text-decoration:none;white-space:nowrap;
  line-height:1.4;
}
.btn-primary{background:var(--accent-warm);color:var(--brown-dark)}
.btn-primary:hover{
  background:#d4a67a;transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(139,94,60,.2);
}
.btn-ghost{
  background:transparent;color:var(--text-muted);
  border:1px solid var(--taupe-light);
}
.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-danger{background:var(--red-light);color:var(--red)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:.35rem .85rem;font-size:.75rem}

/* --- ADMIN LAYOUT --- */
.admin-panel{display:flex;min-height:100vh}

/* --- SIDEBAR --- */
.sidebar{
  width:var(--sidebar-w);
  background:var(--card);
  border-right:1px solid var(--taupe-light);
  display:flex;flex-direction:column;
  padding:1.2rem;
  position:fixed;top:0;left:0;bottom:0;
  z-index:50;overflow-y:auto;
}
.sidebar-logo{margin-bottom:1.5rem;text-align:center;font-size:1.35rem}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.2rem}
.nav-item{
  display:flex;align-items:center;gap:.6rem;
  padding:.55rem .85rem;border-radius:10px;
  background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:.82rem;font-weight:500;
  color:var(--text-muted);transition:all .2s;
  text-decoration:none;width:100%;text-align:left;
}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item.active{background:var(--brown);color:#fff}
.nav-icon{font-size:1rem;flex-shrink:0}
.badge{
  margin-left:auto;
  background:var(--red);color:#fff;
  font-size:.6rem;font-weight:700;
  padding:.1rem .45rem;border-radius:50px;
}

.sidebar-footer{
  border-top:1px solid var(--taupe-light);
  padding-top:.8rem;margin-top:.8rem;
  display:flex;flex-direction:column;gap:.2rem;
}

/* --- MAIN CONTENT --- */
.main-content{
  flex:1;margin-left:var(--sidebar-w);
  padding:1.8rem 2rem;
  max-width:100%;
  overflow-x:hidden;
}

.tab-content{display:none}
.tab-content.active{display:block}

.tab-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:1.5rem;flex-wrap:wrap;gap:.8rem;
}
.tab-header h1{
  font-family:'DM Serif Display',serif;font-size:1.5rem;
}
.tab-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}

/* --- SORT & REORDER --- */
.sort-group{
  display:flex;gap:.3rem;
  background:var(--bg);border-radius:10px;padding:.25rem;
}
.sort-btn{border-radius:8px !important;padding:.4rem .8rem !important}
.sort-btn.active{background:var(--brown);color:#fff;border-color:var(--brown)}

.move-btns{
  display:flex;flex-direction:column;gap:.2rem;
  flex-shrink:0;
}
.move-btn{
  background:var(--bg);border:none;cursor:pointer;
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all .15s;
  padding:0;
}
.move-btn:hover{background:var(--accent-warm);color:#fff}
.move-btn:disabled{opacity:.25;cursor:default;background:var(--bg);color:var(--text-muted)}

/* --- EVENT CARDS (admin) --- */
.events-list{display:flex;flex-direction:column;gap:.8rem}

.admin-event-card{
  background:var(--card);border-radius:var(--radius);
  padding:1.2rem;display:flex;align-items:center;gap:1rem;
  transition:transform .2s,box-shadow .2s;
}
.admin-event-card:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(107,76,59,.08);
}
.admin-event-date{
  background:linear-gradient(135deg,var(--brown),var(--accent));
  color:#fff;border-radius:10px;
  padding:.8rem .6rem;min-width:70px;text-align:center;
  flex-shrink:0;
}
.admin-event-date .month{
  display:block;font-size:.55rem;text-transform:uppercase;
  letter-spacing:1.5px;opacity:.8;
}
.admin-event-date .day{
  display:block;font-family:'DM Serif Display',serif;
  font-size:1.5rem;line-height:1.1;
}
.admin-event-date .year{display:block;font-size:.6rem;opacity:.7}
.admin-event-thumb{
  width:80px;height:55px;object-fit:cover;
  border-radius:8px;flex-shrink:0;
}
.admin-event-info{flex:1;min-width:0}
.admin-event-info .type{
  font-size:.65rem;text-transform:uppercase;
  letter-spacing:1px;font-weight:600;
  color:var(--accent-warm);
}
.admin-event-info h3{
  font-size:.95rem;font-weight:600;
  color:var(--brown-dark);margin:.15rem 0 .2rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.admin-event-info p{
  color:var(--text-muted);font-size:.78rem;font-weight:300;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.admin-event-badge{
  padding:.3rem .75rem;border-radius:50px;
  font-size:.65rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.5px;
  white-space:nowrap;flex-shrink:0;
}
.badge-open{background:rgba(39,174,96,.12);color:var(--green)}
.badge-soon{background:rgba(196,149,106,.15);color:var(--accent)}
.badge-full{background:rgba(192,57,43,.1);color:var(--red)}
.badge-past{background:var(--bg);color:var(--taupe)}

.admin-event-actions{
  display:flex;gap:.4rem;flex-shrink:0;
}

/* --- REQUEST CARDS --- */
.requests-list{display:flex;flex-direction:column;gap:.6rem}

.request-card{
  background:var(--card);border-radius:var(--radius);
  padding:1rem 1.2rem;display:flex;align-items:center;gap:1rem;
  cursor:pointer;transition:all .2s;
  border-left:4px solid transparent;
}
.request-card:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(107,76,59,.06);
}
.request-card.unread{
  border-left-color:var(--accent-warm);
  background:rgba(196,149,106,.04);
}
.request-card .request-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--brown),var(--accent-warm));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:.72rem;
  flex-shrink:0;
}
.request-card .request-info{flex:1;min-width:0}
.request-card .request-info h4{
  font-size:.85rem;font-weight:600;
  color:var(--brown-dark);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.request-card .request-info .request-meta{
  font-size:.72rem;color:var(--text-muted);
  display:flex;gap:.8rem;
}
.request-card .request-info .request-preview{
  font-size:.75rem;color:var(--text-muted);font-weight:300;
  margin-top:.15rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.request-card .request-time{
  font-size:.68rem;color:var(--taupe);white-space:nowrap;flex-shrink:0;
}

/* --- REQUEST DETAIL --- */
.request-detail{padding:1rem 0}
.request-detail .detail-row{
  display:flex;gap:.8rem;padding:.5rem 0;
  border-bottom:1px solid var(--bg);
  font-size:.85rem;
}
.request-detail .detail-label{
  font-weight:600;color:var(--brown-dark);
  min-width:100px;flex-shrink:0;
}
.request-detail .detail-value{
  color:var(--text-muted);word-break:break-word;
}

/* --- EMPTY STATE --- */
.empty-state{
  text-align:center;padding:3rem 1.5rem;
  color:var(--text-muted);
}
.empty-icon{font-size:2.5rem;display:block;margin-bottom:.8rem}
.empty-state p{font-size:.88rem}

/* --- MODAL --- */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(58,45,36,.5);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
}
.modal{
  background:var(--card);border-radius:var(--radius-lg);
  padding:1.8rem;width:100%;max-width:580px;
  max-height:90vh;overflow-y:auto;
  animation:modalIn .25s ease;
}
.modal-sm{max-width:480px}
@keyframes modalIn{
  from{opacity:0;transform:translateY(16px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.modal-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:1.2rem;
}
.modal-header h2{
  font-family:'DM Serif Display',serif;font-size:1.2rem;
}
.modal-close{
  background:none;border:none;cursor:pointer;
  font-size:1.5rem;color:var(--text-muted);
  padding:0 .2rem;line-height:1;
}
.modal-close:hover{color:var(--text)}

.modal-form{display:flex;flex-direction:column;gap:.85rem}
.form-group{display:flex;flex-direction:column;gap:.25rem}
.form-group label{
  font-size:.72rem;font-weight:600;
  color:var(--brown-dark);text-transform:uppercase;
  letter-spacing:.5px;
}
.modal-form input,
.modal-form textarea,
.modal-form select{
  background:var(--bg);border:1px solid var(--taupe-light);
  border-radius:10px;padding:.6rem .85rem;
  font-family:inherit;font-size:.84rem;color:var(--text);
  outline:none;transition:border-color .2s;
}
.modal-form input:focus,
.modal-form textarea:focus,
.modal-form select:focus{border-color:var(--accent-warm)}
.modal-form textarea{resize:vertical}
.modal-form select{cursor:pointer;appearance:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.form-row.three{grid-template-columns:1fr 1fr 1fr}

.modal-actions{
  display:flex;justify-content:flex-end;gap:.6rem;
  margin-top:.5rem;padding-top:.8rem;
  border-top:1px solid var(--bg);
}

/* --- SETTINGS --- */
.settings-section{display:flex;flex-direction:column;gap:1rem}
.settings-card{
  background:var(--card);border-radius:var(--radius);
  padding:1.3rem 1.5rem;
}
.settings-card h3{
  font-size:.92rem;font-weight:600;color:var(--brown-dark);
  margin-bottom:.25rem;
}
.settings-desc{
  color:var(--text-muted);font-size:.78rem;font-weight:300;
  margin-bottom:.8rem;line-height:1.5;
}
.settings-input-row{
  display:flex;gap:.4rem;align-items:center;flex-wrap:wrap;
}
.settings-input{
  flex:1;min-width:0;
  background:var(--bg);border:1px solid var(--taupe-light);
  border-radius:10px;padding:.55rem .85rem;
  font-family:inherit;font-size:.84rem;color:var(--text);
  outline:none;transition:border-color .2s;
}
.settings-input:focus{border-color:var(--accent-warm)}
textarea.settings-input{resize:vertical;min-height:60px}
.settings-status{
  margin-top:.6rem;padding:.45rem .85rem;
  border-radius:8px;font-size:.78rem;font-weight:500;
}
.settings-status.success{background:var(--green-light);color:var(--green)}
.settings-status.error{background:var(--red-light);color:var(--red)}
.settings-hint{
  margin-top:.4rem;color:var(--text-muted);
  font-size:.72rem;font-style:italic;line-height:1.4;
}
.recipients-list{
  display:flex;flex-direction:column;gap:.35rem;margin-top:.6rem;
}
.recipient-row{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg);border-radius:8px;padding:.4rem .85rem;
}
.recipient-row span{font-size:.82rem;color:var(--text)}
.recipient-row button{
  background:none;border:none;cursor:pointer;
  color:var(--red);font-size:1rem;padding:0 .2rem;
  opacity:.6;transition:opacity .2s;
}
.recipient-row button:hover{opacity:1}

/* --- EMAIL TEMPLATE TAB --- */
.email-tabs{
  display:flex;gap:.25rem;margin-bottom:1.2rem;
  background:var(--card);border-radius:10px;padding:.25rem;
  width:fit-content;
}
.email-tab{
  padding:.45rem 1rem;border-radius:8px;
  background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:.8rem;font-weight:500;
  color:var(--text-muted);transition:all .2s;
}
.email-tab:hover{color:var(--text)}
.email-tab.active{background:var(--brown);color:#fff}
.email-panel{display:none}
.email-panel.active{display:block}

.email-panel .form-group{margin-bottom:.85rem}
.email-panel .form-group label{
  font-size:.72rem;font-weight:600;
  color:var(--brown-dark);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:.25rem;display:block;
}

.toggle-row{
  display:flex;align-items:center;gap:.5rem;
  cursor:pointer;font-size:.84rem;color:var(--text);
  font-weight:400;text-transform:none;letter-spacing:0;
}
.toggle-row input[type="checkbox"]{
  width:16px;height:16px;accent-color:var(--accent-warm);cursor:pointer;
}

.email-btn-row{
  display:flex;gap:.4rem;flex-wrap:wrap;
  margin-top:.5rem;
}

.email-preview-frame{
  background:var(--bg);border-radius:10px;
  overflow:hidden;min-height:200px;
}
.email-preview-frame iframe{
  width:100%;min-height:380px;border:none;border-radius:10px;
}
.email-preview-subject{
  font-size:.78rem;color:var(--text-muted);margin-bottom:.8rem;
}

.modal-email-preview{max-width:620px}

/* --- EVENT IMAGE PREVIEW --- */
.event-image-preview{
  margin-top:.4rem;border-radius:8px;overflow:hidden;
  max-height:100px;background:var(--bg);
}
.event-image-preview img{
  width:100%;height:100px;object-fit:cover;display:block;
}

/* --- MEDIA LIBRARY --- */
.upload-zone{
  border:2px dashed var(--taupe-light);
  border-radius:var(--radius);
  padding:2rem;
  text-align:center;cursor:pointer;
  transition:all .25s;
  margin-bottom:1.2rem;
  background:var(--card);
}
.upload-zone:hover,.upload-zone.dragover{
  border-color:var(--accent-warm);
  background:rgba(196,149,106,.05);
}
.upload-zone.dragover{
  transform:scale(1.005);
  box-shadow:0 0 0 4px rgba(196,149,106,.12);
}
.upload-zone-inner{pointer-events:none}
.upload-zone label{pointer-events:all}
.upload-icon{width:40px;height:40px;color:var(--taupe);margin-bottom:.6rem}
.upload-text{font-size:.88rem;color:var(--text);font-weight:500;margin-bottom:.2rem}
.upload-link{color:var(--accent-warm);font-weight:600;cursor:pointer;text-decoration:underline}
.upload-hint{color:var(--text-muted);font-size:.72rem}

.storage-info{
  font-size:.72rem;color:var(--text-muted);
  background:var(--bg);padding:.3rem .7rem;
  border-radius:8px;
}

.media-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(145px,1fr));
  gap:.8rem;
}
.media-card{
  background:var(--card);border-radius:12px;
  overflow:hidden;cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  position:relative;
}
.media-card:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(107,76,59,.1);
}
.media-card-img{
  width:100%;height:110px;object-fit:cover;
  display:block;background:var(--bg);
}
.media-card-info{padding:.5rem .7rem}
.media-card-name{
  font-size:.72rem;font-weight:600;color:var(--brown-dark);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.media-card-size{font-size:.62rem;color:var(--text-muted)}
.media-card-check{
  position:absolute;top:.4rem;right:.4rem;
  background:var(--accent-warm);color:#fff;
  width:22px;height:22px;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  font-size:.7rem;
}
.media-card:hover .media-card-check{display:flex}

/* Media modal */
.modal-media{max-width:600px}
.media-preview-wrap{
  background:var(--bg);border-radius:10px;
  overflow:hidden;margin-bottom:1rem;
  display:flex;align-items:center;justify-content:center;
  max-height:320px;
}
.media-preview-wrap img{
  max-width:100%;max-height:320px;
  object-fit:contain;display:block;
}
.media-meta{margin-bottom:.5rem}
.media-copy-row{display:flex;gap:.4rem;align-items:center}
.media-code{
  flex:1;background:var(--bg);
  padding:.4rem .7rem;border-radius:8px;
  font-size:.68rem;color:var(--text-muted);
  word-break:break-all;line-height:1.4;
  max-height:50px;overflow-y:auto;
  border:1px solid var(--taupe-light);
}

/* Toast */
.upload-toast{
  position:fixed;bottom:1.5rem;right:1.5rem;
  background:var(--brown-dark);color:#fff;
  padding:.65rem 1.2rem;border-radius:10px;
  font-size:.82rem;font-weight:500;
  box-shadow:0 6px 24px rgba(0,0,0,.2);
  animation:modalIn .3s ease;
  z-index:300;
}
.upload-toast.success{background:var(--green)}
.upload-toast.error{background:var(--red)}

/* --- RESPONSIVE --- */
@media(max-width:900px){
  .sidebar{
    width:100%;height:auto;position:static;
    flex-direction:row;padding:.8rem;
    border-right:none;border-bottom:1px solid var(--taupe-light);
    overflow-x:auto;gap:.3rem;
  }
  .sidebar-logo{display:none}
  .sidebar-nav{flex-direction:row;gap:.2rem;flex-shrink:0}
  .sidebar-footer{
    flex-direction:row;border-top:none;
    padding-top:0;margin-top:0;
    border-left:1px solid var(--taupe-light);
    padding-left:.6rem;margin-left:.6rem;
    gap:.2rem;
  }
  .nav-item{
    padding:.45rem .65rem;font-size:.75rem;
    white-space:nowrap;
  }
  .admin-panel{flex-direction:column}
  .main-content{margin-left:0;padding:1.2rem}
}

@media(max-width:640px){
  .modal{margin:.5rem;padding:1.3rem}
  .form-row,.form-row.three{grid-template-columns:1fr}
  .admin-event-card{
    flex-direction:column;align-items:stretch;
    text-align:center;gap:.8rem;
  }
  .admin-event-actions{justify-content:center}
  .admin-event-info h3{white-space:normal}
  .media-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
  .media-card-img{height:85px}
  .upload-zone{padding:1.2rem}
  .tab-header{flex-direction:column;align-items:flex-start}
  .email-tabs{width:100%}
  .email-tab{flex:1;text-align:center}
  .settings-input-row{flex-direction:column;align-items:stretch}
  .settings-input{min-width:0}
  .email-btn-row{flex-direction:column}
  .email-btn-row .btn{width:100%}
}
