/* ===== NicePe portal theme ===== */
:root{
  --p1:#5b2a86; --p2:#7c3aed; --p3:#4c1d95;
  --o1:#f7941d; --o2:#ff7a00;
  --ink:#1f2233; --muted:#6b7280; --line:#eceef3; --bg:#f4f5fa; --card:#fff;
  --ok:#10b981; --okb:#e7f8f1; --warn:#f59e0b; --warnb:#fff6e6; --bad:#ef4444; --badb:#fdeaea;
  --grad:linear-gradient(120deg,var(--p1),var(--p2) 55%,var(--o1));
  --radius:14px; --shadow:0 6px 22px rgba(31,34,51,.08); --shadow2:0 2px 10px rgba(31,34,51,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);font-size:14.5px;line-height:1.5}
a{color:var(--p2);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
h1,h2,h3,h4{margin:0 0 .4em}
.muted{color:var(--muted)}
.small{font-size:12.5px}
.center{text-align:center}
.right{text-align:right}
.nowrap{white-space:nowrap}
.hide{display:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:0;cursor:pointer;
  background:var(--grad);color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;font-size:14px;transition:.15s;text-decoration:none}
.btn:hover{filter:brightness(1.05);text-decoration:none;transform:translateY(-1px)}
.btn:disabled{opacity:.6;cursor:not-allowed}
.btn.o{background:#fff;color:var(--p2);border:1.5px solid #e7defb}
.btn.o:hover{background:#faf7ff}
.btn.g{background:linear-gradient(120deg,#0ea371,#10b981)}
.btn.r{background:linear-gradient(120deg,#e11d48,#ef4444)}
.btn.sm{padding:7px 12px;font-size:12.5px;border-radius:8px}
.btn.full{width:100%}
.btn.ghost{background:transparent;color:var(--p2);border:1px solid var(--line)}

/* badges + alerts */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.b-ok{background:var(--okb);color:#0b7a55}.b-warn{background:var(--warnb);color:#a96a00}
.b-bad{background:var(--badb);color:#b91c1c}.b-muted{background:#eef0f5;color:#566}
.alert{padding:12px 14px;border-radius:10px;margin:0 0 14px;font-size:13.5px;border:1px solid transparent}
.alert.ok{background:var(--okb);border-color:#bdebd9;color:#0b7a55}
.alert.err{background:var(--badb);border-color:#f5c4c4;color:#b91c1c}
.alert.info{background:#eef2ff;border-color:#d6deff;color:#3b46b3}

/* cards + grid */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow2)}
.card .hd{padding:14px 16px;border-bottom:1px solid var(--line);font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .bd{padding:16px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g2,.g3,.g4{grid-template-columns:1fr}}

/* forms */
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:13px;margin-bottom:6px}
.input,select,textarea{width:100%;padding:11px 12px;border:1.5px solid #e3e6ef;border-radius:10px;font-size:14px;background:#fff;color:var(--ink);font-family:inherit}
.input:focus,select:focus,textarea:focus{outline:0;border-color:var(--p2);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
.req{color:var(--bad)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>.col{flex:1;min-width:180px}

/* tables */
.table-wrap{overflow-x:auto;border-radius:12px}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;background:#fff}
table.tbl th,table.tbl td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
table.tbl th{background:#faf8ff;color:#5b5570;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
table.tbl tr:hover td{background:#fcfbff}

/* ======= PUBLIC SITE ======= */
.nav{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav .in{max-width:1140px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:12px 18px}
.nav .sp{flex:1}
.nav a.lnk{color:var(--ink);font-weight:600;font-size:14px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;color:var(--p1)}
.brand .dot{width:30px;height:30px;border-radius:9px;background:var(--grad);display:inline-block}
.hero{background:var(--grad);color:#fff;position:relative;overflow:hidden}
.hero .in{max-width:1140px;margin:0 auto;padding:64px 18px;display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center}
.hero h1{font-size:40px;line-height:1.12;margin-bottom:14px}
.hero p{font-size:16.5px;opacity:.95;max-width:520px}
.hero .pills{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 24px}
.pill{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);padding:7px 13px;border-radius:999px;font-weight:600;font-size:13px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.hero .btn.o{background:#fff;color:var(--p1)}
.heroCard{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:18px;padding:18px}
.heroCard .row4{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.heroCard .ic{background:rgba(255,255,255,.14);border-radius:12px;padding:14px 8px;text-align:center;font-size:12px;font-weight:600}
.heroCard .ic svg{width:26px;height:26px;margin-bottom:6px}
@media(max-width:860px){.hero .in{grid-template-columns:1fr;padding:40px 18px}.hero h1{font-size:30px}}
.sec{max-width:1140px;margin:0 auto;padding:56px 18px}
.sec h2{font-size:28px;text-align:center}
.sec .lead{text-align:center;color:var(--muted);max-width:620px;margin:0 auto 34px}
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.feat{grid-template-columns:1fr}}
.feat .f{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow2)}
.feat .f .ico{width:48px;height:48px;border-radius:12px;background:#f3edff;color:var(--p2);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.feat .f .ico svg{width:26px;height:26px}
.svcband{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svcgrid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media(max-width:860px){.svcgrid{grid-template-columns:repeat(3,1fr)}}
.svcgrid .t{text-align:center;padding:16px 8px;border:1px solid var(--line);border-radius:12px;font-size:12.5px;font-weight:600;background:#fff}
.svcgrid .t .ci{width:46px;height:46px;border-radius:50%;background:#f3edff;color:var(--p2);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.svcgrid .t .ci svg{width:24px;height:24px}
.foot{background:#241433;color:#cfc6dd;margin-top:0}
.foot .in{max-width:1140px;margin:0 auto;padding:40px 18px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.foot h4{color:#fff}
.foot a{color:#cfc6dd;display:block;margin:6px 0}
.foot .bar{border-top:1px solid #3a2a4d;text-align:center;padding:16px;color:#9b8fae;font-size:12.5px}
@media(max-width:860px){.foot .in{grid-template-columns:1fr}}

/* ======= AUTH ======= */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth .side{background:var(--grad);color:#fff;padding:48px;display:flex;flex-direction:column;justify-content:center}
.auth .side h2{font-size:32px}
.auth .side .pt{display:flex;gap:10px;align-items:flex-start;margin:14px 0}
.auth .side .pt .d{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.2);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.auth .side .pt svg{width:16px;height:16px}
.auth .main{display:flex;align-items:center;justify-content:center;padding:30px}
.auth .box{width:100%;max-width:400px}
.auth .box .brand{justify-content:center;margin-bottom:6px}
@media(max-width:860px){.auth{grid-template-columns:1fr}.auth .side{display:none}}

/* ======= APP SHELL ======= */
.shell{display:grid;grid-template-columns:256px 1fr;min-height:100vh}
.side{background:#fff;border-right:1px solid var(--line);position:sticky;top:0;height:100vh;overflow-y:auto}
.side .pro{background:var(--grad);color:#fff;padding:18px 16px}
.side .pro .av{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;margin-bottom:10px}
.side .pro .nm{font-weight:700;font-size:16px}
.side .pro .meta{font-size:12px;opacity:.92;margin-top:3px}
.side .pro .stars{color:#ffd36b;margin-top:6px;font-size:13px}
.side .menu{padding:10px 8px}
.side .menu .lbl{font-size:11px;text-transform:uppercase;color:#9aa0b4;letter-spacing:.5px;padding:12px 12px 6px;font-weight:700}
.side .menu a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:#3a3550;font-weight:600;font-size:13.5px;margin:1px 0}
.side .menu a svg{width:19px;height:19px;color:#8a85a0}
.side .menu a:hover{background:#f6f3ff;text-decoration:none}
.side .menu a.on{background:#f1ebff;color:var(--p2)}
.side .menu a.on svg{color:var(--p2)}
.main{display:flex;flex-direction:column;min-width:0}
.top{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:11px 18px}
.top .burger{display:none;background:none;border:0;cursor:pointer;font-size:22px;color:var(--p2)}
.top .news{flex:1;overflow:hidden;white-space:nowrap;background:#f6f3ff;border-radius:8px;padding:8px 12px;font-size:13px;color:#5b5570}
.top .news .mv{display:inline-block;padding-left:100%;animation:mv 22s linear infinite}
@keyframes mv{to{transform:translateX(-100%)}}
.top .tools{display:flex;align-items:center;gap:12px}
.top .tools .ic{width:36px;height:36px;border-radius:9px;background:#f6f3ff;color:var(--p2);display:flex;align-items:center;justify-content:center}
.top .tools .ic svg{width:18px;height:18px}
.content{padding:18px;max-width:1180px;width:100%}
.pagehd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.pagehd h1{font-size:21px;margin:0}
.crumbs{font-size:12.5px;color:var(--muted)}

/* wallet cards */
.wallets{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
@media(max-width:760px){.wallets{grid-template-columns:1fr}}
.wcard{border-radius:14px;padding:16px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.wcard.balance{background:linear-gradient(120deg,#5b2a86,#7c3aed)}
.wcard.bank{background:linear-gradient(120deg,#0ea371,#10b981)}
.wcard.reward{background:linear-gradient(120deg,#f7941d,#ff7a00)}
.wcard .lab{font-size:12.5px;opacity:.92}
.wcard .val{font-size:25px;font-weight:800;margin-top:2px}
.wcard .act{margin-top:10px}
.wcard .act a{color:#fff;background:rgba(255,255,255,.2);padding:6px 12px;border-radius:8px;font-size:12.5px;font-weight:600}
.wcard .gi{position:absolute;right:12px;top:12px;opacity:.5}
.wcard .gi svg{width:34px;height:34px}

/* banner carousel */
.carousel{position:relative;border-radius:16px;overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow)}
.carousel .slides{display:flex;transition:transform .5s ease}
.carousel .slide{min-width:100%}
.carousel .slide img{width:100%;display:block;height:200px;object-fit:cover}
.carousel .dots{position:absolute;bottom:10px;left:0;right:0;display:flex;gap:7px;justify-content:center}
.carousel .dots b{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.6);cursor:pointer}
.carousel .dots b.on{background:#fff;width:22px;border-radius:6px}
.carousel .ar{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.3);color:#fff;border:0;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:18px}
.carousel .ar.l{left:10px}.carousel .ar.r{right:10px}

/* services grid (dashboard) */
.svccat{font-weight:800;font-size:15px;margin:22px 0 12px;display:flex;align-items:center;gap:10px;color:#3a3550}
.svccat:before{content:'';width:4px;height:18px;border-radius:3px;background:var(--grad)}
.svcs{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media(max-width:980px){.svcs{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.svcs{grid-template-columns:repeat(3,1fr)}}
.svc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 8px;text-align:center;color:#3a3550;transition:.15s;position:relative;display:block}
.svc:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none;border-color:#e0d6fb}
.svc .ci{width:54px;height:54px;border-radius:50%;background:#f3edff;color:var(--p2);display:flex;align-items:center;justify-content:center;margin:0 auto 9px}
.svc .ci svg{width:27px;height:27px}
.svc .nm{font-size:12.5px;font-weight:600;line-height:1.3}
.svc .nb{position:absolute;top:8px;right:8px;background:var(--o1);color:#fff;font-size:9px;font-weight:800;padding:2px 6px;border-radius:6px}
.svc.off{opacity:.45;pointer-events:none}

/* stat cards (admin/reports) */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
@media(max-width:980px){.stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.stats{grid-template-columns:1fr}}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow2);display:flex;gap:13px;align-items:center}
.stat .si{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto}
.stat .si svg{width:24px;height:24px}
.stat .v{font-size:21px;font-weight:800;line-height:1}
.stat .l{font-size:12px;color:var(--muted);margin-top:4px}
.c-p{background:linear-gradient(120deg,#5b2a86,#7c3aed)}.c-o{background:linear-gradient(120deg,#f7941d,#ff7a00)}
.c-g{background:linear-gradient(120deg,#0ea371,#10b981)}.c-b{background:linear-gradient(120deg,#2563eb,#3b82f6)}

/* receipt */
.receipt{max-width:430px;margin:0 auto}
.receipt .top{background:var(--grad);color:#fff;border-radius:14px 14px 0 0;padding:22px;text-align:center}
.receipt .top .ok{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.receipt .top .ok svg{width:34px;height:34px}
.receipt .rows{background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 14px 14px}
.receipt .rows .r{display:flex;justify-content:space-between;padding:12px 18px;border-bottom:1px dashed var(--line);font-size:13.5px}
.receipt .rows .r b{font-weight:700}

@media(max-width:900px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:-280px;width:256px;z-index:50;transition:left .25s;box-shadow:var(--shadow)}
  .side.open{left:0}
  .top .burger{display:block}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:40}
  .scrim.show{display:block}
}
