/* style.css — PassportMS Design System */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&family=Outfit:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:       #0b0d13;
  --surface:  #111318;
  --surface2: #181b22;
  --surface3: #1e2130;
  --border:   #232733;
  --border2:  #2c3044;

  --text:     #dde1f0;
  --text2:    #8890ab;
  --text3:    #4a5168;

  --blue:     #3d72f5;
  --blue2:    #2d5cd4;
  --blue-g:   rgba(61,114,245,.14);

  --green:    #22c55e;
  --red:      #ef4444;
  --amber:    #f59e0b;
  --violet:   #8b5cf6;
  --cyan:     #06b6d4;

  --sidebar:  200px;
  --radius:   8px;
  --radius-lg:12px;

  --font: 'Outfit', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
}

html{font-size:15px}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
input,select,button,textarea{font-family:var(--font)}

code{font-family:var(--mono);font-size:.8em;background:var(--surface3);
     border:1px solid var(--border2);padding:1px 6px;border-radius:4px;color:var(--cyan)}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.52rem 1.1rem;
     border:1px solid transparent;border-radius:var(--radius);font-size:.875rem;
     font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none!important}

.btn-primary{background:#fff;color:#000000;border-color:#fff;}
.btn-primary:hover{background:#00e0ff;box-shadow:0 0 0 3px var(--blue-g)}

.btn-secondary{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.btn-secondary:hover{background:var(--surface3)}

.btn-ghost{background:transparent;color:var(--text2);border-color:transparent}
.btn-ghost:hover{background:var(--surface2);color:var(--text)}

.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover{opacity:.85}

.btn-edit{background:var(--surface2);color:var(--blue);border-color:var(--border2)}
.btn-edit:hover{background:var(--blue-g);border-color:var(--blue)}

.btn-full{width:100%;justify-content:center}
.btn-sm{padding:.34rem .75rem;font-size:.8rem}
.btn-xs{padding:.24rem .6rem;font-size:.77rem;border-radius:5px}

/* ── ALERTS ─────────────────────────────────────────────────── */
.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.88rem;
       margin-bottom:1rem;border-left:3px solid;transition:opacity .4s,transform .4s}
.alert-error{background:rgba(239,68,68,.1);border-color:var(--red);color:#fca5a5}
.alert-success{background:rgba(34,197,94,.1);border-color:var(--green);color:var(--green)}

/* ── FORM FIELDS ────────────────────────────────────────────── */
.field-group{display:flex;flex-direction:column;gap:.3rem}
.field-group label{font-size:.78rem;font-weight:600;color:var(--text2);
                   text-transform:uppercase;letter-spacing:.05em}
.req{color:var(--red)}

.field-group input,
.field-group select{background:var(--surface2);border:1px solid var(--border2);
  color:var(--text);padding:.58rem .85rem;border-radius:var(--radius);
  font-size:.9rem;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}
.field-group input:focus,
.field-group select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-g)}
.field-group select option{background:var(--surface2)}

/* ── AUTH PAGE ─────────────────────────────────────────────── */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
           background:var(--bg);
           background-image:radial-gradient(ellipse 60% 50% at 50% -5%,rgba(61,114,245,.1),transparent)}

.auth-wrap{width:100%;max-width:400px;padding:1.5rem}
.auth-card{background:var(--surface);border:1px solid var(--border);
           border-radius:var(--radius-lg);padding:2.5rem 2rem;
           box-shadow:0 8px 40px rgba(0,0,0,.5)}
.auth-brand{text-align:center;margin-bottom:2rem}
.brand-logo{font-size:2.5rem;display:block;margin-bottom:.5rem}
.auth-brand h1{font-family:var(--mono);font-size:1.5rem;color:var(--text)}
.auth-brand p{color:var(--text2);font-size:.84rem;margin-top:.2rem}
.auth-form,.auth-card form{display:flex;flex-direction:column;gap:1rem}
.auth-footer{text-align:center;margin-top:1.5rem;font-size:.82rem;color:var(--text3)}

/* ── DASHBOARD LAYOUT ──────────────────────────────────────── */
.dash-body{display:flex;min-height:100vh}

.sidebar{width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);
         display:flex;flex-direction:column;position:fixed;top:0;left:0;
         height:100vh;padding:1.25rem .85rem;z-index:10}

.sidebar-brand{display:flex;align-items:center;gap:.5rem;
               font-family:var(--mono);font-size:1rem;font-weight:600;
               color:var(--text);padding:.25rem .5rem;margin-bottom:1.5rem}

.sidebar-nav{display:flex;flex-direction:column;gap:.15rem;flex:1}

.nav-item{display:flex;align-items:center;gap:.55rem;padding:.5rem .65rem;
          border-radius:var(--radius);color:var(--text2);font-size:.88rem;
          transition:all .15s;text-decoration:none!important}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:var(--blue-g);color:var(--blue);font-weight:500}

.sidebar-footer{border-top:1px solid var(--border);padding-top:.85rem;
                display:flex;flex-direction:column;gap:.5rem}
.admin-name{font-size:.8rem;color:var(--text2);padding:0 .25rem}

.main-content{margin-left:var(--sidebar);flex:1;padding:1.75rem 2rem;
              min-width:0;max-width:calc(100vw - var(--sidebar))}

/* ── PAGE SECTIONS ─────────────────────────────────────────── */
.section-header{display:flex;justify-content:space-between;align-items:flex-start;
                margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}
.section-header h2{font-family:var(--mono);font-size:1.3rem;color:var(--text)}
.page-sub{color:var(--text3);font-size:.82rem;margin-top:.15rem}

/* ── ADD/EDIT FORM CARD ────────────────────────────────────── */
.form-card{background:var(--surface);border:1px solid var(--border);
           border-radius:var(--radius-lg);padding:1.75rem}
.form-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;
                    letter-spacing:.08em;color:var(--blue);margin:1.5rem 0 1rem;
                    padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.form-section-title:first-child{margin-top:0}

.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.form-actions{display:flex;justify-content:flex-end;gap:.75rem;
              margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border)}

/* ── FILTER BAR ────────────────────────────────────────────── */
.filter-bar{display:flex;align-items:center;gap:.65rem;
            margin-bottom:1.25rem;flex-wrap:wrap}

.search-wrap{position:relative;flex:1;min-width:200px}
.search-icon{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);
             font-size:.9rem;pointer-events:none}
.search-wrap input{background:var(--surface);border:1px solid var(--border2);
  color:var(--text);padding:.58rem .85rem .58rem 2.1rem;border-radius:var(--radius);
  font-size:.88rem;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}
.search-wrap input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-g)}

.filter-select{background:var(--surface);border:1px solid var(--border2);
  color:var(--text);padding:.58rem .85rem;border-radius:var(--radius);
  font-size:.875rem;outline:none;cursor:pointer;transition:border-color .15s}
.filter-select:focus{border-color:var(--blue)}
.filter-select option{background:var(--surface)}

/* ── TABLE ─────────────────────────────────────────────────── */
.table-container{background:var(--surface);border:1px solid var(--border);
                 border-radius:var(--radius-lg);overflow:hidden}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

.data-table{width:100%;border-collapse:collapse;font-size:.84rem;min-width:900px}
.data-table thead{background:var(--surface2);border-bottom:1px solid var(--border)}
.data-table th{padding:.5rem;text-align:left;font-size:.72rem;font-weight:600;
               text-transform:uppercase;letter-spacing:.05em;color:#00e0ff;
               white-space:nowrap}
.data-table td{padding:.5rem;border-bottom:1px solid var(--border);
               color:var(--text);vertical-align:middle}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:rgba(255,255,255,.02)}

.muted{color:var(--text3);font-size:.8rem}
.bold{font-weight:500}
.center{text-align:center}
.actions-cell{display:flex;gap:.35rem;flex-wrap:nowrap}

/* ── BADGES ────────────────────────────────────────────────── */
.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;
       font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
       white-space:nowrap}
.badge-approved{background:rgba(34,197,94,.12);color:var(--green)}
.badge-rejected{background:rgba(239,68,68,.12);color:var(--red)}
.badge-processing{background:rgba(6,182,212,.12);color:var(--cyan)}
.badge-pending{background:rgba(245,158,11,.12);color:var(--amber)}
.badge-on-hold{background:rgba(139,92,246,.12);color:var(--violet)}

/* ── EMPTY STATE ───────────────────────────────────────────── */
.empty-state{text-align:center;padding:3.5rem 2rem;color:var(--text3);
             display:flex;flex-direction:column;align-items:center;gap:.5rem}
.empty-icon{font-size:2.5rem;margin-bottom:.25rem}

/* ── PAGINATION ────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:.3rem;
            margin-top:1rem;padding:0 .25rem;flex-wrap:wrap}
.page-btn{background:var(--surface);border:1px solid var(--border2);color:var(--text2);
          padding:.38rem .7rem;border-radius:var(--radius);font-size:.8rem;
          cursor:pointer;transition:all .15s;text-decoration:none!important;display:inline-block}
.page-btn:hover{background:var(--surface2);color:var(--text)}
.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600}
.page-btn.disabled{opacity:.3;pointer-events:none}
.page-ellipsis{color:var(--text3);padding:0 .2rem}

/* ── PUBLIC PAGE ───────────────────────────────────────────── */
.pub-body{display:flex;flex-direction:column;min-height:100vh;
          background:var(--bg);
          background-image:radial-gradient(ellipse 80% 40% at 50% 0%,rgba(61,114,245,.07),transparent)}

.pub-header{display:flex;justify-content:space-between;align-items:center;
            padding:1rem 2rem;border-bottom:1px solid var(--border);
            background:var(--surface)}
.pub-brand{display:flex;align-items:center;gap:.5rem;
           font-family:var(--mono);font-size:1.05rem;font-weight:700;color:var(--text)}

.pub-main{flex:1;max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem;width:100%}

.pub-hero{text-align:center;margin-bottom:2rem}
.pub-hero h1{font-family:var(--mono);font-size:clamp(1.5rem,4vw,2.2rem);
             color:var(--text);margin-bottom:.4rem}
.pub-hero p{color:var(--text2);font-size:.95rem}

.search-card{background:var(--surface);border:1px solid var(--border);
             border-radius:var(--radius-lg);padding:1.5rem 1.75rem}
.search-card-title{font-size:.75rem;font-weight:700;text-transform:uppercase;
                   letter-spacing:.07em;color:var(--blue);margin-bottom:1rem}

.pub-filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}

.pub-search-actions{display:flex;gap:.65rem;margin-top:1.25rem;
                    padding-top:1.25rem;border-top:1px solid var(--border)}

.results-meta{font-size:.83rem;color:var(--text3);margin-bottom:.6rem}

/* Loading */
.loading-state{display:flex;align-items:center;gap:.75rem;
               color:var(--text2);font-size:.88rem;padding:2rem;justify-content:center}
.spinner{width:18px;height:18px;border:2px solid var(--border2);
         border-top-color:var(--blue);border-radius:50%;
         animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.pub-footer{text-align:center;padding:1.25rem;border-top:1px solid var(--border);
            color:var(--text3);font-size:.79rem}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:768px){
  :root{--sidebar:0px}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;
           align-items:center;padding:.65rem 1rem;border-right:none;
           border-bottom:1px solid var(--border)}
  .sidebar-brand{margin-bottom:0;font-size:.9rem}
  .sidebar-nav{flex-direction:row;flex:1;justify-content:center;gap:.25rem}
  .nav-item{font-size:.78rem;padding:.4rem .5rem}
  .sidebar-footer{border-top:none;flex-direction:row;align-items:center;padding-top:0;gap:.35rem}

  .dash-body{flex-direction:column}
  .main-content{margin-left:0;padding:1rem;max-width:100vw}

  .form-grid{grid-template-columns:1fr}
  .section-header{flex-direction:column;gap:.5rem}

  .pub-main{padding:1.5rem 1rem}
  .pub-filter-grid{grid-template-columns:1fr}
  .pub-header{padding:.75rem 1rem}
}
/* ── DATE INPUT CALENDAR ICON FIX ─────────────────────────── */
input[type="date"] {
    color-scheme: dark;
}

input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(2);
    cursor: pointer;
    opacity: 0.8;
    padding: 2px;
    border-radius: 3px;
}

input[type="date"]::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
    background: rgba(255, 255, 255, 0.1);
}
