/* ============================================================
   Mwuïlu Admin — admin.css
   Palette: deep navy bg, champagne gold accents, ivory text
   Font: Cormorant Garamond (headings) + Jost (body/UI)
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  --bg:          #0c0e14;
  --bg-2:        #12151f;
  --bg-3:        #181c2a;
  --border:      rgba(255,255,255,0.07);
  --border-hi:   rgba(255,255,255,0.14);
  --gold:        #c9a96e;
  --gold-dim:    rgba(201,169,110,0.18);
  --gold-hover:  #d9bc8a;
  --text:        rgba(255,255,255,0.88);
  --text-dim:    rgba(255,255,255,0.45);
  --text-faint:  rgba(255,255,255,0.22);
  --red:         #c0605a;
  --red-dim:     rgba(192,96,90,0.18);
  --green:       #6aaa82;
  --green-dim:   rgba(106,170,130,0.18);
  --blue:        #6a9ec0;
  --blue-dim:    rgba(106,158,192,0.18);
  --amber:       #c8a44a;
  --amber-dim:   rgba(200,164,74,0.18);
  --sidebar-w:   240px;
  --topbar-h:    58px;
  --radius:      3px;
  --radius-lg:   6px;
  --shadow:      0 4px 24px rgba(0,0,0,0.45);
  --trans:       all 0.18s ease;
}

html,body{height:100%}
body{font-family:'Jost',sans-serif;font-size:14px;font-weight:400;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold-hover)}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:0.02em;line-height:1.2}
input,select,textarea,button{font-family:'Jost',sans-serif;font-size:13px}

/* ── Layout ── */
.adm-wrap{display:flex;min-height:100vh;width:100%;overflow-x:hidden}

/* ── Sidebar ── */
.adm-sidebar{
  width:var(--sidebar-w);
  background:var(--bg-2);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  position:fixed;
  top:0;left:0;bottom:0;
  z-index:200;
  overflow-y:auto;
  transition:transform 0.25s ease;
}
.adm-sidebar__brand{padding:28px 22px 20px;border-bottom:1px solid var(--border)}
.adm-sidebar__brand img{height:28px;width:auto;opacity:0.9}
.adm-sidebar__sublabel{display:block;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-faint);margin-top:5px}
.adm-nav{flex:1;padding:16px 0}
.adm-nav__section{padding:0 14px;margin-bottom:4px}
.adm-nav__section-label{font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-faint);padding:10px 8px 4px;display:block}
.adm-nav__item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);color:var(--text-dim);font-size:13px;font-weight:400;letter-spacing:0.02em;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:var(--trans);text-decoration:none}
.adm-nav__item:hover{background:rgba(255,255,255,0.04);color:var(--text)}
.adm-nav__item.active{background:var(--gold-dim);color:var(--gold)}
.adm-nav__item svg{flex-shrink:0;opacity:0.7}
.adm-nav__item.active svg{opacity:1}
.adm-nav__badge{margin-left:auto;background:var(--gold);color:var(--bg);font-size:10px;font-weight:500;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.adm-sidebar__foot{padding:16px 14px;border-top:1px solid var(--border)}
.adm-user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius);margin-bottom:8px}
.adm-user-chip__avatar{width:30px;height:30px;border-radius:50%;background:var(--gold-dim);border:1px solid var(--gold);color:var(--gold);font-size:11px;font-weight:500;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.adm-user-chip__name{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-signout{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--radius);border:none;background:none;color:var(--text-faint);font-size:12px;cursor:pointer;transition:var(--trans)}
.adm-signout:hover{color:var(--red);background:var(--red-dim)}

/* ── Main ── */
.adm-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0;overflow-x:hidden}

/* ── Topbar ── */
.adm-topbar{height:var(--topbar-h);background:var(--bg-2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 32px;gap:16px;position:sticky;top:0;z-index:100}
.adm-topbar__title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;letter-spacing:0.04em;color:var(--text);flex:1}
.adm-topbar__subtitle{font-size:12px;color:var(--text-faint);letter-spacing:0.04em}

/* Hamburger button — hidden on desktop */
.adm-hamburger{
  display:none;
  align-items:center;
  justify-content:center;
  width:36px;height:36px;
  border:1px solid var(--border-hi);
  border-radius:var(--radius);
  background:none;
  color:var(--text-dim);
  cursor:pointer;
  flex-shrink:0;
  transition:var(--trans);
}
.adm-hamburger:hover{border-color:var(--gold);color:var(--gold)}

/* ── Body ── */
.adm-body{padding:32px;flex:1;min-width:0}

/* ── Cards ── */
.adm-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 28px;margin-bottom:24px}
.adm-card--flush{padding:0}
.adm-card__title{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:500;margin-bottom:18px;letter-spacing:0.03em;color:var(--text)}

/* ── Stats ── */
.adm-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:28px}
.adm-stat{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}
.adm-stat__label{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px}
.adm-stat__value{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:300;color:var(--gold);line-height:1}
.adm-stat__sub{font-size:11px;color:var(--text-faint);margin-top:4px}

/* ── Tables ── */
.adm-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
.adm-table{width:100%;border-collapse:collapse;font-size:13px;min-width:520px}
.adm-table thead th{text-align:left;padding:10px 14px;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-faint);border-bottom:1px solid var(--border);white-space:nowrap;font-weight:400}
.adm-table tbody tr{border-bottom:1px solid var(--border);transition:background 0.12s}
.adm-table tbody tr:last-child{border-bottom:none}
.adm-table tbody tr:hover{background:rgba(255,255,255,0.025)}
.adm-table td{padding:12px 14px;vertical-align:middle;color:var(--text)}
.adm-table td.dim{color:var(--text-dim)}

/* ── Badges ── */
.adm-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:400;letter-spacing:0.04em;white-space:nowrap}
.adm-badge--received{background:var(--blue-dim);color:var(--blue)}
.adm-badge--in_progress{background:var(--amber-dim);color:var(--amber)}
.adm-badge--confirmed{background:var(--gold-dim);color:var(--gold)}
.adm-badge--paid{background:var(--green-dim);color:var(--green)}
.adm-badge--completed{background:rgba(255,255,255,0.06);color:var(--text-dim)}
.adm-badge--cancelled{background:var(--red-dim);color:var(--red)}

/* ── Forms ── */
.adm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.adm-form-row--3{grid-template-columns:1fr 1fr 1fr}
.adm-form-row--1{grid-template-columns:1fr}
.adm-field{display:flex;flex-direction:column;gap:5px}
.adm-label{font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-faint)}
.adm-input,.adm-select,.adm-textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;color:var(--text);font-size:13px;font-family:'Jost',sans-serif;transition:border-color 0.15s;width:100%}
.adm-input:focus,.adm-select:focus,.adm-textarea:focus{outline:none;border-color:var(--gold)}
.adm-select{appearance:none;cursor:pointer}
.adm-textarea{resize:vertical;min-height:80px}
.adm-input[readonly]{opacity:0.5;cursor:default}

/* ── Buttons ── */
.adm-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:var(--radius);font-size:12px;font-family:'Jost',sans-serif;font-weight:400;letter-spacing:0.06em;cursor:pointer;transition:var(--trans);border:none;white-space:nowrap}
.adm-btn--gold{background:var(--gold);color:var(--bg)}
.adm-btn--gold:hover{background:var(--gold-hover)}
.adm-btn--ghost{background:transparent;border:1px solid var(--border-hi);color:var(--text-dim)}
.adm-btn--ghost:hover{border-color:var(--gold);color:var(--gold)}
.adm-btn--danger{background:var(--red-dim);color:var(--red);border:1px solid transparent}
.adm-btn--danger:hover{background:var(--red);color:#fff}
.adm-btn--sm{padding:6px 13px;font-size:11px}
.adm-btn:disabled{opacity:0.35;cursor:not-allowed;pointer-events:none}

/* ── Misc UI ── */
.adm-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.adm-detail-grid{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}
.adm-detail-row{display:flex;padding:11px 0;border-bottom:1px solid var(--border);gap:16px}
.adm-detail-row:last-child{border-bottom:none}
.adm-detail-row__key{width:160px;flex-shrink:0;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-faint);padding-top:2px}
.adm-detail-row__val{flex:1;color:var(--text);font-size:13px;word-break:break-word}
.adm-passport-file{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:var(--text-dim);text-decoration:none;transition:var(--trans)}
.adm-passport-file:hover{border-color:var(--gold);color:var(--gold)}
.adm-status-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;position:sticky;top:calc(var(--topbar-h) + 20px)}
.adm-status-card__title{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-faint);margin-bottom:14px}
.adm-pdf-locked{padding:18px;background:var(--red-dim);border:1px solid rgba(192,96,90,0.3);border-radius:var(--radius);color:var(--red);font-size:13px;margin-top:16px;text-align:center}
.adm-pdf-section{border-top:1px solid var(--border);padding-top:24px;margin-top:24px}
.adm-pdf-section__title{font-family:'Cormorant Garamond',serif;font-size:16px;margin-bottom:18px;color:var(--text)}
.adm-member-hero{display:flex;align-items:center;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.adm-member-hero__avatar{width:54px;height:54px;border-radius:50%;background:var(--gold-dim);border:1px solid var(--gold);color:var(--gold);font-size:18px;font-family:'Cormorant Garamond',serif;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.adm-member-hero__name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400}
.adm-member-hero__id{font-size:12px;color:var(--text-faint);letter-spacing:0.06em;margin-top:2px}
.adm-filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px}
.adm-filter{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-dim);font-size:12px;font-family:'Jost',sans-serif;cursor:pointer;transition:var(--trans)}
.adm-filter:hover{border-color:var(--border-hi);color:var(--text)}
.adm-filter.active{background:var(--gold-dim);border-color:transparent;color:var(--gold)}
.adm-search-wrap{position:relative;width:100%;max-width:260px}
.adm-search{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:20px;padding:7px 14px 7px 34px;color:var(--text);font-size:12px;font-family:'Jost',sans-serif}
.adm-search:focus{outline:none;border-color:var(--gold)}
.adm-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none}
.adm-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.adm-toolbar form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;flex:1;min-width:0}
.adm-empty{padding:48px;text-align:center;color:var(--text-faint);font-size:13px}
.adm-flash{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:var(--radius);font-size:13px;margin-bottom:20px}
.adm-flash--success{background:var(--green-dim);color:var(--green)}
.adm-flash--error{background:var(--red-dim);color:var(--red)}
.adm-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-faint);margin-bottom:24px;flex-wrap:wrap}
.adm-breadcrumb a{color:var(--text-dim)}
.adm-breadcrumb a:hover{color:var(--gold)}
.adm-breadcrumb__sep{color:var(--text-faint)}
.adm-login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.adm-login-card{width:100%;max-width:380px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px}
.adm-login-logo{height:32px;margin-bottom:28px}
.adm-login-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;margin-bottom:6px;letter-spacing:0.04em}
.adm-login-sub{font-size:12px;color:var(--text-faint);letter-spacing:0.06em;margin-bottom:28px}
.adm-login-field{margin-bottom:16px}
.adm-login-btn{width:100%;padding:11px;background:var(--gold);color:var(--bg);border:none;border-radius:var(--radius);font-size:13px;font-family:'Jost',sans-serif;font-weight:500;letter-spacing:0.08em;cursor:pointer;margin-top:8px;transition:background 0.15s}
.adm-login-btn:hover{background:var(--gold-hover)}
.adm-login-error{padding:10px 14px;background:var(--red-dim);color:var(--red);border-radius:var(--radius);font-size:12px;margin-bottom:16px}
.adm-reminder-flag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--amber-dim);color:var(--amber);border-radius:20px;font-size:11px}

/* ── Backdrop ── */
#adm-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:199}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.18)}

/* ============================================================
   RESPONSIVE — tablet (≤ 1024px)
============================================================ */
@media(max-width:1024px){
  :root{--sidebar-w:220px}
  .adm-body{padding:24px 20px}
  .adm-detail-grid{grid-template-columns:1fr 280px}
}

/* ============================================================
   RESPONSIVE — mobile (≤ 768px)
============================================================ */
@media(max-width:768px){

  /* Sidebar slides off-canvas */
  .adm-sidebar{
    transform:translateX(-100%);
    box-shadow:none;
  }
  .adm-sidebar.open{
    transform:translateX(0);
    box-shadow:8px 0 40px rgba(0,0,0,0.6);
  }

  /* Show backdrop when open */
  .adm-sidebar.open ~ #adm-backdrop,
  body.sidebar-open #adm-backdrop{display:block}

  /* Main takes full width */
  .adm-main{margin-left:0;width:100%}

  /* Show hamburger */
  .adm-hamburger{display:flex}

  /* Topbar adjustments */
  .adm-topbar{padding:0 16px;gap:12px}
  .adm-topbar__subtitle{display:none}

  /* Body padding */
  .adm-body{padding:16px}

  /* Stats: 2 columns on mobile */
  .adm-stats{grid-template-columns:1fr 1fr;gap:12px}
  .adm-stat{padding:16px}
  .adm-stat__value{font-size:28px}

  /* Detail grid stacks */
  .adm-detail-grid{grid-template-columns:1fr}

  /* Status card: no longer sticky on mobile */
  .adm-status-card{position:static}

  /* Form rows collapse */
  .adm-form-row,
  .adm-form-row--3{grid-template-columns:1fr}

  /* Cards */
  .adm-card{padding:16px}

  /* Toolbar stacks */
  .adm-toolbar{flex-direction:column;align-items:stretch}
  .adm-toolbar form{flex-direction:column;align-items:stretch}
  .adm-search-wrap{max-width:100%}

  /* Filters scroll horizontally */
  .adm-filters{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .adm-filters::-webkit-scrollbar{height:0}

  /* Table: allow horizontal scroll within card */
  .adm-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .adm-table{min-width:480px}

  /* Breadcrumb */
  .adm-breadcrumb{margin-bottom:16px}

  /* Detail rows on very small screens */
  .adm-detail-row{flex-direction:column;gap:4px;padding:10px 0}
  .adm-detail-row__key{width:auto}

  /* Actions wrap */
  .adm-actions{flex-direction:column;align-items:stretch}
  .adm-actions .adm-btn{justify-content:center}

  /* PDF section */
  .adm-pdf-section{padding-top:16px}
}

/* ============================================================
   RESPONSIVE — very small (≤ 400px)
============================================================ */
@media(max-width:500px){
  .adm-stats{grid-template-columns:1fr}
  .adm-topbar__title{font-size:10px}
  .adm-login-card{padding:28px 20px}
}