/* ═══════════════════════════════════════════════
   YOURMIDDLEMAN.COM — COMPLETE UI SYSTEM
   Royal Mobile Style · Teal/Mint · Premium
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --pink:#0d9488;--pink2:#14b8a6;--pink3:#5eead4;--pink4:#f0fdfa;
  --purple:#059669;--purple2:#10b981;--purple3:#6ee7b7;
  --purple-deep:#042f2e;--purple-mid:#115e59;
  --gold:#f59e0b;--green:#10b981;--blue:#3b82f6;
  --orange:#f97316;--red:#ef4444;
  --bg:#f0fbfa;--bg2:#e6f7f5;--bg3:#d7f3ef;
  --dark:#042f2e;--dark2:#0f3d3a;--dark3:#115e59;
  --card:#ffffff;
  --text:#042f2e;--text2:#1f6f64;--muted:#5f9c91;
  --border:rgba(17,94,89,.12);--border2:rgba(17,94,89,.07);
  --font:'Nunito',system-ui,sans-serif;
  --nav-h:60px;--bottom-h:88px;--sidebar-w:240px;
  --r:18px;--r-sm:12px;--r-xs:8px;
  --shadow:0 4px 20px rgba(4,47,46,.12);
  --shadow-dark:0 8px 32px rgba(0,0,0,.3);
  --shadow-card:0 2px 12px rgba(4,47,46,.08);
}

html{font-size:15px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;min-height:100vh}
a{color:var(--pink);text-decoration:none;transition:opacity .15s}
a:hover{opacity:.8}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--pink3);border-radius:99px}

/* ══ TOPBAR ══ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);
  background:rgba(255,255,255,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 20px;
  box-shadow:0 2px 12px rgba(4,47,46,.05);
}
.navbar-brand{display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-icon{width:38px;height:38px;border-radius:50%;border:2px solid var(--pink);
  background:linear-gradient(135deg,#5eead4,#0d9488);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.brand-text{font-size:15px;font-weight:800;color:var(--pink);letter-spacing:.01em}
.brand-text span{color:var(--pink)}
.navbar-menu{display:flex;align-items:center;gap:8px}
.navbar-link{font-size:13px;font-weight:600;color:var(--text2);padding:7px 12px;border-radius:var(--r-xs);text-decoration:none;transition:all .15s}
.navbar-link:hover{color:var(--pink);background:var(--pink4)}
.wallet-pill{display:flex;align-items:center;gap:6px;background:rgba(16,185,129,.1);border:1.5px solid rgba(16,185,129,.2);color:var(--green);font-size:12px;font-weight:800;padding:6px 14px;border-radius:99px;text-decoration:none;transition:all .2s}
.wallet-pill:hover{background:rgba(16,185,129,.18);opacity:1;color:var(--green)}

/* ══ LAYOUT ══ */
.layout{display:flex;padding-top:var(--nav-h);min-height:100vh}

/* ══ SIDEBAR ══ */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;background:var(--card);
  border-right:1px solid var(--border2);
  position:fixed;top:var(--nav-h);left:0;bottom:0;overflow-y:auto;
  padding:16px 10px;display:flex;flex-direction:column;gap:1px;
  box-shadow:2px 0 12px rgba(4,47,46,.04);
}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 8px 16px;border-bottom:1px solid var(--border2);margin-bottom:10px}
.sidebar-avatar{width:38px;height:38px;flex-shrink:0;border-radius:12px;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:#fff;
  box-shadow:0 3px 10px rgba(13,148,136,.3)}
.sidebar-user-info p{font-size:13px;font-weight:700;color:var(--text);line-height:1.2}
.sidebar-user-info small{font-size:11px;color:var(--green);font-weight:700}
.sidebar-section{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:10px 10px 4px;margin-top:4px}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);font-size:13px;font-weight:600;color:var(--text2);transition:all .18s;text-decoration:none;position:relative}
.sidebar-link:hover{background:var(--pink4);color:var(--pink);opacity:1}
.sidebar-link.active{background:linear-gradient(135deg,rgba(13,148,136,.1),rgba(5,150,105,.08));color:var(--pink);font-weight:700;border-right:3px solid var(--pink)}
.sidebar-link .icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.sidebar-divider{height:1px;background:var(--border2);margin:8px 0}
.sidebar-link.logout:hover{background:rgba(239,68,68,.06);color:var(--red)}
.main-content{flex:1;margin-left:var(--sidebar-w);padding:28px;min-width:0;transition:opacity .15s ease}

/* ══ MOBILE TOPBAR ══ */
.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);
  background:rgba(255,255,255,.88);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  align-items:center;justify-content:space-between;padding:0 16px;
  box-shadow:0 2px 10px rgba(4,47,46,.05)}
.mobile-topbar-brand{display:flex;align-items:center;gap:8px;text-decoration:none}
.mobile-topbar-right{display:flex;align-items:center;gap:8px}

/* ══ BOTTOM NAV (mobile) ══ */
.bottom-nav{display:none;position:fixed;bottom:14px;left:14px;right:14px;z-index:300;
  height:auto;background:var(--card);
  padding:10px 8px 8px;align-items:flex-start;justify-content:space-around;
  border-radius:24px;box-shadow:0 14px 34px rgba(4,47,46,.2)}
.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;
  cursor:pointer;text-decoration:none;background:none;border:none;
  font-family:var(--font);color:var(--muted);font-size:9.5px;font-weight:800;
  letter-spacing:.03em;text-transform:uppercase;padding:4px 8px;
  transition:color .2s;min-width:48px}
.bottom-nav-item .bn-icon{font-size:22px;line-height:1;transition:transform .2s}
.bottom-nav-item.active{color:var(--purple-mid)}
.bottom-nav-item.active .bn-icon{transform:translateY(-2px)}
.bottom-nav-fab{width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--purple-mid));
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:0 10px 24px rgba(17,94,89,.4);margin-top:-30px;
  border:5px solid var(--card);cursor:pointer;text-decoration:none;transition:all .22s;color:#fff}
.bottom-nav-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 12px 28px rgba(17,94,89,.5)}

/* ══ MOBILE SHEET ══ */
.mobile-menu-overlay{display:none;position:fixed;inset:0;background:rgba(4,47,46,.5);z-index:500;backdrop-filter:blur(4px)}
.mobile-menu-overlay.show{display:block}
.mobile-menu-sheet{position:fixed;bottom:0;left:0;right:0;z-index:501;
  background:var(--card);border-radius:24px 24px 0 0;
  padding:20px 16px 36px;
  transform:translateY(100%);transition:transform .32s cubic-bezier(.32,.72,0,1);
  box-shadow:0 -10px 40px rgba(0,0,0,.15)}
.mobile-menu-sheet.show{transform:translateY(0)}
.mobile-menu-handle{width:44px;height:5px;background:var(--bg3);border-radius:99px;margin:0 auto 22px}
.mobile-menu-user{display:flex;align-items:center;gap:12px;padding:14px;
  background:var(--bg);border-radius:16px;margin-bottom:16px;border:1px solid var(--border2)}
.mobile-menu-avatar{width:44px;height:44px;border-radius:14px;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;
  box-shadow:0 3px 12px rgba(13,148,136,.3)}
.mobile-menu-links{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.mobile-menu-link{display:flex;align-items:center;gap:10px;padding:13px;
  background:var(--bg);border-radius:14px;font-size:13px;font-weight:700;
  color:var(--text);text-decoration:none;border:1px solid var(--border2);transition:all .18s}
.mobile-menu-link:hover{border-color:var(--pink);color:var(--pink);background:var(--pink4);opacity:1}
.mobile-menu-link .icon{font-size:18px}
.mobile-menu-link.danger:hover{border-color:var(--red);color:var(--red);background:rgba(239,68,68,.05)}

/* ══ CARDS ══ */
.card{background:var(--card);border:1px solid var(--border2);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-card);transition:box-shadow .2s}
.card:hover{box-shadow:var(--shadow)}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border2);
  font-weight:800;font-size:14px;color:var(--text);
  display:flex;align-items:center;justify-content:space-between;background:var(--bg)}
.card-body{padding:18px}

/* ══ ADMIN / SECTION HERO BANNER ══ */
.admin-hero-wrap{background:linear-gradient(135deg,var(--purple-deep),var(--purple-mid));
  border-radius:18px;padding:16px 20px;box-shadow:0 10px 26px rgba(4,47,46,.25)}
.admin-hero-wrap .page-title{color:#fff}
.admin-hero-wrap .page-sub{color:rgba(255,255,255,.75)}

/* ══ STAT CARDS ══ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border2);border-radius:var(--r);
  padding:18px 16px;transition:all .22s;position:relative;overflow:hidden;box-shadow:var(--shadow-card)}
.stat-card::after{content:'';position:absolute;bottom:-20px;right:-20px;width:70px;height:70px;border-radius:50%;opacity:.06;background:var(--pink)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.stat-icon{font-size:22px;margin-bottom:10px}
.stat-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}
.stat-value{font-size:22px;font-weight:900;color:var(--text);line-height:1}

/* ══ BUTTONS ══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 20px;border-radius:99px;font-size:13px;font-weight:800;
  cursor:pointer;border:none;transition:all .2s;text-decoration:none;
  white-space:nowrap;font-family:var(--font)}
.btn-primary{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;box-shadow:0 4px 16px rgba(13,148,136,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(13,148,136,.45);opacity:1;color:#fff}
.btn-secondary{background:var(--card);color:var(--text);border:1.5px solid var(--border);box-shadow:var(--shadow-card)}
.btn-secondary:hover{background:var(--bg);border-color:var(--pink);color:var(--pink);opacity:1}
.btn-success{background:linear-gradient(135deg,#059669,var(--green));color:#fff;box-shadow:0 4px 14px rgba(16,185,129,.3)}
.btn-success:hover{transform:translateY(-2px);opacity:1;color:#fff}
.btn-danger{background:linear-gradient(135deg,#dc2626,var(--red));color:#fff;box-shadow:0 4px 14px rgba(239,68,68,.25)}
.btn-danger:hover{transform:translateY(-2px);opacity:1;color:#fff}
.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border)}
.btn-ghost:hover{color:var(--pink);border-color:var(--pink);background:var(--pink4);opacity:1}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-lg{padding:14px 28px;font-size:15px}
.btn-block{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* ══ FORMS ══ */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.form-control{width:100%;padding:11px 14px;background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r-sm);color:var(--text);font-size:14px;font-family:var(--font);transition:all .15s}
.form-control:focus{outline:none;border-color:var(--pink);background:var(--card);box-shadow:0 0 0 3px rgba(13,148,136,.1)}
.form-control::placeholder{color:var(--muted)}
textarea.form-control{resize:vertical;min-height:88px}
select.form-control{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239d7bb5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center}

/* ══ ALERTS ══ */
.alert{padding:12px 15px;border-radius:var(--r-sm);font-size:13px;margin-bottom:14px;font-weight:600}
.alert-danger{background:rgba(239,68,68,.07);border:1.5px solid rgba(239,68,68,.2);color:var(--red)}
.alert-success{background:rgba(16,185,129,.07);border:1.5px solid rgba(16,185,129,.2);color:#059669}
.alert-info{background:rgba(5,150,105,.07);border:1.5px solid rgba(5,150,105,.18);color:var(--purple)}
.alert-warning{background:rgba(245,158,11,.07);border:1.5px solid rgba(245,158,11,.2);color:#b45309}

/* ══ BADGES ══ */
.badge{display:inline-flex;align-items:center;padding:4px 11px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.02em}
.badge-pending{background:rgba(245,158,11,.12);color:#b45309;border:1px solid rgba(245,158,11,.2)}
.badge-submitted{background:rgba(59,130,246,.12);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.badge-verified,.badge-completed{background:rgba(16,185,129,.12);color:#059669;border:1px solid rgba(16,185,129,.2)}
.badge-delivered{background:rgba(5,150,105,.12);color:var(--purple);border:1px solid rgba(5,150,105,.2)}
.badge-confirmed{background:rgba(0,196,140,.12);color:#059669;border:1px solid rgba(0,196,140,.2)}
.badge-disputed{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.badge-cancelled{background:rgba(95,156,145,.1);color:var(--muted);border:1px solid rgba(95,156,145,.15)}
.badge-buyer{background:rgba(59,130,246,.12);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.badge-seller{background:rgba(5,150,105,.12);color:var(--purple);border:1px solid rgba(5,150,105,.2)}
.badge-admin{background:rgba(245,158,11,.12);color:#b45309;border:1px solid rgba(245,158,11,.2)}
.badge-user{background:rgba(13,148,136,.1);color:var(--pink);border:1px solid rgba(13,148,136,.18)}

/* ══ TABLE ══ */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{background:var(--bg)}
th{padding:10px 14px;text-align:left;font-size:10px;font-weight:800;color:var(--muted);
  text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border2);white-space:nowrap}
td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--border2);color:var(--text2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg)}
.td-id{font-family:monospace;color:var(--muted);font-size:12px}

/* ══ MOBILE DEAL CARDS ══ */
.deal-card-mobile{background:var(--card);border:1px solid var(--border2);border-radius:16px;
  padding:14px;margin-bottom:10px;transition:all .2s;box-shadow:var(--shadow-card)}
.deal-card-mobile:hover{border-color:rgba(13,148,136,.25);box-shadow:var(--shadow)}
.deal-card-mobile-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.deal-card-mobile-title{font-size:14px;font-weight:800;color:var(--text)}
.deal-card-mobile-code{font-size:10px;color:var(--muted);font-family:monospace;margin-top:2px}
.deal-card-mobile-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border2)}
.deal-card-mobile-amount{font-size:17px;font-weight:900;color:var(--text)}
.deal-card-mobile-meta{font-size:12px;color:var(--muted)}

/* ══ DEAL PROGRESS ══ */
.deal-progress{display:flex;align-items:center;overflow-x:auto;padding:4px 0 8px}
.progress-step{display:flex;flex-direction:column;align-items:center;flex:1;min-width:64px}
.progress-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;z-index:1;transition:all .3s}
.progress-dot.done{background:linear-gradient(135deg,var(--green),#059669);color:#fff;box-shadow:0 3px 10px rgba(16,185,129,.35)}
.progress-dot.active{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;box-shadow:0 3px 12px rgba(13,148,136,.4)}
.progress-dot.idle{background:var(--bg3);color:var(--muted);border:2px dashed var(--border)}
.progress-label{font-size:9px;font-weight:700;color:var(--muted);text-align:center;margin-top:6px;text-transform:uppercase;letter-spacing:.03em}
.progress-step.done .progress-label,.progress-step.active .progress-label{color:var(--text)}
.progress-line{flex:1;height:2px;background:var(--bg3);margin:0 -1px;position:relative;top:-12px;transition:background .4s}
.progress-line.done{background:var(--green)}

/* ══ AUTH PAGES ══ */
.auth-page{min-height:100vh;
  background:linear-gradient(160deg,#03201f,#042f2e,#0f3d3a);
  display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:24px;padding:38px 32px;width:100%;max-width:420px;
  backdrop-filter:blur(20px);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:26px;text-decoration:none}
.auth-logo .logo-wrap{width:40px;height:40px;background:linear-gradient(135deg,var(--pink),var(--purple));
  border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 4px 14px rgba(13,148,136,.4)}
.auth-title{font-size:22px;font-weight:900;margin-bottom:4px;color:#fff}
.auth-sub{color:rgba(255,255,255,.45);font-size:13px;margin-bottom:24px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.auth-footer{text-align:center;margin-top:18px;font-size:13px;color:rgba(255,255,255,.35)}
.auth-footer a{color:var(--pink);font-weight:800}
.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.1)}
.auth-divider span{font-size:11px;font-weight:700;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.06em}

/* Auth inputs dark style */
.auth-page .form-control{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1);color:#fff}
.auth-page .form-control:focus{border-color:var(--pink);background:rgba(255,255,255,.1);box-shadow:0 0 0 3px rgba(13,148,136,.15)}
.auth-page .form-control::placeholder{color:rgba(255,255,255,.25)}
.auth-page .form-group label{color:rgba(255,255,255,.45)}
.auth-page .btn-primary{box-shadow:0 6px 22px rgba(13,148,136,.4)}
.auth-page .btn-secondary{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.12)}
.auth-page .btn-secondary:hover{background:rgba(255,255,255,.14);color:#fff}

/* ══ DROPDOWN ══ */
.dropdown{position:relative}
.dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-sm);box-shadow:0 12px 40px rgba(0,0,0,.15);
  min-width:210px;z-index:400;display:none;animation:dropIn .2s ease}
.dropdown-menu.show{display:block}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 15px;
  font-size:13px;color:var(--text2);transition:all .12s;text-decoration:none;cursor:pointer;font-weight:600}
.dropdown-item:hover{background:var(--pink4);color:var(--pink);opacity:1}
.dropdown-item.danger:hover{color:var(--red);background:rgba(239,68,68,.06)}
.dropdown-divider{height:1px;background:var(--border2);margin:4px 0}

/* ══ USER AVATAR ══ */
.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--pink),var(--purple));
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(13,148,136,.3)}

/* ══ TIMELINE ══ */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:'';position:absolute;left:7px;top:6px;bottom:0;width:1.5px;background:linear-gradient(180deg,var(--pink),rgba(13,148,136,.05))}
.timeline-item{position:relative;margin-bottom:18px}
.timeline-dot{position:absolute;left:-19px;top:3px;width:13px;height:13px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  border:2px solid var(--card);box-shadow:0 0 0 2px rgba(13,148,136,.2)}
.timeline-date{font-size:10px;color:var(--muted);font-weight:700;margin-bottom:2px;text-transform:uppercase;letter-spacing:.04em}
.timeline-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.timeline-note{font-size:12px;color:var(--muted)}

/* ══ WALLET HERO ══ */
.wallet-hero{background:linear-gradient(135deg,var(--purple-deep),var(--purple-mid),var(--purple));
  border-radius:20px;padding:24px;color:#fff;position:relative;overflow:hidden;
  box-shadow:var(--shadow-dark)}
.wallet-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:180px;height:180px;border-radius:50%;background:rgba(20,184,166,.2)}
.wallet-hero::after{content:'';position:absolute;bottom:-35px;left:-35px;width:130px;height:130px;border-radius:50%;background:rgba(13,148,136,.12)}

/* ══ FEE BOX ══ */
.fee-box{background:rgba(13,148,136,.06);border:1.5px solid rgba(13,148,136,.15);border-radius:var(--r-sm);padding:14px 16px;margin:12px 0}
.fee-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text2);margin-bottom:6px}
.fee-row:last-child{margin-bottom:0;font-weight:800;font-size:14px;color:var(--pink);border-top:1px dashed rgba(13,148,136,.15);padding-top:8px;margin-top:6px}

/* ══ REFERRAL ══ */
.referral-card{background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(59,130,246,.06));border:1.5px solid rgba(16,185,129,.2);border-radius:var(--r);padding:20px}
.referral-code{background:var(--bg);border:2px dashed rgba(13,148,136,.3);border-radius:var(--r-sm);padding:14px;font-family:monospace;font-size:20px;font-weight:800;letter-spacing:3px;color:var(--pink);text-align:center;cursor:pointer;transition:all .18s;user-select:all}
.referral-code:hover{background:var(--pink4);border-color:var(--pink)}

/* ══ EMPTY STATE ══ */
.empty-state{text-align:center;padding:52px 24px}
.empty-icon{font-size:44px;margin-bottom:14px;display:block;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.empty-state h3{font-size:17px;font-weight:800;color:var(--text);margin-bottom:8px}
.empty-state p{color:var(--muted);font-size:14px}

/* ══ TOAST ══ */
#toast-container{position:fixed;bottom:80px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:12px 16px;font-size:13px;color:var(--text);max-width:300px;
  box-shadow:var(--shadow);animation:slideUp .3s ease;font-weight:600}
@keyframes slideUp{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}

/* ══ NOTIF BADGE ══ */
.notif-badge{position:absolute;top:-3px;right:-3px;background:var(--red);color:#fff;
  font-size:9px;font-weight:800;width:16px;height:16px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(239,68,68,.4)}

/* ══ PAGE TITLES ══ */
.page-title{font-size:22px;font-weight:900;color:var(--text);margin-bottom:4px;letter-spacing:-.01em}
.page-sub{color:var(--muted);font-size:14px;font-weight:600}

/* ══ ICON BUTTONS (home page) ══ */
.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.icon-btn{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;text-decoration:none}
.icon-box{width:58px;height:58px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .2s;box-shadow:0 4px 14px rgba(0,0,0,.12)}
.icon-btn:hover .icon-box{transform:translateY(-3px) scale(1.06)}
.icon-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--text2);text-align:center}

/* ══ FEATURE CARDS ══ */
.feat-card-colored{border-radius:var(--r);padding:16px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}
.feat-card-colored:hover{transform:translateX(4px)}
.feat-card-colored .feat-icon-big{width:44px;height:44px;border-radius:14px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:22px}
.feat-card-colored .feat-title{font-size:15px;font-weight:800;color:#fff}
.feat-card-colored .feat-sub{font-size:12px;color:rgba(255,255,255,.7)}
.feat-card-colored .feat-arrow{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;flex-shrink:0}

/* ══ ANIMATIONS ══ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.animate-pulse{animation:pulse 2s infinite}
.fade-in{animation:fadeIn .4s ease forwards}

/* ══ UTILITIES ══ */
.dur-btn{padding:7px 13px;border-radius:var(--r-sm);font-size:12px;font-weight:700;
  cursor:pointer;border:1.5px solid var(--border);background:var(--card);color:var(--muted);transition:all .15s;font-family:var(--font)}
.dur-btn:hover,.dur-btn.active{border-color:var(--pink);color:var(--pink);background:var(--pink4)}
.text-pink{color:var(--pink)}.text-green{color:var(--green)}.text-muted{color:var(--muted)}
.fw-800{font-weight:800}.fw-700{font-weight:700}

/* ══ RESPONSIVE ══ */
@media(max-width:768px){
  body{padding-bottom:var(--bottom-h)}
  .navbar{display:none}
  .mobile-topbar{display:flex}
  .sidebar{display:none}
  .bottom-nav{display:flex}
  .main-content{margin-left:0;padding:16px;padding-top:calc(var(--nav-h) + 16px)}
  .layout{padding-top:0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-card{padding:14px 12px}
  .stat-value{font-size:18px}
  .hide-mobile{display:none!important}
  .show-mobile{display:block!important}
  th,td{padding:8px 10px;font-size:12px}
  .auth-card{padding:28px 20px;border-radius:20px}
  #toast-container{bottom:calc(var(--bottom-h) + 12px);right:10px;left:10px}
  .toast{max-width:100%}
  .page-title{font-size:18px}

  /* Tables: scroll horizontally instead of squishing/breaking layout */
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Sidebar / two-column dense layouts: stack to one column */
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns:300px 1fr"],
  [style*="grid-template-columns:220px 1fr"],
  [style*="grid-template-columns:160px 1fr"],
  [style*="grid-template-columns:1fr 300px"],
  [style*="grid-template-columns:1fr 320px"],
  [style*="grid-template-columns:1fr 360px"],
  [style*="grid-template-columns:1fr auto"]{
    grid-template-columns:1fr!important;
  }

  /* Fixed-width search/filter inputs: go full width so they don't overflow */
  input[style*="width:240px"],
  input[style*="width:200px"],
  input[style*="width:380px"],
  input[style*="width:300px"],
  input[style*="width:290px"],
  select[style*="width:240px"],
  select[style*="width:200px"]{
    width:100%!important;
  }

  /* Forms that put a search box + button side by side: let them wrap */
  form[style*="display:flex"]{flex-wrap:wrap}

  /* Modal: tighter padding on small screens */
  #proof-modal-overlay{padding:10px}
  #proof-modal-body{padding:16px!important}

  /* Card grids inside cards (evidence panels etc.) lose their border divider on mobile since they're now stacked */
  .card [style*="border-right:1px solid"]{border-right:none!important;border-bottom:1px solid #f1f5f9}
}
@media(max-width:380px){
  .dx-grid{gap:14px 4px}
  .stat-value{font-size:16px}
  .btn{padding:8px 12px;font-size:12.5px}
}
@media(min-width:769px){
  .show-mobile{display:none!important}
  .mobile-topbar{display:none!important}
  .bottom-nav{display:none!important}
}

/* ══ ICON WRAPPER SYSTEM ══ */
.ic{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:0}
.ic svg{display:block}
.icon-circle{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-square{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-square-sm{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-box{width:58px;height:58px;border-radius:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;box-shadow:0 4px 14px rgba(0,0,0,.12)}
.icon-btn:hover .icon-box{transform:translateY(-3px) scale(1.06)}
.badge-ic{display:inline-flex;align-items:center;gap:5px}
.badge-ic .ic svg{width:12px;height:12px}
.bn-icon-wrap{display:flex;align-items:center;justify-content:center;height:22px}

/* ══ APP-STORE QUALITY ENHANCEMENTS (Royal pink/purple kept) ══ */

/* Stat card with side icon (like reference screenshots) */
.stat-row-card{background:var(--card);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow-card);display:flex;align-items:center;justify-content:space-between}
.stat-row-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* Tab bar (Overview / Chat / Timeline style) */
.tab-bar{display:flex;border-bottom:1.5px solid var(--border2);margin-bottom:18px;gap:4px}
.tab-bar-item{flex:1;text-align:center;padding:12px 8px;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .2s;text-decoration:none}
.tab-bar-item.active{color:var(--pink);border-bottom-color:var(--pink)}

/* Pill filter row (All / Active / Completed) */
.pill-filters{display:flex;gap:8px;margin-bottom:18px;overflow-x:auto;padding-bottom:2px}
.pill-filter{padding:8px 18px;border-radius:99px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:var(--card);color:var(--text2);white-space:nowrap;transition:all .18s;text-decoration:none}
.pill-filter.active{background:var(--pink4);border-color:var(--pink);color:var(--pink)}

/* Deal progress dots (Created -> Escrow -> Delivered -> Done) */
.progress-dots-row{display:flex;align-items:center;background:var(--card);border-radius:16px;padding:20px 16px;box-shadow:var(--shadow-card);margin-bottom:16px}
.pd-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.pd-dot{width:14px;height:14px;border-radius:50%;background:var(--bg3);border:2px solid var(--bg3);z-index:1;transition:all .3s}
.pd-dot.done{background:var(--pink);border-color:var(--pink)}
.pd-dot.active{background:var(--pink);border-color:var(--pink);box-shadow:0 0 0 4px rgba(13,148,136,.18);width:16px;height:16px}
.pd-label{font-size:10px;font-weight:700;color:var(--muted);margin-top:8px;text-transform:uppercase;letter-spacing:.03em}
.pd-step.done .pd-label,.pd-step.active .pd-label{color:var(--pink)}
.pd-line{position:absolute;top:6px;left:50%;width:100%;height:2px;background:var(--bg3);z-index:0}
.pd-line.done{background:var(--pink)}
.pd-step:first-child .pd-line{display:none}

/* Detail row list (Role / Seller / Amount etc) */
.detail-list{background:var(--card);border-radius:16px;padding:4px 18px;box-shadow:var(--shadow-card)}
.detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--border2);gap:16px}
.detail-row:last-child{border-bottom:none}
.detail-row-key{font-size:13px;color:var(--muted);font-weight:600;flex-shrink:0}
.detail-row-val{font-size:13px;color:var(--text);font-weight:700;text-align:right}

/* Payment method row */
.payment-method-list{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card)}
.payment-method-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--border2);cursor:pointer;transition:background .15s}
.payment-method-row:last-child{border-bottom:none}
.payment-method-row:hover{background:var(--pink4)}
.pm-icon{width:42px;height:42px;border-radius:13px;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pm-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}
.pm-sub{font-size:11px;color:var(--muted);font-weight:600}

/* Fee breakdown card */
.fee-breakdown-card{background:var(--card);border-radius:16px;padding:18px;box-shadow:var(--shadow-card)}
.fee-breakdown-row{display:flex;justify-content:space-between;padding:9px 0;font-size:13px;color:var(--text2);border-bottom:1px dashed var(--border2)}
.fee-breakdown-row:last-child{border-bottom:none;font-weight:800;font-size:15px;color:var(--green);padding-top:13px}

/* Section label (REFERRAL / SECURITY style uppercase) */
.section-label-sm{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;margin-top:20px}
.section-label-sm:first-child{margin-top:0}

/* Settings row list (Edit Profile / Notification Settings) */
.settings-list{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card)}
.settings-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--border2);cursor:pointer;text-decoration:none;transition:background .15s}
.settings-row:last-child{border-bottom:none}
.settings-row:hover{background:var(--pink4)}
.settings-row-icon{width:38px;height:38px;border-radius:11px;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text2)}
.settings-row-title{font-size:14px;font-weight:700;color:var(--text);flex:1}
.settings-row-meta{font-size:12px;color:var(--muted);font-weight:600}
.settings-row.danger .settings-row-icon{background:rgba(239,68,68,.08);color:var(--red)}
.settings-row.danger .settings-row-title{color:var(--red)}

/* Notification list row */
.notif-row{display:flex;gap:14px;padding:16px 4px;border-bottom:1px solid var(--border2)}
.notif-row:last-child{border-bottom:none}
.notif-row-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-row-title{font-size:14px;font-weight:800;color:var(--text);margin-bottom:3px}
.notif-row-msg{font-size:12.5px;color:var(--muted);line-height:1.5}
.notif-row-time{font-size:11px;color:var(--muted);font-weight:600;flex-shrink:0}
.notif-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--pink);flex-shrink:0;margin-top:6px}

/* Banner alert (KYC verify style) */
.banner-alert{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;margin-bottom:18px}
.banner-alert.warning{background:rgba(245,158,11,.08);border:1.5px solid rgba(245,158,11,.25)}
.banner-alert-icon{width:36px;height:36px;border-radius:10px;background:rgba(245,158,11,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#b45309}
.banner-alert-title{font-size:13px;font-weight:800;color:#b45309;margin-bottom:1px}
.banner-alert-sub{font-size:12px;color:#b45309;opacity:.85}

/* Referral card (HAMZA2IO4 style) */
.referral-display-card{background:var(--card);border-radius:16px;padding:18px;box-shadow:var(--shadow-card)}
.referral-code-big{font-size:24px;font-weight:900;color:var(--text);letter-spacing:.04em;margin-bottom:4px}
.referral-code-meta{font-size:12px;color:var(--muted);font-weight:600}
.referral-tip{display:flex;align-items:center;gap:9px;background:var(--bg);border-radius:11px;padding:11px 14px;margin-top:14px;font-size:12.5px;color:var(--text2);font-weight:600}
