/* ============================================================
   SWATrade Client Portal — portal.css
   Styled to match the swatrade.com homepage design system.
   Tokens mirror css/style.css (Cinzel display, gold accent,
   navy backgrounds, blue-gradient primary button).
   No cursor glow in member areas.
   ============================================================ */
:root{
  --bg:#060D1A; --panel:#0C1828; --panel2:#122036; --line:#162030;
  --text:#F2F0ED; --muted:#8A8880; --subtle:#4A5060;
  --accent:#C4933A; --accent2:#E3C789;
  --blue:#1A4FA0; --green:#2ea66b; --red:#d0524e; --radius:12px;
  --font-d:'Cinzel',serif; --font-b:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-b);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent2)}
h1,h2{font-family:var(--font-d);font-weight:600;letter-spacing:.4px;color:var(--text)}

/* nav */
.pnav{border-bottom:1px solid var(--line);background:rgba(6,13,26,.92);backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}
.pnav__in{max-width:1100px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.pnav__logo{display:flex;align-items:center;gap:11px;color:var(--text)}
.pnav__logo:hover{color:var(--text)}
.pnav__logo img{height:30px}
.pnav__logo span{font-family:var(--font-d);font-size:15px;font-weight:600;letter-spacing:1.5px;color:var(--accent2)}
.pnav__links{display:flex;align-items:center;gap:22px}
.pnav__links a{font-family:var(--font-d);font-size:11.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted)}
.pnav__links a:hover{color:var(--accent2)}
.pnav__who{color:var(--subtle);font-size:12px;font-family:var(--font-d);letter-spacing:1px;text-transform:uppercase}

/* layout */
.pwrap{max-width:1100px;margin:0 auto;padding:48px 32px 72px}
.ph{margin:0 0 6px;font-size:30px}
.muted{color:var(--muted)}
.flash{background:rgba(46,166,107,.12);border:1px solid rgba(46,166,107,.4);color:#a9e3c5;padding:13px 16px;border-radius:var(--radius);margin-bottom:24px}
.err{background:rgba(208,82,78,.12);border:1px solid rgba(208,82,78,.45);color:#f0b3b1;padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}
.empty{background:var(--panel);border:1px dashed var(--line);border-radius:var(--radius);padding:48px;text-align:center;color:var(--muted)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--panel2);color:var(--text);
  padding:12px 24px;border-radius:9px;font-family:var(--font-b);font-size:12.5px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;cursor:pointer;transition:.16s}
.btn:hover{border-color:var(--accent);color:var(--accent2)}
.btn-primary{color:#fff;border:1px solid rgba(120,160,220,.18);
  background:linear-gradient(180deg,#1B4A92 0%,#0B1E44 100%);
  box-shadow:0 10px 26px -14px rgba(0,0,0,.72), inset 0 1px 0 rgba(255,255,255,.06)}
.btn-primary:hover{background:linear-gradient(180deg,#205AB0 0%,#0F2A5E 100%);color:#fff;transform:translateY(-1px)}
.btn-gold{background:linear-gradient(180deg,var(--accent2),var(--accent));border-color:var(--accent);color:#1a1305}
.btn-gold:hover{filter:brightness(1.07);color:#1a1305}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--line)}
.btn-ghost:hover{color:var(--red);border-color:var(--red)}
.btn-sm{padding:7px 15px;font-size:11px;border-radius:7px}

/* auth / request cards */
.auth{max-width:900px;margin:0 auto}
.auth__hero{text-align:center;margin:14px 0 34px}
.auth__hero h1{font-size:32px;margin:0 0 10px}
.auth__hero p{color:var(--muted);margin:0}
.auth__cards{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:720px){.auth__cards{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.card h2{margin:0 0 18px;font-size:20px}
.card.is-active{border-color:var(--accent)}
form label{display:block;font-family:var(--font-d);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
form input,form textarea{display:block;width:100%;margin-top:7px;background:rgba(0,0,0,.32);border:1px solid var(--line);border-radius:8px;color:var(--text);padding:12px 13px;font:inherit;font-family:var(--font-b)}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,147,58,.14)}
.row{display:flex;gap:12px}
.row label{flex:1}

/* panels / tables */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:22px}
.panel h2{margin:0 0 18px;font-size:19px;display:flex;align-items:center;gap:10px}
.badge{background:var(--accent);color:#1a1305;border-radius:20px;padding:1px 9px;font-family:var(--font-b);font-size:12px;font-weight:600}
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;color:var(--muted);font-family:var(--font-d);font-weight:500;font-size:10.5px;text-transform:uppercase;letter-spacing:1px;padding:10px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.actions{display:flex;gap:8px}
.actions form{margin:0}
.pill{font-size:11px;padding:3px 11px;border-radius:20px;text-transform:capitalize;font-family:var(--font-d);letter-spacing:.5px}
.pill-approved{background:rgba(46,166,107,.18);color:#7fd6a8}
.pill-suspended,.pill-pending{background:rgba(208,82,78,.18);color:#eda6a3}
.upload label{margin-bottom:14px}

/* files (client) */
.files{display:flex;flex-direction:column;gap:12px;margin-top:20px}
.file{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;transition:border-color .16s}
.file:hover{border-color:var(--accent)}
.file__title{font-weight:600;font-size:16px}
.file__desc{color:var(--muted);font-size:14px;margin-top:4px}
.file__meta{color:var(--subtle);font-size:12px;margin-top:6px}
.pfoot{max-width:1100px;margin:0 auto;padding:34px 32px;color:var(--subtle);font-size:12.5px;border-top:1px solid var(--line);font-family:var(--font-d);letter-spacing:.5px}

/* onboarding disclosure */
.disc{max-height:400px;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-top:16px}
.disc__head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:8px}
.disc__head strong{font-family:var(--font-d);font-weight:600;font-size:16px}
.disc__head span{color:var(--red);font-size:12px}
.disc h3{font-family:var(--font-d);font-weight:600;font-size:15px;margin:20px 0 5px;color:var(--accent2);letter-spacing:.3px}
.disc p{font-size:14px;color:#c8d2e0;margin:0}
.disc__warn{margin-top:18px;background:rgba(208,82,78,.12);border:1px solid rgba(208,82,78,.4);border-radius:8px;padding:12px 14px;font-weight:600;font-size:13px;text-align:center}
.disc__scrollnote{text-align:center;color:var(--accent2);font-size:13px;margin-top:14px}
.chk{display:flex !important;gap:11px;align-items:flex-start;margin:14px 0;color:var(--text);font-size:14px;cursor:pointer}
.chk input{width:auto;margin-top:3px;flex:0 0 auto}
.sigwrap{position:relative;background:#fff;border-radius:8px;border:1px solid var(--line);overflow:hidden;max-width:660px}
.sigwrap canvas{width:100%;height:150px;display:block;touch-action:none;cursor:crosshair}
.sigph{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);text-align:center;color:#aaa;font-size:14px;pointer-events:none}

/* password eye toggle — used on request.php and login/account pages */
.pw-wrap{position:relative}
.pw-wrap input{padding-right:46px}
.pw-toggle{position:absolute;top:50%;right:6px;transform:translateY(-50%);width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer;
  color:var(--muted);transition:color .15s}
.pw-toggle:hover{color:var(--accent)}
.pw-toggle svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pw-toggle .ic-eyeoff{display:none}
.pw-toggle.is-on .ic-eye{display:none}
.pw-toggle.is-on .ic-eyeoff{display:block}

/* ============================================================
   Site footer — identical to the swatrade.com homepage footer
   (tokens mapped to portal.css variable names)
   ============================================================ */
.footer{background:#040A14;border-top:1px solid var(--line);padding:60px 0 40px;margin-top:56px}
.footer__inner{max-width:1100px;margin:0 auto;padding:0 32px}
.footer__top{display:grid;grid-template-columns:auto 1fr auto;gap:48px;align-items:start;margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.footer__brand img{height:38px;width:auto;margin-bottom:12px}
.footer__brand p{font-size:13px;color:var(--subtle);max-width:200px;line-height:1.6}
.footer__nav{display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.footer__nav a{font-family:var(--font-b);font-size:13px;color:var(--muted);letter-spacing:.05em;text-transform:none}
.footer__nav a:hover{color:var(--text)}
.footer__disclaimer{padding:28px;background:var(--panel);border:1px solid var(--line);margin-bottom:36px}
.footer__disclaimer p{font-size:11px;color:var(--subtle);line-height:1.7;font-style:italic;margin:0}
.footer__disclaimer strong{color:var(--muted);font-style:normal}
.footer__motto{text-align:center;padding:20px 0 16px;border-top:1px solid var(--line);margin-top:16px}
.footer__motto p{font-family:var(--font-d);font-size:clamp(11px,1.2vw,14px);letter-spacing:.12em;color:var(--subtle);display:flex;align-items:center;justify-content:center;gap:14px;margin:0}
.footer__cross{color:var(--accent);font-size:20px;line-height:1;flex-shrink:0}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer__copy{font-size:12px;color:var(--subtle);margin:0}
@media(max-width:720px){.footer__top{grid-template-columns:1fr;gap:28px}.footer__nav{align-items:flex-start}}
