/* ============================================================
   يمن توب — نظام التصميم المشترك (app.css)
   نفس هوية الصفحة الرئيسية: داكن أولاً + تبديل للوضع الفاتح
   تُستخدم في صفحات: الدخول، التسجيل، حساب المستخدم
   ============================================================ */

:root{
  --ink:#0B0916; --navy:#160733; --navy-2:#1E0E44; --navy-3:#2A1559;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.15);
  --orange:#FE7A39; --orange-2:#FF9D5E; --orange-deep:#E85F1F;
  --royal:#5570E4; --royal-2:#7E95F4; --royal-deep:#3752AD;
  --gold:#F6C44E; --text:#F4F0FB; --muted:#A99FC6; --good:#37D6A0;
  --warn:#F6C44E; --bad:#FF6B6B; --info:#7E95F4;
  --card:rgba(255,255,255,.035); --card-2:rgba(255,255,255,.06);
  --shadow:0 24px 60px -18px rgba(0,0,0,.7);
  --r:18px; --r-sm:13px; --r-lg:26px;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
html[data-theme="light"]{
  --ink:#F2EFFA; --navy:#FFFFFF; --navy-2:#FBF9FF; --navy-3:#F2EDFF;
  --line:rgba(24,5,60,.10); --line-2:rgba(24,5,60,.18);
  --text:#1A0B3A; --muted:#6A5C8E; --card:rgba(24,5,60,.025); --card-2:rgba(24,5,60,.05);
  --shadow:0 24px 50px -22px rgba(40,12,90,.35);
}

/* ============================ BASE ============================ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Cairo',system-ui,sans-serif;background:var(--ink);color:var(--text);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh;
  display:flex;flex-direction:column;transition:background .35s,color .35s;
}
h1,h2,h3,.dpl{font-family:'Tajawal','Cairo',sans-serif;font-weight:800;line-height:1.18;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
img{display:block;max-width:100%}
.num{font-family:var(--mono);font-feature-settings:"tnum";letter-spacing:.02em}
.wrap{width:100%;max-width:1200px;margin-inline:auto;padding-inline:20px}
:focus-visible{outline:2.5px solid var(--orange);outline-offset:3px;border-radius:8px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.muted{color:var(--muted)}
.text-good{color:var(--good)} .text-bad{color:var(--bad)} .text-gold{color:var(--gold)}

/* ambient page glows (identical to homepage) */
body::before,body::after{content:"";position:fixed;inset:auto;z-index:0;pointer-events:none;
  width:46vw;height:46vw;border-radius:50%;filter:blur(120px);opacity:.5}
body::before{top:-12vw;inset-inline-start:-8vw;background:radial-gradient(circle,var(--orange),transparent 65%)}
body::after{bottom:-16vw;inset-inline-end:-10vw;background:radial-gradient(circle,var(--royal),transparent 65%)}
html[data-theme="light"] body::before,html[data-theme="light"] body::after{opacity:.18}
main{position:relative;z-index:1;flex:1}

/* ============================ HEADER ============================ */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(16px);
  background:color-mix(in srgb,var(--ink) 78%,transparent);
  border-bottom:1px solid var(--line)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){
  .site-header{background:rgba(11,9,22,.86)}
  html[data-theme="light"] .site-header{background:rgba(242,239,250,.86)}
}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:70px}
.brand{display:flex;align-items:center;gap:11px;font-weight:900}
.brand img{width:42px;height:42px;border-radius:11px;object-fit:cover;box-shadow:0 6px 16px rgba(254,122,57,.3)}
.brand .bt{font-family:'Tajawal';font-size:19px;line-height:1.05;display:flex;flex-direction:column}
.brand .bt small{font-weight:500;font-size:11px;color:var(--muted);letter-spacing:.02em}
.nav{display:flex;align-items:center;gap:6px;margin-inline-start:8px}
.nav a{padding:9px 14px;border-radius:11px;font-size:14.5px;font-weight:600;color:var(--muted);transition:.2s}
.nav a:hover{color:var(--text);background:var(--card)}
.nav a.active{color:var(--text);background:var(--card-2)}
.h-actions{margin-inline-start:auto;display:flex;align-items:center;gap:9px}
.icon-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--card);border:1px solid var(--line);color:var(--text);transition:.2s;position:relative}
.icon-btn:hover{background:var(--card-2);border-color:var(--line-2)}
.cart-badge{position:absolute;top:-6px;inset-inline-end:-6px;min-width:19px;height:19px;padding:0 5px;
  border-radius:10px;background:var(--orange);color:#fff;font-size:11px;font-weight:800;
  display:grid;place-items:center;border:2px solid var(--ink)}
.user-chip{display:flex;align-items:center;gap:9px;padding:6px 12px 6px 6px;border-radius:30px;
  background:var(--card);border:1px solid var(--line)}
.user-chip .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--royal-deep));
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px}
.user-chip span{font-size:13.5px;font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.burger{display:none}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 19px;border-radius:13px;
  font-weight:800;font-size:15px;transition:.2s;white-space:nowrap;border:1px solid transparent}
.btn svg{width:18px;height:18px}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange-deep));color:#fff;
  box-shadow:0 10px 26px -8px rgba(232,95,31,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(232,95,31,.7)}
.btn-royal{background:linear-gradient(135deg,var(--royal),var(--royal-deep));color:#fff;
  box-shadow:0 10px 26px -8px rgba(55,82,173,.55)}
.btn-royal:hover{transform:translateY(-2px)}
.btn-ghost{background:var(--card);border-color:var(--line);color:var(--text)}
.btn-ghost:hover{background:var(--card-2);border-color:var(--line-2)}
.btn-outline{background:transparent;border-color:var(--line-2);color:var(--text)}
.btn-outline:hover{background:var(--card)}
.btn-danger{background:transparent;border-color:color-mix(in srgb,var(--bad) 45%,transparent);color:var(--bad)}
.btn-danger:hover{background:color-mix(in srgb,var(--bad) 12%,transparent)}
.btn-block{width:100%}
.btn-lg{padding:14px 24px;font-size:16px;border-radius:14px}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}

/* ============================ FORMS ============================ */
.field{margin-bottom:17px}
.field > label{display:block;font-size:13.5px;font-weight:700;margin-bottom:8px;color:var(--text)}
.field .req{color:var(--orange)}
.control{position:relative;display:flex;align-items:center}
.control .lead{position:absolute;inset-inline-start:14px;display:grid;place-items:center;color:var(--muted);pointer-events:none}
.control .lead svg{width:19px;height:19px}
.input,textarea.input,select.input{
  width:100%;padding:13px 15px;border-radius:var(--r-sm);background:var(--card);
  border:1.5px solid var(--line);color:var(--text);font-size:15px;transition:.18s;line-height:1.5}
.control.has-lead .input{padding-inline-start:44px}
textarea.input{resize:vertical;min-height:96px}
.input::placeholder{color:var(--muted);opacity:.85}
.input:focus{outline:none;border-color:var(--orange);background:var(--card-2);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--orange) 16%,transparent)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){
  .input:focus{box-shadow:0 0 0 4px rgba(254,122,57,.16)}
}
.input.is-invalid{border-color:var(--bad)}
.input.is-invalid:focus{box-shadow:0 0 0 4px rgba(255,107,107,.16)}
.pw-toggle{position:absolute;inset-inline-end:10px;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted)}
.pw-toggle:hover{color:var(--text);background:var(--card-2)}
.field-error{display:block;color:var(--bad);font-size:12.5px;font-weight:600;margin-top:7px}
.field-help{display:block;color:var(--muted);font-size:12.5px;margin-top:7px}
/* phone field with country code */
.phone-group{display:flex;gap:9px}
.phone-cc{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:0 14px;border-radius:var(--r-sm);
  background:var(--card-2);border:1.5px solid var(--line);font-weight:800;font-size:14px;color:var(--muted)}
.phone-group .control{flex:1}
/* checkbox */
.check{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--muted);cursor:pointer;user-select:none}
.check input{appearance:none;width:20px;height:20px;flex:0 0 auto;margin-top:1px;border-radius:6px;
  border:1.5px solid var(--line-2);background:var(--card);display:grid;place-items:center;transition:.18s}
.check input:checked{background:var(--orange);border-color:var(--orange)}
.check input:checked::after{content:"✓";color:#fff;font-size:13px;font-weight:900}
.check a{color:var(--orange-2);font-weight:700}

/* ============================ ALERTS ============================ */
.alert{display:flex;gap:11px;align-items:flex-start;padding:13px 15px;border-radius:var(--r-sm);
  font-size:14px;font-weight:600;margin-bottom:18px;border:1px solid var(--line)}
.alert svg{width:20px;height:20px;flex:0 0 auto;margin-top:1px}
.alert ul{margin:0;padding-inline-start:18px;font-weight:500}
.alert-success{background:color-mix(in srgb,var(--good) 13%,transparent);border-color:color-mix(in srgb,var(--good) 35%,transparent);color:var(--good)}
.alert-error{background:color-mix(in srgb,var(--bad) 12%,transparent);border-color:color-mix(in srgb,var(--bad) 35%,transparent);color:var(--bad)}
.alert-info{background:color-mix(in srgb,var(--info) 12%,transparent);border-color:color-mix(in srgb,var(--info) 32%,transparent);color:var(--royal-2)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){
  .alert-success{background:rgba(55,214,160,.13);border-color:rgba(55,214,160,.35)}
  .alert-error{background:rgba(255,107,107,.12);border-color:rgba(255,107,107,.35)}
  .alert-info{background:rgba(126,149,244,.12);border-color:rgba(126,149,244,.32)}
}

/* ============================ AUTH SHELL ============================ */
.auth{display:grid;place-items:center;padding:46px 20px 70px}
.auth-card{width:100%;max-width:980px;display:grid;grid-template-columns:1fr 1fr;
  background:var(--navy);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.auth-aside{position:relative;padding:44px 38px;color:#fff;overflow:hidden;
  background:linear-gradient(150deg,var(--royal-deep),var(--navy-3) 55%,var(--orange-deep))}
.auth-aside::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0%,rgba(255,255,255,.16),transparent 60%)}
.auth-aside .ab-inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column}
.auth-aside .brand .bt,.auth-aside .brand .bt small{color:#fff}
.auth-aside h2{font-size:28px;margin:auto 0 14px}
.auth-aside p{color:rgba(255,255,255,.85);font-size:15px;max-width:330px}
.auth-aside .feats{margin-top:26px;display:flex;flex-direction:column;gap:13px}
.auth-aside .feat{display:flex;align-items:center;gap:11px;font-size:14px;font-weight:600}
.auth-aside .feat .ic{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.16);
  display:grid;place-items:center;flex:0 0 auto}
.auth-aside .feat svg{width:18px;height:18px}
.auth-form{padding:44px 40px}
.auth-form .ttl{font-size:25px;margin-bottom:6px}
.auth-form .sub{color:var(--muted);font-size:14.5px;margin-bottom:26px}
.auth-form .alt{margin-top:22px;text-align:center;font-size:14px;color:var(--muted)}
.auth-form .alt a{color:var(--orange-2);font-weight:800}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.form-aux{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:-4px 0 20px}
.form-aux a{font-size:13px;color:var(--orange-2);font-weight:700}
.divider{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:12.5px;margin:22px 0}
.divider::before,.divider::after{content:"";height:1px;flex:1;background:var(--line)}

/* ============================ ACCOUNT ============================ */
.account{padding:34px 20px 70px}
.account-grid{max-width:1140px;margin-inline:auto;display:grid;grid-template-columns:268px 1fr;gap:24px;align-items:start}
.account-side{position:sticky;top:90px;background:var(--navy);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.side-head{padding:22px 20px;display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,color-mix(in srgb,var(--royal-deep) 30%,transparent),transparent)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){.side-head{background:rgba(55,82,173,.16)}}
.side-head .av{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--orange),var(--royal-deep));
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:18px;flex:0 0 auto}
.side-head .nm{font-weight:800;font-size:15.5px;line-height:1.2}
.side-head .ph{color:var(--muted);font-size:12.5px;margin-top:3px}
.side-nav{padding:10px}
.side-nav a{display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:12px;
  font-size:14.5px;font-weight:600;color:var(--muted);transition:.18s;margin-bottom:2px}
.side-nav a svg{width:19px;height:19px;flex:0 0 auto}
.side-nav a:hover{background:var(--card);color:var(--text)}
.side-nav a.active{background:linear-gradient(135deg,var(--orange),var(--orange-deep));color:#fff;
  box-shadow:0 8px 20px -8px rgba(232,95,31,.55)}
.side-nav .logout{color:var(--bad)}
.side-nav .logout:hover{background:color-mix(in srgb,var(--bad) 12%,transparent)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){.side-nav .logout:hover{background:rgba(255,107,107,.12)}}

.account-main{min-width:0}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{font-size:23px}
.page-head .crumb{color:var(--muted);font-size:13px;margin-top:4px}

.acard{background:var(--navy);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.acard + .acard{margin-top:20px}
.acard-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.acard-head h3{font-size:16.5px}
.acard-head .tip{color:var(--muted);font-size:12.5px}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.stat{background:var(--navy);border:1px solid var(--line);border-radius:var(--r);padding:20px;position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;inset-inline-end:-26px;top:-26px;width:96px;height:96px;border-radius:50%;
  background:radial-gradient(circle,var(--glow,var(--orange)),transparent 68%);opacity:.18}
.stat .lab{color:var(--muted);font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}
.stat .lab svg{width:17px;height:17px}
.stat .val{font-size:27px;font-weight:900;margin-top:10px;font-family:'Tajawal'}
.stat .val small{font-size:14px;font-weight:700;color:var(--muted);margin-inline-start:4px}
.stat.wallet{--glow:var(--gold)} .stat.orders{--glow:var(--royal)} .stat.done{--glow:var(--good)}

/* wallet hero */
.wallet-hero{border-radius:var(--r-lg);padding:30px;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--royal-deep),var(--navy-3) 60%,var(--orange-deep))}
.wallet-hero::after{content:"";position:absolute;inset-inline-end:-40px;bottom:-50px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(246,196,78,.5),transparent 65%)}
.wallet-hero .lab{font-size:14px;opacity:.85;position:relative;z-index:1}
.wallet-hero .bal{font-size:42px;font-weight:900;font-family:'Tajawal';margin-top:6px;position:relative;z-index:1}
.wallet-hero .bal small{font-size:18px;opacity:.8;margin-inline-start:6px}
.wallet-hero .acts{margin-top:22px;display:flex;gap:10px;position:relative;z-index:1;flex-wrap:wrap}
.wallet-hero .acts .btn{background:rgba(255,255,255,.16);color:#fff;backdrop-filter:blur(6px)}
.wallet-hero .acts .btn:hover{background:rgba(255,255,255,.26)}

/* tables */
.table-wrap{overflow-x:auto;border-radius:var(--r-sm);border:1px solid var(--line)}
table.table{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
table.table th{text-align:start;padding:14px 16px;background:var(--card-2);color:var(--muted);
  font-weight:700;font-size:12.5px;white-space:nowrap}
table.table td{padding:14px 16px;border-top:1px solid var(--line)}
table.table tr:hover td{background:var(--card)}
.t-strong{font-weight:800}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:30px;
  font-size:12px;font-weight:800;white-space:nowrap}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.pending{color:var(--warn);background:color-mix(in srgb,var(--warn) 14%,transparent)}
.badge.processing{color:var(--royal-2);background:color-mix(in srgb,var(--royal-2) 14%,transparent)}
.badge.completed{color:var(--good);background:color-mix(in srgb,var(--good) 14%,transparent)}
.badge.cancelled{color:var(--bad);background:color-mix(in srgb,var(--bad) 14%,transparent)}
.badge.refunded{color:var(--muted);background:var(--card-2)}
.badge.paid{color:var(--good);background:color-mix(in srgb,var(--good) 14%,transparent)}
.badge.unpaid{color:var(--warn);background:color-mix(in srgb,var(--warn) 14%,transparent)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){
  .badge.pending,.badge.unpaid{background:rgba(246,196,78,.14)}
  .badge.processing{background:rgba(126,149,244,.14)}
  .badge.completed,.badge.paid{background:rgba(55,214,160,.14)}
  .badge.cancelled{background:rgba(255,107,107,.14)}
}
/* wallet tx direction */
.tx-in{color:var(--good);font-weight:800} .tx-out{color:var(--bad);font-weight:800}

/* empty state */
.empty{text-align:center;padding:46px 20px;color:var(--muted)}
.empty .ic{width:66px;height:66px;border-radius:20px;background:var(--card-2);display:grid;place-items:center;margin:0 auto 16px}
.empty .ic svg{width:30px;height:30px;color:var(--muted)}
.empty h4{color:var(--text);font-size:17px;margin-bottom:6px}
.empty p{font-size:14px;max-width:340px;margin:0 auto 18px}

/* two-column form rows */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}

/* ============================ FOOTER ============================ */
.site-footer{position:relative;z-index:1;margin-top:40px;border-top:1px solid var(--line);
  background:var(--navy);padding:42px 0 26px}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-footer .ab{color:var(--muted);font-size:14px;max-width:300px;margin-top:14px}
.site-footer h4{font-size:15px;font-family:'Tajawal';margin-bottom:15px}
.site-footer .lk{display:flex;flex-direction:column;gap:10px}
.site-footer .lk a{color:var(--muted);font-size:14px;transition:.18s}
.site-footer .lk a:hover{color:var(--orange-2)}
.pay-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.pay{padding:7px 12px;border-radius:10px;background:var(--card);border:1px solid var(--line);
  font-size:12.5px;font-weight:700;color:var(--muted)}
.foot-bottom{margin-top:30px;padding-top:20px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  color:var(--muted);font-size:13px}
.foot-bottom .tag{color:var(--orange-2);font-weight:800}

/* ============================ RESPONSIVE ============================ */
@media (max-width:880px){
  .account-grid{grid-template-columns:1fr}
  .account-side{position:static}
  .stat-grid{grid-template-columns:1fr 1fr}
  .auth-card{grid-template-columns:1fr;max-width:480px}
  .auth-aside{display:none}
  .site-footer .cols{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .nav{display:none}
  .burger{display:grid}
  .auth-row,.grid-2{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr}
  .auth-form,.auth-form .ttl{padding-inline:24px}
  .auth-form{padding:32px 24px}
  .site-footer .cols{grid-template-columns:1fr}
  .user-chip span{display:none}
}

/* respect reduced motion */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* toast */
.toast{position:fixed;inset-block-end:24px;inset-inline-start:50%;transform:translateX(50%) translateY(20px);
  background:var(--navy-3);border:1px solid var(--line-2);color:var(--text);padding:13px 20px;border-radius:13px;
  font-weight:700;font-size:14px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.3s;z-index:100}
.toast.show{opacity:1;transform:translateX(50%) translateY(0)}
