/* ══════════════════════════════════════════════════
   LA CARRIERS, LLC — Crew Portal Stylesheet
   Theme: Industrial Maritime — dark steel + amber
   Fonts: Bebas Neue (display) + IBM Plex Sans (body)
   ══════════════════════════════════════════════════ */

:root {
  --bg:         #0b1a2e;
  --bg2:        #0f2038;
  --panel:      #132840;
  --panel2:     #1a3456;
  --border:     rgba(255,255,255,0.07);
  --border2:    rgba(255,255,255,0.13);
  --amber:      #e8a020;
  --amber2:     #f4b840;
  --rust:       #c0392b;
  --rust2:      #e74c3c;
  --teal:       #1abc9c;
  --blue:       #2980b9;
  --blue2:      #3b9fd4;
  --white:      #e8edf4;
  --muted:      #6b8099;
  --muted2:     #98afc4;
  --success:    #27ae60;
  --warn:       #e67e22;
  --shadow:     0 8px 32px rgba(0,0,0,0.5);
  --shadow2:    0 2px 12px rgba(0,0,0,0.3);
  --r:          10px;
  --r2:         6px;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;background:var(--bg);color:var(--white);font-family:'IBM Plex Sans',sans-serif;font-size:15px;-webkit-font-smoothing:antialiased;}
#app{height:100%;display:flex;flex-direction:column;}
button{font-family:'IBM Plex Sans',sans-serif;cursor:pointer;}
input,select,textarea{font-family:'IBM Plex Sans',sans-serif;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:2px;}

/* ── Animations ─────────────────────────────────── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes pulse    { 0%,100%{opacity:1} 50%{opacity:0.6} }
@keyframes shimmer  { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes slideIn  { from{transform:translateX(-100%)} to{transform:translateX(0)} }

/* ── LOGIN ─────────────────────────────────────── */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 60% 50% at 15% 50%, rgba(20,50,90,0.8) 0%,transparent 70%),
    radial-gradient(ellipse 40% 40% at 85% 20%, rgba(192,57,43,0.12) 0%,transparent 60%),
    repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,0.015) 60px,rgba(255,255,255,0.015) 61px),
    repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,0.015) 60px,rgba(255,255,255,0.015) 61px);
  padding:20px;
}

.login-card{
  background:var(--panel);
  border:1px solid var(--border2);
  border-radius:16px;
  padding:44px 40px 36px;
  width:100%;max-width:420px;
  box-shadow:var(--shadow),0 0 100px rgba(0,0,0,0.6);
  animation:fadeUp 0.5s ease both;
}

.login-top{text-align:center;margin-bottom:32px;}
.login-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--rust) 0%,var(--amber) 100%);
  font-size:36px;margin-bottom:16px;
  box-shadow:0 0 30px rgba(192,57,43,0.4);
  animation:pulse 4s ease-in-out infinite;
}
.login-co{
  font-family:'Bebas Neue',sans-serif;font-size:34px;letter-spacing:3px;
  line-height:1;color:var(--white);
}
.login-tagline{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--amber);margin-top:6px;}

.login-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border2),transparent);margin:28px 0;}

.fl{margin-bottom:18px;}
.fl label{display:block;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.fi{
  width:100%;background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r2);padding:12px 14px;color:var(--white);font-size:14px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.fi:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(232,160,32,0.15);}
.fi::placeholder{color:var(--muted);}
select.fi{cursor:pointer;}
textarea.fi{resize:vertical;min-height:88px;}

.err-box{background:rgba(192,57,43,0.12);border:1px solid rgba(192,57,43,0.3);border-radius:var(--r2);padding:10px 14px;color:var(--rust2);font-size:13px;margin-bottom:16px;}
.ok-box{background:rgba(39,174,96,0.12);border:1px solid rgba(39,174,96,0.3);border-radius:var(--r2);padding:10px 14px;color:var(--teal);font-size:13px;margin-bottom:16px;animation:fadeIn .3s ease;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:var(--r2);padding:12px 22px;
  font-size:13px;font-weight:600;letter-spacing:.5px;cursor:pointer;
  transition:all .2s;
}
.btn-primary{
  background:linear-gradient(135deg,var(--rust) 0%,var(--amber) 100%);
  color:#fff;box-shadow:0 4px 16px rgba(192,57,43,0.35);width:100%;
  font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:2px;padding:14px;
}
.btn-primary:hover{box-shadow:0 6px 22px rgba(192,57,43,0.5);filter:brightness(1.08);}
.btn-primary:active{transform:scale(0.98);}
.btn-secondary{background:var(--panel2);border:1px solid var(--border2);color:var(--white);}
.btn-secondary:hover{background:var(--bg2);border-color:var(--border2);}
.btn-danger{background:rgba(192,57,43,0.15);border:1px solid rgba(192,57,43,0.3);color:var(--rust2);}
.btn-danger:hover{background:rgba(192,57,43,0.25);}
.btn-success{background:rgba(39,174,96,0.15);border:1px solid rgba(39,174,96,0.3);color:var(--teal);}
.btn-sm{padding:6px 14px;font-size:12px;}
.btn-xs{padding:4px 10px;font-size:11px;}

.login-hint{text-align:center;margin-top:14px;font-size:12px;color:var(--muted);}
.login-hint em{color:var(--amber);font-style:normal;font-weight:600;}

/* ── APP SHELL ────────────────────────────────── */
.app-shell{display:flex;height:100vh;overflow:hidden;}

/* ── SIDEBAR ─────────────────────────────────── */
.sidebar{
  width:250px;min-width:250px;background:var(--panel);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;
  transition:transform .25s ease;
}

.sb-head{
  padding:22px 18px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;
}
.sb-logo{
  width:40px;height:40px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--rust),var(--amber));
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.sb-brand{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:2px;line-height:1;}
.sb-tagline{font-size:10px;color:var(--amber);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;}

.sb-user{
  padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;
}
.sb-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:17px;font-weight:700;
}
.sb-uname{font-size:13px;font-weight:600;line-height:1.2;}
.sb-role{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-top:3px;}

.sb-section{
  padding:8px 0 0;
}
.sb-section-label{
  padding:10px 18px 4px;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);
}
.nav-btn{
  display:flex;align-items:center;gap:11px;
  width:100%;padding:11px 18px;
  background:none;border:none;border-left:3px solid transparent;
  color:var(--muted2);font-size:13px;font-weight:500;text-align:left;
  cursor:pointer;transition:all .15s;
}
.nav-btn:hover{background:rgba(255,255,255,0.04);color:var(--white);}
.nav-btn.active{
  background:rgba(232,160,32,0.08);color:var(--amber2);
  border-left-color:var(--amber);
}
.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;}

.sb-footer{padding:14px 18px;border-top:1px solid var(--border);}
.btn-logout{
  width:100%;background:none;border:1px solid var(--border2);
  border-radius:var(--r2);padding:9px;color:var(--muted);
  font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;
  transition:all .2s;
}
.btn-logout:hover{border-color:var(--rust);color:var(--rust2);}

/* ── MOBILE HEADER ───────────────────────────── */
.mob-head{
  display:none;background:var(--panel);border-bottom:1px solid var(--border);
  padding:13px 16px;align-items:center;justify-content:space-between;flex-shrink:0;
}
.mob-brand{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;}
.mob-ham{
  background:none;border:1px solid var(--border2);border-radius:6px;
  padding:6px 11px;color:var(--white);font-size:17px;cursor:pointer;
}

/* ── BOTTOM NAV ──────────────────────────────── */
.bot-nav{display:none;background:var(--panel);border-top:1px solid var(--border);flex-shrink:0;}
.bot-nav-inner{display:flex;justify-content:space-around;padding:2px 0 env(safe-area-inset-bottom,0);}
.bot-btn{
  background:none;border:none;color:var(--muted);
  padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;
  min-width:52px;cursor:pointer;transition:color .15s;
}
.bot-btn.active{color:var(--amber);}
.bot-btn span:first-child{font-size:19px;}
.bot-btn span:last-child{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;}

/* Sidebar overlay on mobile */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:99;}
.sb-overlay.open{display:block;}
.sidebar.mob-open{display:flex;position:fixed;top:0;left:0;bottom:0;z-index:100;animation:slideIn .25s ease;}

/* ── MAIN CONTENT ─────────────────────────────── */
.main{flex:1;overflow-y:auto;background:var(--bg);position:relative;}
.page{padding:28px 30px;max-width:1100px;animation:fadeUp .35s ease both;}
.ph{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap;}
.pt{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:2px;line-height:1;}
.ps{font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.5px;}
.ph-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ── CARDS ────────────────────────────────────── */
.card{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r);padding:22px;margin-bottom:18px;
  box-shadow:var(--shadow2);
}
.card-title{
  font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:1.5px;
  color:var(--muted2);margin-bottom:16px;
  display:flex;align-items:center;gap:8px;
}
.card-title span{font-size:18px;}

/* ── STATS GRID ───────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;}
.stat{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r);padding:18px;text-align:center;
  box-shadow:var(--shadow2);transition:transform .2s;
}
.stat:hover{transform:translateY(-2px);}
.stat-ico{font-size:26px;margin-bottom:6px;}
.stat-val{font-family:'Bebas Neue',sans-serif;font-size:34px;line-height:1;margin-bottom:4px;}
.stat-lbl{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}

/* ── GRID LAYOUTS ─────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.span2{grid-column:span 2;}

/* ── TABLE ────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;}
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl th{
  padding:10px 14px;text-align:left;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);background:rgba(0,0,0,0.25);white-space:nowrap;
}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl tbody tr:hover{background:rgba(255,255,255,0.02);}

/* ── FORM GRID ────────────────────────────────── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:15px;}
.fg .span2{grid-column:1/-1;}

/* ── BADGES ───────────────────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px;}
.b-red   {background:rgba(192,57,43,.18);color:var(--rust2);border:1px solid rgba(192,57,43,.3);}
.b-green {background:rgba(27,188,156,.15);color:var(--teal);border:1px solid rgba(27,188,156,.3);}
.b-amber {background:rgba(232,160,32,.15);color:var(--amber2);border:1px solid rgba(232,160,32,.3);}
.b-blue  {background:rgba(41,128,185,.18);color:var(--blue2);border:1px solid rgba(41,128,185,.3);}
.b-gray  {background:rgba(107,128,153,.15);color:var(--muted2);border:1px solid rgba(107,128,153,.3);}

/* ── ALERTS ───────────────────────────────────── */
.alert-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px;}
.alert-row:last-child{border-bottom:none;}

/* ── SECTION DIVIDER ─────────────────────────── */
.sec-div{
  font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:2px;
  color:var(--amber);margin:18px 0 12px;padding-bottom:8px;
  border-bottom:1px solid var(--border);
}

/* ── ACTIVITY LOG ─────────────────────────────── */
.log-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);}
.log-item:last-child{border-bottom:none;}
.log-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0;}
.log-body{flex:1;}
.log-title{font-size:13px;font-weight:600;}
.log-meta{font-size:11px;color:var(--muted);margin-top:2px;}

/* ── SCHEDULE ─────────────────────────────────── */
.schedule-card{
  background:var(--panel2);border:1px solid var(--border);
  border-radius:var(--r);padding:16px;
  border-left:4px solid var(--amber);
}
.sch-name{font-weight:700;font-size:14px;}
.sch-vessel{font-size:12px;color:var(--amber);font-weight:600;margin:2px 0;}
.sch-dates{font-size:11px;color:var(--muted);}

/* ── BENEFITS ─────────────────────────────────── */
.ben-card{
  background:var(--panel2);border:1px solid var(--border);
  border-radius:var(--r);padding:20px;cursor:pointer;
  transition:all .2s;
}
.ben-card:hover{border-color:var(--amber);transform:translateY(-2px);}
.ben-ico{font-size:32px;margin-bottom:10px;}
.ben-cat{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:1px;}
.ben-preview{font-size:12px;color:var(--muted);margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

.ben-detail{
  background:var(--panel);border:1px solid var(--border2);
  border-radius:var(--r);padding:24px;margin-top:16px;
  white-space:pre-line;font-size:14px;line-height:1.8;color:var(--muted2);
  animation:fadeUp .3s ease;
}
.ben-detail h2{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:1px;color:var(--white);margin-bottom:12px;}

/* ── CERT STATUS ─────────────────────────────── */
.cert-exp{color:var(--warn);font-weight:700;}
.cert-valid{color:var(--teal);}
.cert-expired{color:var(--rust2);}

/* ── FORM TYPE SELECTOR ──────────────────────── */
.form-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;}
.form-type-btn{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:16px 10px;text-align:center;
  cursor:pointer;transition:all .2s;color:var(--muted);
}
.form-type-btn:hover{border-color:var(--amber);color:var(--white);}
.form-type-btn.sel{border-color:var(--amber);background:rgba(232,160,32,0.08);color:var(--white);}
.fti{font-size:26px;display:block;margin-bottom:6px;}
.ftl{font-size:11px;font-weight:600;letter-spacing:.3px;}

/* ── TABS ─────────────────────────────────────── */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;}
.tab-btn{
  background:none;border:none;color:var(--muted);
  padding:10px 18px;font-size:13px;font-weight:600;
  cursor:pointer;border-bottom:2px solid transparent;
  transition:all .15s;
}
.tab-btn.active{color:var(--amber);border-bottom-color:var(--amber);}
.tab-btn:hover:not(.active){color:var(--white);}

/* ── MODAL ────────────────────────────────────── */
.modal-bg{
  position:fixed;inset:0;background:rgba(0,0,0,0.7);
  z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;
  animation:fadeIn .2s ease;
}
.modal{
  background:var(--panel);border:1px solid var(--border2);
  border-radius:var(--r);padding:28px;width:100%;max-width:560px;
  max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);
  animation:fadeUp .25s ease;
}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:1px;margin-bottom:20px;}
.modal-close{float:right;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;margin-top:-4px;}

/* ── ROLE COLORS ─────────────────────────────── */
.role-admin   {background:rgba(192,57,43,.18);color:var(--rust2);}
.role-captain {background:rgba(232,160,32,.15);color:var(--amber2);}
.role-engineer{background:rgba(41,128,185,.18);color:var(--blue2);}
.role-deckhand{background:rgba(27,188,156,.15);color:var(--teal);}

/* ── EDIT INPUT ──────────────────────────────── */
.ei{
  background:var(--bg2);border:1px solid var(--amber);
  border-radius:4px;padding:4px 8px;color:var(--white);
  font-size:13px;width:80px;outline:none;
}

/* ── DOCUMENT CARD ───────────────────────────── */
.doc-card{
  display:flex;align-items:center;gap:14px;
  padding:14px;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--r2);
  margin-bottom:8px;transition:border-color .2s;
}
.doc-card:hover{border-color:var(--border2);}
.doc-ico{font-size:28px;flex-shrink:0;}
.doc-name{font-weight:600;font-size:13px;}
.doc-meta{font-size:11px;color:var(--muted);margin-top:2px;}
.doc-actions{margin-left:auto;display:flex;gap:6px;}

/* ── PAY CARD ─────────────────────────────────── */
.pay-card{
  display:flex;align-items:center;gap:14px;
  padding:14px;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--r2);
  margin-bottom:8px;
}
.pay-period{font-weight:700;font-size:14px;}
.pay-gross{font-size:12px;color:var(--muted);margin-top:2px;}
.pay-net{font-family:'IBM Plex Mono',monospace;font-size:16px;font-weight:600;color:var(--teal);margin-left:auto;}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:900px){
  .stats{grid-template-columns:repeat(2,1fr);}
  .g2{grid-template-columns:1fr;}
  .g3{grid-template-columns:1fr 1fr;}
  .form-picker{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:768px){
  .sidebar{display:none;}
  .mob-head{display:flex;}
  .bot-nav{display:block;}
  .page{padding:16px;}
  .pt{font-size:28px;}
  .fg{grid-template-columns:1fr;}
  .fg .span2{grid-column:1;}
  .g3{grid-template-columns:1fr;}
  .hide-mob{display:none;}
  .tbl th,.tbl td{padding:8px 10px;}
  .form-picker{grid-template-columns:1fr 1fr;}
}

@media(max-width:480px){
  .stats{grid-template-columns:1fr 1fr;}
  .login-card{padding:28px 20px;}
  .form-picker{grid-template-columns:1fr 1fr;}
}
