/* ============================================================
   OneLMS Portal — shared premium theme
   Matches onelms.lk landing (Sora + Inter, indigo→aqua)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
  --ink:#0b0f1a; --ink-2:#10162a; --paper:#f4f6fd; --paper-2:#eef1fb;
  --muted:#5c647e; --line:rgba(13,20,45,.10);
  --indigo:#6366f1; --violet:#8b5cf6; --aqua:#06b6d4; --teal:#14b8a6;
  --gold:#f5b53d; --rose:#fb7185; --emerald:#10b981; --amber:#f59e0b;
  --card:#fff; --shadow:0 24px 60px -30px rgba(13,20,55,.4);
  --r:18px;
  --grad:linear-gradient(115deg,#6366f1,#8b5cf6 42%,#06b6d4);
  --grad-soft:linear-gradient(115deg,rgba(99,102,241,.12),rgba(6,182,212,.12));
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--paper);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60vw 50vw at 8% -8%,rgba(99,102,241,.16),transparent 60%),
    radial-gradient(55vw 45vw at 100% 0%,rgba(6,182,212,.16),transparent 60%),
    radial-gradient(50vw 40vw at 50% 110%,rgba(139,92,246,.12),transparent 60%)}
a{color:var(--indigo);text-decoration:none}
h1,h2,h3,h4{font-family:'Sora',sans-serif;letter-spacing:-.02em;line-height:1.1}
.mono{font-family:'JetBrains Mono',monospace}
.grad-txt{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- top bar ---- */
.pnav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;
  padding:14px 26px;background:rgba(255,255,255,.78);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line)}
.pnav .brand{display:flex;align-items:center;gap:11px;font:700 18px 'Sora';margin-right:auto;color:var(--ink)}
.pnav .bmark{width:34px;height:34px;border-radius:11px;background:var(--grad);display:grid;place-items:center;color:#fff;font:800 18px 'Sora';box-shadow:0 8px 22px -6px rgba(99,102,241,.7)}
.pnav .who{font-size:13px;color:var(--muted)}
.pnav .who b{color:var(--ink)}
.pnav a.logout{font-size:13px;font-weight:600;color:var(--rose);padding:8px 14px;border-radius:999px;border:1px solid var(--line);transition:.2s}
.pnav a.logout:hover{background:rgba(251,113,133,.1)}
.pnav .home{font-size:13px;font-weight:600;color:var(--muted);padding:8px 14px;border-radius:999px;transition:.2s}
.pnav .home:hover{background:var(--grad-soft);color:var(--indigo)}

/* ---- shells ---- */
.shell{max-width:1180px;margin:0 auto;padding:42px 22px 70px}
.shell.narrow{max-width:620px}
.shell.auth{max-width:430px;padding-top:64px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:30px}
.card + .card{margin-top:20px}
.lead{color:var(--muted);font-size:15px}
h1.page{font-size:30px;font-weight:800;margin-bottom:6px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 13px;border-radius:999px;background:var(--grad-soft);border:1px solid var(--line);font:700 11px 'Inter';letter-spacing:.14em;text-transform:uppercase;color:var(--indigo);margin-bottom:14px}

/* ---- alerts ---- */
.alert{padding:14px 16px;border-radius:13px;margin-bottom:20px;font-size:14px;display:flex;gap:10px;align-items:flex-start}
.alert::before{font-weight:800}
.alert.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.alert.error::before{content:"⚠"}
.alert.success{background:#dcfce7;color:#14633b;border:1px solid #bbf7d0}
.alert.success::before{content:"✓"}
.alert.info{background:var(--grad-soft);color:#3730a3;border:1px solid rgba(99,102,241,.2)}
.alert.info::before{content:"ℹ"}

/* ---- forms ---- */
.field{margin-bottom:18px}
label{display:block;font:600 13px 'Inter';color:#3b4256;margin-bottom:7px}
.req::after{content:" *";color:var(--rose)}
input[type=text],input[type=email],input[type=tel],input[type=password],input[type=file],select,textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fcfdff;
  font:500 14.5px 'Inter';color:var(--ink);transition:.2s;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 4px rgba(99,102,241,.13)}
textarea{resize:vertical;min-height:78px}
input[type=file]{padding:10px;background:var(--grad-soft);cursor:pointer}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.full{grid-column:1/-1}
.section-h{grid-column:1/-1;margin:8px 0 2px;font:700 13px 'Sora';color:var(--indigo);letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:9px}
.section-h::after{content:"";flex:1;height:1px;background:var(--line)}
@media(max-width:640px){.grid2{grid-template-columns:1fr}}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:13px 22px;border-radius:12px;
  font:600 14.5px 'Inter';cursor:pointer;border:none;transition:.25s;text-decoration:none}
.btn.block{width:100%}
.btn-pri{background:var(--grad);color:#fff;box-shadow:0 16px 36px -14px rgba(99,102,241,.7)}
.btn-pri:hover{transform:translateY(-2px);box-shadow:0 22px 44px -16px rgba(99,102,241,.8);color:#fff}
.btn-ok{background:linear-gradient(120deg,#10b981,#14b8a6);color:#fff;box-shadow:0 16px 36px -14px rgba(16,185,129,.6)}
.btn-ok:hover{transform:translateY(-2px);color:#fff}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--indigo);color:var(--indigo)}
.btn-sm{padding:8px 13px;font-size:13px;border-radius:10px}

/* ---- product picker ---- */
.prodpick{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:6px}
.prodpick label{display:block;margin:0;cursor:pointer}
.prodpick input{position:absolute;opacity:0;pointer-events:none}
.prodopt{border:1.5px solid var(--line);border-radius:14px;padding:15px;transition:.2s;background:#fcfdff;height:100%}
.prodopt .pi{font-size:22px}
.prodopt .pn{font:700 15px 'Sora';margin-top:6px}
.prodopt .pp{font-size:12.5px;color:var(--muted);margin-top:2px}
.prodpick input:checked + .prodopt{border-color:var(--indigo);background:var(--grad-soft);box-shadow:0 0 0 3px rgba(99,102,241,.12)}
@media(max-width:560px){.prodpick{grid-template-columns:1fr}}

/* ---- bank box ---- */
.bank{background:var(--grad-soft);border:1px dashed rgba(99,102,241,.4);border-radius:14px;padding:18px;margin-bottom:18px}
.bank h4{font-size:14px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.bank table{width:100%;font-size:13.5px}
.bank td{padding:3px 0}
.bank td:first-child{color:var(--muted);width:120px}
.bank td:last-child{font-weight:600;font-family:'JetBrains Mono'}
.adv-callout{margin-top:12px;padding:12px 14px;border-radius:11px;background:#fff;border:1px solid var(--line);font-size:14px}
.adv-callout b{font-family:'Sora';font-size:20px;color:var(--indigo)}

/* ---- status / progress ---- */
.statushead{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.pill{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:999px;font:700 13px 'Inter';background:var(--grad-soft);color:var(--indigo)}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--indigo);box-shadow:0 0 0 4px rgba(99,102,241,.18)}
.meta{font-size:13px;color:var(--muted)}
.meta b{color:var(--ink)}

.steps{display:flex;gap:0;margin:30px 0 6px;overflow-x:auto;padding-bottom:12px}
.stepi{flex:1;min-width:88px;text-align:center;position:relative}
.stepi::before{content:"";position:absolute;top:17px;left:-50%;width:100%;height:3px;background:var(--line);z-index:0}
.stepi:first-child::before{display:none}
.stepi .c{position:relative;z-index:1;width:36px;height:36px;border-radius:50%;margin:0 auto 9px;display:grid;place-items:center;font:700 14px 'Sora';background:#fff;border:2px solid var(--line);color:var(--muted)}
.stepi .l{font-size:10.5px;font-weight:600;color:var(--muted);line-height:1.3;padding:0 4px}
.stepi.done .c{background:var(--emerald);border-color:var(--emerald);color:#fff}
.stepi.done::before{background:var(--emerald)}
.stepi.done .l{color:var(--emerald)}
.stepi.active .c{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 0 0 5px rgba(99,102,241,.18)}
.stepi.active .l{color:var(--indigo)}

.action-card{border-left:4px solid var(--indigo)}
.action-card.warn{border-left-color:var(--amber)}
.action-card.pay{border-left-color:var(--rose)}
.waiting{text-align:center;padding:46px 20px}
.waiting .e{font-size:42px}
.waiting h3{color:var(--indigo);margin:10px 0 6px}
.waiting p{color:var(--muted);font-size:15px;max-width:440px;margin:0 auto}

/* ---- admin table ---- */
.tbl-wrap{overflow-x:auto}
table.admin{width:100%;border-collapse:collapse;font-size:13.5px;min-width:760px}
table.admin th,table.admin td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
table.admin th{font:700 12px 'Inter';text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--paper-2)}
table.admin tbody tr:hover{background:var(--grad-soft)}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font:700 11px 'Inter';background:rgba(99,102,241,.13);color:var(--indigo)}
.badge.pending{background:#fef3c7;color:#92560e}
.badge.live{background:#dcfce7;color:#14633b}
.slip-link{font-size:12px;font-weight:600;display:inline-block;margin-right:8px}
.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.muted-link{color:var(--muted);font-size:12px}

/* footer note */
.foot{text-align:center;color:var(--muted);font-size:12.5px;margin-top:26px}
.foot a{font-weight:600}
