@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root{
  --bg:#f4f7fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e2e8f0;
  --primary:#0ea5e9;
  --primary-dark:#0284c7;
  --accent:#14b8a6;
  --soft:#eef2ff;
  --success:#16a34a;
  --warning:#f59e0b;
  --danger:#ef4444;
  --shadow:0 18px 40px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:"Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(1200px 400px at 80% -10%, rgba(14,165,233,.15), transparent 60%),
    radial-gradient(900px 400px at -10% 20%, rgba(20,184,166,.12), transparent 55%),
    var(--bg);
  color:var(--text);
}
.container{max-width:none;margin:0;padding:0;}
.app-shell{max-width:1200px;margin:0 auto;padding:24px 18px 40px;}
.hidden{display:none !important;}

/* Buttons */
.btn{border:none;border-radius:12px;padding:10px 16px;font-weight:700;cursor:pointer;transition:.2s ease;}
.btn.primary{background:linear-gradient(135deg,var(--primary),#38bdf8);color:#fff;box-shadow:0 10px 22px rgba(14,165,233,.25);} 
.btn.success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 10px 22px rgba(22,163,74,.2);} 
.btn.light{background:#f1f5f9;color:#0f172a;border:1px solid var(--border);} 
.btn.ghost{background:#fff;color:#0f172a;border:1px solid var(--border);} 
.btn:hover{transform:translateY(-1px);} 

/* Header */
.portal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;}
.brand-title{font-family:"Sora", sans-serif;font-size:20px;font-weight:800;letter-spacing:.02em;}
.brand-sub{font-size:12px;color:var(--muted);} 
.header-actions{display:flex;align-items:center;gap:10px;}
.customer-chip{background:#fff;border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:12px;color:var(--muted);} 

/* Hero */
.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:18px;align-items:stretch;margin-bottom:18px;}
.hero-left{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow);} 
.hero-left h1{font-family:"Sora", sans-serif;margin:0 0 6px;font-size:24px;} 
.hero-left p{margin:0;color:var(--muted);} 
.hero-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;} 
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;} 

.stat-card{padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;} 
.stat-card label{font-size:11px;color:var(--muted);font-weight:700;display:block;margin-bottom:6px;} 
.stat-card div{font-size:16px;font-weight:800;} 
.stat-card.blue{background:#e0f2fe;border-color:#bae6fd;} 
.stat-card.green{background:#dcfce7;border-color:#bbf7d0;} 
.stat-card.orange{background:#fff7ed;border-color:#fed7aa;} 
.stat-card.gray{background:#f8fafc;} 

/* Panels */
.panel{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:16px;margin-bottom:16px;box-shadow:var(--shadow);} 
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap;} 
.panel h2{margin:0;font-family:"Sora", sans-serif;font-size:18px;} 
.panel .muted{font-size:12px;color:var(--muted);} 
.panel-actions{margin-top:10px;} 
.panel-subtitle{margin-top:14px;font-size:12px;color:var(--muted);font-weight:700;} 

/* Pills */
.pill-group{display:flex;gap:8px;flex-wrap:wrap;} 
.pill{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:700;cursor:pointer;} 
.pill.active{background:var(--primary);color:#fff;border-color:var(--primary);} 

/* Stocks */
.stock-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;} 
@media(max-width:980px){.hero{grid-template-columns:1fr;}.stock-grid{grid-template-columns:repeat(2,minmax(0,1fr));}} 
@media(max-width:640px){.stock-grid{grid-template-columns:1fr;}} 
.stock-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff;} 
.stock-title{font-weight:700;} 
.stock-meta{font-size:11px;color:var(--muted);margin-top:4px;} 
.stock-qty{margin-top:8px;font-weight:800;font-size:16px;} 
.stock-qty span{font-size:12px;color:var(--muted);} 

/* Jobs */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;} 
.tab{padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:#fff;font-weight:700;font-size:12px;cursor:pointer;} 
.tab.active{background:var(--primary);color:#fff;border-color:var(--primary);} 
.jobs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;} 
@media(max-width:900px){.jobs{grid-template-columns:1fr;}} 
.job-card{border:1px solid var(--border);border-radius:14px;padding:12px;cursor:pointer;transition:.2s ease;background:#fff;} 
.job-card:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(15,23,42,.10);} 
.job-top{display:flex;justify-content:space-between;gap:10px;align-items:center;} 
.job-title{font-weight:800;font-size:14px;} 
.job-sub{font-size:12px;color:var(--muted);margin-top:4px;} 
.job-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;} 

.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;} 
.badge.gray{background:#e2e8f0;color:#334155;} 
.badge.blue{background:#dbeafe;color:#1d4ed8;} 
.badge.green{background:#dcfce7;color:#166534;} 
.badge.orange{background:#ffedd5;color:#9a3412;} 

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;} 
.form-grid .full{grid-column:1/-1;} 
@media(max-width:900px){.form-grid{grid-template-columns:1fr;}} 
.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;font-size:14px;background:#fff;} 
.label{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:6px;display:block;} 
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:900px){.grid{grid-template-columns:1fr;}}

/* Request list */
.request-list{display:flex;flex-direction:column;gap:8px;margin-top:8px;} 
.request-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;} 
.request-title{font-weight:700;} 
.request-meta{font-size:12px;color:var(--muted);} 

/* History */
.history-list{display:flex;flex-direction:column;gap:8px;} 
.history-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;} 
.history-title{font-weight:700;} 
.history-meta{font-size:12px;color:var(--muted);} 
.history-qty{font-weight:800;} 

.empty{padding:12px;border:1px dashed #cbd5f5;border-radius:12px;color:#64748b;text-align:center;} 

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:999;} 
.modal{background:#fff;border-radius:16px;width:760px;max-width:92vw;box-shadow:0 30px 60px rgba(15,23,42,.25);} 
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);} 
.modal-body{padding:16px 18px;} 
.modal-footer{padding:14px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;} 
.timeline{display:flex;flex-direction:column;gap:10px;margin-top:10px;} 
.step{display:flex;gap:12px;align-items:flex-start;} 
.dot{width:10px;height:10px;border-radius:999px;background:var(--primary);margin-top:6px;} 
.step-title{font-weight:700;font-size:13px;} 
.step-sub{font-size:12px;color:var(--muted);} 

/* Login */
.login-screen{
  position:relative;
  min-height:100vh;
  background:
    linear-gradient(120deg, rgba(2,132,199,.55), rgba(15,23,42,.8)),
    url('../../portal-bg.png');
  background-size:cover;
  background-position:center;
}
.login-overlay{position:absolute;inset:0;background:radial-gradient(800px 300px at 80% 10%, rgba(56,189,248,.4), transparent 60%);} 
.login-panel{
  position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);
  width:min(680px,92vw);padding:18px;border-radius:16px;background:rgba(255,255,255,.95);
  border:1px solid var(--border);box-shadow:0 24px 48px rgba(15,23,42,.25);
}
.login-panel-title{font-family:"Sora", sans-serif;font-weight:800;font-size:18px;margin-bottom:10px;} 
.login-label{display:block;color:#475569;font-weight:700;font-size:12px;margin-bottom:6px;} 
.login-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;font-size:15px;} 
.login-actions{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap;} 
.login-btn{padding:12px 18px;border-radius:12px;border:1px solid rgba(37,99,235,.4);background:linear-gradient(180deg,#1d4ed8,#2563eb);color:#fff;font-weight:800;cursor:pointer;} 
.login-btn.ghost{background:#f1f5f9;color:#0f172a;} 
.login-note,.login-timer{margin-top:8px;font-size:12px;color:#64748b;} 

@media(max-width:980px){.hero{grid-template-columns:1fr;} .hero-stats{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:640px){.hero-stats{grid-template-columns:1fr;} .login-panel{top:50%;}}
