/* ==============================
   ESIMAX — Cleaned & Consolidated CSS
   ============================== */

/* ---------- Design tokens ---------- */
:root{
  /* base */

    /* text */
  --text-strong: #111111;
  --text-mid:    #333333;
  --text-disabled:#999999;
  --text-muted-3:#939393;

  /* links */
  --link-muted: #AAAAAA;
  --link-hover: #48525a;

  /* ui micro colors */
  --status-offline:#bbbbbb;
  --switch-track: #d7dbe3;
  --surface-100:  #fafafa;
  --surface-50:   #f9fafb;
  --border-eee:   #eeeeee;
  --alert-bg:     #fff0f0;
  --alert-border: #ffd4d4;
  --track-bg:     #eaf3f7;
  --focus-ring:   #0091AD33;

  /* shadows (rgba) */
  --shadow-chip:         rgba(183, 9, 76, 0.20);
  --shadow-chip-hover:   rgba(183, 9, 76, 0.28);
  --shadow-blue-soft:    rgba(136,198,231,.18);
  --shadow-blue-soft-h:  rgba(136,198,231,.24);
  --shadow-inset-1:      rgba(255,255,255,.60);
  --shadow-inset-1h:     rgba(255,255,255,.70);
  --shadow-black-06:     rgba(0,0,0,.06);
  --shadow-black-15:     rgba(0,0,0,.15);
  --shadow-black-25:     rgba(0,0,0,.25);
  --shadow-pink-1:       rgba(231,51,103,.25);
  --shadow-pink-1h:      rgba(231,51,103,.35);
  --shadow-cyan-1:       rgba(7,157,176,.25);
  --shadow-cyan-1h:      rgba(7,157,176,.35);

  /* common gradients */
  --brand-grad-h:    linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
  --brand-grad-v:    linear-gradient(180deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
  --brand-grad-h-3:  linear-gradient(90deg, var(--grad-pink-start), var(--grad-pink-end), var(--grad-cyan));
  --brand-border-grad: linear-gradient(180deg, var(--pkg-b1) 0%, var(--pkg-b2) 49%, var(--pkg-b3) 100%);
  --divider-grad:    linear-gradient(180deg, var(--divider-start) 0%, var(--divider-end) 100%);
  --bg: #ffffff;
  --text: #000000;
  --muted: #6B6B6B;
  --muted-2: #929292;

  /* hero */
  --hero-bg: #f0446a;
  --hero-text: #ffffff;

  /* tabs */
  --tabs-bg: #EDF2F4;
  --tabs-border: #E3E1E1;

  /* panels / lines */
  --soft: #F7F9FB;
  --line: #E3ECF2;
  --panel-border: #CFE1EE;
  --surface-border: #E6E6E6; /* common light border */
  --surface-muted: #E8E8E8;  /* input bg light */

  /* gradients (brand) */
  --grad-pink-start: #B7094C;
  --grad-pink-end:   #ED4C5C;
  --grad-cyan:       #0091AD;

  /* accents */
  --accent-pink:   #E73367;
  --accent-purple: #8A2BE2;
  --accent-cyan:   #079DB0;

  /* radius / borders */
  --pkg-radius: 15px;
  --pkg-border-w: 2px;

  /* package gradient stops (border) */
  --pkg-b1: #B7094C;
  --pkg-b2: #ED4C5C;
  --pkg-b3: #0091AD;

  /* progress */
  --progress-start:#1591ff;
  --progress-end:  #0b7cde;

  /* divider */
  --divider-start:#4f46e5;
  --divider-end:  #ec4899;

  /* misc */
  --glow-pink: rgba(255, 140, 180, 0.15);
  --bg-btn-gray:#DDDDDD;

  /* badges */
  --badge-green:#377E60;  --badge-green-bg:#D8F8E5;
  --badge-yellow:#7B7B06; --badge-yellow-bg:#FCF6C1;
  --badge-gray:#888888;   --badge-gray-bg:#f1f1f1;
  --badge-red:#690735;    --badge-red-bg:#facacf;

  /* password-inline (unified) */
  --g1: var(--grad-pink-start);
  --g2: var(--grad-pink-end);
  --g3: var(--grad-cyan);
  --pill-bg:#EDEDEF;
  --pill-text:#111111;
  --pill-muted:#8A8A90;
  --circle:#E2E2E7;
  --line-alt:#E9E9EE;

  /* sizing tokens */
  --chip-radius: 999px;
  --btn-radius: 16px;
  --card-radius: 21px;
}

/* ---------- Page  ---------- */
.esimax-page {
  font-family: "coherentic", Sans-serif;
  direction: rtl;
}

body .esimax-page *:not(i):not(input):not(textarea):not(select) {
  font-family: "coherentic", Sans-serif;
}

.esimax-app h2, 
.esimax-app h3, 
.esimax-app h4,
.esimax-app h5,
.esimax-app p,
.esimax-app span:not(.date-col span, span.val.chip),
.esimax-app a,
.esimax-app button{
    font-family: "coherentic", Sans-serif;
}
.total {
    font-family: "coherentic", Sans-serif;
    font-weight: 500;
}

.esimax-page  input:focus::-webkit-input-placeholder { opacity: 0; }
.esimax-page  input:focus::-moz-placeholder { opacity: 0; }
.esimax-page  input:focus:-ms-input-placeholder { opacity: 0; }
.esimax-page  input:focus::placeholder { opacity: 0; }
.esimax-page  input:focus::placeholder { color: transparent; }

.text-gradient {
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
}

/* ---------- Account chip (logged-in) ---------- */
.esimax-chip {
  min-width: 160px;
  display:inline-flex; align-items:center; gap:14px;
  padding: 10px 16px;
  background:var(--bg);
  border-radius: var(--chip-radius);
  text-decoration:none;
  border: 1px solid var(--surface-border);
  box-shadow: 0 0 20px 4px var(--shadow-chip) !important;
}
.esimax-chip:hover{ box-shadow: 0 14px 36px rgba(183, 9, 76, .28); }

.esimax-chip .chip-text{
  display:flex;gap:4px; flex-direction:column; align-items:flex-start; line-height:1.1;
}
.esimax-chip .chip-name{
  font-weight:400; font-size:clamp(10.45px, 1.05vw, 22px); color:var(--text);
}
.esimax-chip .chip-id{
  font-weight:500; font-size:clamp(9.5px, 0.78vw, 20px); color:var(--muted-2); letter-spacing:.3px;
}
.esimax-chip .chip-id .hash{ opacity:.9; }

/* Avatar with status dot */
.esimax-chip .chip-avatar{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:14px; flex:0 0 44px;
  background: linear-gradient(135deg, var(--grad-pink-start), var(--grad-pink-end));
  color:var(--bg); font-weight:500; position:relative;
}
.esimax-chip .chip-avatar .i{ line-height:1; }
.esimax-chip .chip-avatar .dot{
  position:absolute; bottom:-3px; right:-3px;
  width:14px; height:14px; border-radius:50%;
  border:2px solid var(--bg); background:#bbb;
}
.esimax-chip .chip-avatar .dot.is-on{ background:#4cd964; }

/* Guest header button (kept as link variant) */
a.esimax-header-btn.is-guest {
  background-color: transparent;
  font-family: "coherentic", Sans-serif;
  font-size: 0.9vw;
  font-weight: 400;
  background-image: linear-gradient(90deg, var(--grad-pink-start) 26%, var(--grad-pink-end) 100%);
  border-radius: 50px;
  padding: 17px 35px;
  color: var(--bg);
  transition: all .3s;
}
a.esimax-header-btn.is-guest:hover {
  background-image: linear-gradient(180deg, var(--grad-cyan) 0%, var(--grad-cyan) 100%);
}

/* ---------- Login Card ---------- */
.esimax-login-card {
  padding: 0 clamp(15px, 6.25vw, 160px) clamp(60px, 3.13vw, 80px);
  position: relative;
  margin: 5rem auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.5vw;
  width: clamp(350px, 878px, 34.3vw); 
  border-radius: var(--card-radius);
  background: var(--bg);
}
.esimax-login-card::before{
  content:"";
  position:absolute; inset:0; padding:3px;
  border-radius: inherit;
  background: linear-gradient(90.25deg, var(--grad-pink-start) 1.8%, var(--grad-pink-end) 49.31%, var(--grad-cyan) 99.32%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events:none;
}
.esimax-login-card form { width: 100%; }

.esimax-login-card__head {
  display: inline-block;
  min-width: 63%;
  padding: 16px 0;
  border-bottom-right-radius: 30px; border-bottom-left-radius: 30px;
  color: var(--bg);
  font-weight: 600;
  font-size: clamp(18px, 1.56vw, 40px);
  line-height: 1;
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 36.2%, var(--grad-cyan) 100%);
  text-align: center;
}

/* Login form */
.esi-btn.is-loading { opacity: .7; pointer-events: none; position: relative; }
.esi-btn.is-loading::after {
  content: '';
  position: absolute; right: 5px; top: 50%; width: 14px; height: 14px; margin-top: -7px;
  border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%;
  animation: esimax-spin .8s linear infinite;
}
.esi-btn.is-loading .title-icon {
  display: none;
}
@keyframes esimax-spin { to { transform: rotate(360deg); } }

.esimax-login-form .form-row { margin: 0 0 14px; }
.esimax-login-form  .form-row.esimax-submit-row {
    margin-bottom: 0;
}
.esimax-login-form label { display:block; font-size:14px; margin-bottom:6px; color: var(--text-mid); }
.esimax-login-form .input-text {
  width: 100%; height: clamp(40px, 3.13vw, 80px);
  border-radius: 12px; border: none; padding: 0 16px;
  background: var(--surface-muted); outline: none;
}
.esimax-login-form .input-text:focus { border-color: var(--grad-pink-start); }
.esimax-login-form input::placeholder{ opacity: 1; color: var(--text); }


button.esimax-toggle-pass {
  color: var(--text); border: none; padding: 0; outline: none; background: none;
  line-height: 1; display: flex; align-items: center; justify-content: center;
}
.esimax-password-row .esimax-password-field { position: relative; display: block; }
.esimax-toggle-pass {
  position: absolute; inset-inline-end: 12px; top: 50%; transform: translateY(-50%);
  width: 30px; height: 30px; border: 0; background: transparent; cursor: pointer; color: #333;
  display: flex; align-items: center; justify-content: center;
}
.esimax-toggle-pass:hover { color: var(--grad-pink-start); }
.esimax-toggle-pass svg { width: 24px; height: 24px; }
.esimax-toggle-pass .icon-eye { display: none; }
.esimax-toggle-pass .icon-eye-off { display: inline-block; }
.esimax-toggle-pass.is-visible .icon-eye { display: inline-block; }
.esimax-toggle-pass.is-visible .icon-eye-off { display: none; }

.esimax-bottom-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 2px;
}
.esimax-remember-row { display:flex; align-items:center; gap:10px; }
.esimax-remember-text{ font-size:14px; color:#333; }

.esimax-switch { position:relative; display:inline-block; width:48px; height:26px; }
.esimax-switch input { display:none; }
.esimax-slider {
  position:absolute; inset:0; border-radius:999px; background:#d7dbe3; transition:.2s; cursor:pointer;
}
.esimax-slider::before {
  content:""; position:absolute; height:20px; width:20px; right:3px; top:3px;
  background:var(--bg); border-radius:50%; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.25);
}
.esimax-switch input:checked + .esimax-slider { background:var(--grad-cyan); }
.esimax-switch input:checked + .esimax-slider::before { transform: translateX(-22px); }

.esimax-lost-pwd { margin: 0; }

.esimax-lost-pwd a {
  color: var(--text) !important; text-decoration: underline !important; text-underline-offset: 4px;
}
.esimax-lost-pwd a:hover { color:var(--grad-pink-start); }

.esimax-submit-row { margin-top: 18px; text-align:center; }
button.button.esimax-login-btn {
  margin-top: 60px; min-width: 270px; color: var(--bg);
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
  border-radius: 30px; font-size: 20px; font-weight: 400; line-height: 1.2;
  transition: all .3s; border:none;
}
button.button.esimax-login-btn:hover{
  background-image: linear-gradient(180deg, var(--grad-cyan) 0%, var(--grad-cyan) 100%);
  color:var(--bg);
}

/* ---------- Panels / Hero ---------- */
.esimax-panels .panel { display: none; }
.esimax-panels .panel.active { display: block; }
.panel { display: none; }
.panel.active { display: block; }

.esimax-hero {
  background: var(--hero-bg);
  color: var(--hero-text);
  padding: 20px;
  border-radius: 15px;
  margin-bottom: 16px;
}

/* ---------- Tabs ---------- */
.esimax-tabs {
  margin: clamp(16px,2.34vw,60px) auto;
  padding: clamp(16px, 1.17vw, 30px);
  width: max-content;
  display: flex; gap: 16px; justify-content: center; align-items: center;
  background: var(--tabs-bg);
  border: 1px solid var(--tabs-border);
  border-radius: 60px;
}
.tab-btn {
  padding: 0; display: flex; align-items: center; justify-content: center; gap: 8px;
  color: var(--text); background: none; border: none; cursor: pointer;line-height: 1;
}
.tab-btn span {
  color: var(--text); font-weight: 600; font-size: clamp(18px, 0.98vw, 25px);
}
.tab-icon {
  display: inline-block; width: clamp(28px,1.09vw, 28px); height: clamp(24px,1.09vw, 28px);
  background: var(--text);
  -webkit-mask-repeat: no-repeat; -webkit-mask-position: center; -webkit-mask-size: contain;
  mask-repeat: no-repeat; mask-position: center; mask-size: contain;
}
.tab-icon.home    { -webkit-mask-image: url('../icons/home.svg');    mask-image: url('../icons/home.svg'); }
.tab-icon.user    { -webkit-mask-image: url('../icons/user.svg');    mask-image: url('../icons/user.svg'); }
.tab-icon.receipt { -webkit-mask-image: url('../icons/payment.svg'); mask-image: url('../icons/payment.svg'); }
.tab-icon.gift    { -webkit-mask-image: url('../icons/gift.svg');    mask-image: url('../icons/gift.svg'); }

.tab-btn.active .tab-icon,
.tab-btn:hover .tab-icon {
  background: linear-gradient(180deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
}
/* Reset button focus/visited artifacts */
.tab-btn.active,
.tab-btn:hover,
.tab-btn:focus,
.tab-btn:visited,
.tab-btn:active,
.tab-btn:focus-visible { background: none; outline: none; }

.tab-btn.active span,
.tab-btn:hover span {
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.tab-divider {
  display: inline-block;
  width: 2px;
  min-width: 2px;
  height: 24px;
  background: linear-gradient(180deg, var(--divider-start) 0%, var(--divider-end) 100%);
  border-radius: 2px;
}

/* ---------- Legacy accordion & simple cards ---------- */
.accordion { margin-bottom: 16px; }
.acc-item { border: 1px solid var(--border-eee); border-radius: 15px; margin-bottom: 8px; }
.acc-head {
  width: 100%; padding: 12px; text-align: right; font-weight: 600; cursor: pointer;
  background: var(--surface-50);  border: none;
}
.acc-body { padding: 12px; }

.pack-card {
  border: 1px solid #eee; border-radius: 15px; padding: 12px; margin-bottom: 8px;
}

/* Legacy usage bar */
.usage .bar {
  height: 15px; background: var(--tabs-bg); border-radius: 15px; overflow: hidden;
}
.usage .bar span {
  display: block; height: 15px;
  background: linear-gradient(269.96deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 48.48%, var(--grad-cyan) 98.37%);
}

/* ---------- New dashboard accordions ---------- */
.dash-accordions { display: grid; gap: 1.76vw; direction: rtl; }
.dash-accordions .drop.is-open { background: none; box-shadow: none; }

.dash-accordions button.drop-head {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 18px; background: #fff; cursor: pointer; position: relative;
  box-shadow: 0 0 20px 0 rgba(183, 9, 76, 0.12); border-radius: var(--pkg-radius);
  border:none;
}
.dash-accordions button.drop-head:hover {
  background: #fff; 
}
.dash-accordions .drop-head.is-open {
  box-shadow: 0 0 20px rgba(183, 9, 76, 0.2); background: var(--bg);
}
.dash-accordions .head-left { display:flex; align-items:center; gap:10px; width:100%; }

/* simple background icons */
.dash-accordions .ico{
  width:22px; height:22px; flex:0 0 22px; display:inline-block;
  background-repeat:no-repeat; background-position:center; background-size:22px 22px;
}
.dash-accordions .wifi-ico    { background-image:url('../icons/wifi.svg'); }
.dash-accordions .orders-ico  { background-image:url('../icons/orders.svg'); }
.dash-accordions .rewards-ico { background-image:url('../icons/rewards.png'); }

.dash-accordions .title { font-weight: 600; font-size: clamp(19px, 1.17vw, 30px); color: var(--text); }
.dash-accordions .count { font-weight: 400; font-size: clamp(14px, 0.78vw, 20px); line-height:1.6; margin-inline-start:auto; color: var(--muted-2); }

.dash-accordions .chev { inline-size: 18px; block-size: 18px; flex: 0 0 18px; position: relative; }
.dash-accordions .chev::before {
  content: ''; position: absolute; inset: 0;
  -webkit-mask: url("data:image/svg+xml,%3Csvg width='22' height='22' viewBox='0 0 22 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.4898 6.39551L10.9787 11.8844L16.4677 6.39551L18.2973 8.22515L10.9787 15.5437L3.66016 8.22515L5.4898 6.39551Z' fill='%23000'/%3E%3C/svg%3E") no-repeat center/18px 18px;
          mask: url("data:image/svg+xml,%3Csvg width='22' height='22' viewBox='0 0 22 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.4898 6.39551L10.9787 11.8844L16.4677 6.39551L18.2973 8.22515L10.9787 15.5437L3.66016 8.22515L5.4898 6.39551Z' fill='%23000'/%3E%3C/svg%3E") no-repeat center/18px 18px;
  background: var(--muted-2); transition: transform .2s ease;
}
.dash-accordions .drop-head.is-open .chev::before { transform: rotate(180deg); }

.dash-accordions .drop-body { display: none; padding: 32px 0; }
.dash-accordions .pack-list,
.dash-accordions .orders-table,
.dash-accordions .rewards-list { display: grid; gap: 30px; }

/* ---------- Package cards ---------- */
.pack-list{
  display:grid; gap:16px; direction: rtl; margin: 6px 0 0;
}

.pkg-card{
  position: relative;
  padding: clamp(16px, 1.56vw, 40px) clamp(16px, 1.17vw, 40px);
  position: relative; background: var(--bg); border-radius: var(--pkg-radius);
  border: var(--pkg-border-w) solid transparent;
  background: #fff;
  box-shadow:
    0 6px 18px var(--shadow-blue-soft),
    0 0 0 1px var(--shadow-inset-1) inset;
  overflow: hidden;
      transition: all 0.3s ease;
}
.pkg-card::before {
content: "";
    position: absolute;
    inset: 0;
    padding: 2px;
    border-radius: inherit;
    background: linear-gradient(180deg, var(--pkg-b1) 12.77%, var(--pkg-b2) 34.55%, var(--pkg-b3) 66.06%) border-box;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}
.pkg-card:hover{
   box-shadow:
    0 8px 22px var(--shadow-blue-soft-h),
    0 0 0 1px var(--shadow-inset-1h) inset;
}
.pkg-inner{
  display:flex; gap: clamp(16px, 2.34vw, 60px);justify-content: space-between;align-items: flex-start;
}

.pkg-card .plan { display:flex; align-items:center; gap:.5rem; font-family: "coherentic", Sans-serif;font-size: clamp(16px, 0.78vw, 20px); }
.pkg-card .plan .sep { opacity:.5; }
.pkg-card .plan .plan-type { white-space:nowrap;}

/* Actions */
.pkg-actions{ position: relative;flex: 1 1 20%;display:grid; gap:10px; align-content:start; overflow: visible;  }
.qr-dropdown { position: relative; display: inline-block; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  min-height:44px; padding:10px 16px;
  border:0; border-radius: var(--btn-radius);
  font-weight:600; text-decoration:none; cursor:pointer;
  transition: transform .05s ease, box-shadow .2s ease, opacity .2s ease; user-select:none;
}
.btn:active{ transform: translateY(1px); }

.btn-ico{ width:18px; height:18px; display:inline-block; background-size:18px 18px; background-repeat:no-repeat; background-position:center; }
.use-ico{ width:18px; height:18px; display:inline-block; background-size:18px 18px; background-repeat:no-repeat; background-position:center; }
.qr-ico{ background-image:url('../icons/qr.svg'); }
.qr-close{ background-image:url('../icons/x-solid-full.svg'); }
.dl-ico{ background-image:url('../icons/download.svg'); }
.wdl-ico{ background-image:url('../icons/white_download.svg'); }
.cd-ico{ background-image:url('../icons/date.svg'); }
.pulse-ico{ background-image:url('../icons/pulse.svg'); }
.cc-ico{ background-image:url('../icons/credit-card.svg'); }
.dolar-ico{ background-image:url('../icons/dolar-b.svg'); }
.close-ico{ background-image:url('../icons/x-solid-full.svg'); }
.trash-ico{ background-image:url('../icons/mdi_garbage.svg'); }

.btn-grad{ color:var(--bg); background: linear-gradient(90deg, var(--accent-pink), var(--accent-purple));  box-shadow: 0 6px 16px var(--shadow-pink-1); }
.btn-grad:hover{   box-shadow: 0 8px 18px var(--shadow-cyan-1h); }

.btn-cyan{ color:var(--bg); background: var(--accent-cyan);  box-shadow: 0 6px 14px var(--shadow-cyan-1);}
.btn-cyan:hover{ box-shadow: 0 8px 18px rgba(7,157,176,.35); }

.btn-danger{ color:var(--bg); background:#E34D5E; box-shadow: 0 6px 14px rgba(227,77,94,.25); }
.btn-danger:hover{ box-shadow: 0 8px 18px rgba(227,77,94,.35); }

.btn-link{
  color: var(--link-muted);  background: transparent; min-height:auto; padding: 6px 8px;
  font-weight:500; border-radius:8px;
}
.btn-link:hover{  color: var(--link-hover); text-decoration: underline; }
.btn-link.is-disabled{ opacity:.5; pointer-events:none; text-decoration:none; }

/* Middle: dates & inputs */
.pkg-details{ flex:1 1 42%;display:grid; gap:12px; }
.usage-right {
    display: flex;
    gap: 4px;
    align-items: center;
}
.dates-row{
  position: relative;
  display:grid;
 grid-template-columns: 1.2fr 1.2fr 1fr;
    gap:12px;
  background: #F4F7F8; border: 1px solid var(--surface-border); padding: 8px 16px; border-radius: 15px;
}
.date-col .lbl{
  display:block; font-size: clamp(12px, 0.7vw, 18px); color:#6B6B6B;font-weight: 500;
}
.date-col .val{
  display:flex; flex-direction: column; align-items:center; gap:0;
  font-weight:800; font-size: clamp(13px, 0.51vw, 13px); color:var(--text);
}
/* date icons */
.date-col {
    display: flex;
   align-items: flex-start;
    gap: 8px;
    
}
.date-col .lbl{
  font-family: "coherentic", Sans-serif;
}
.date-col:nth-child(1)::before,
.date-col:nth-child(2)::before{
  display: flex;
  min-width: 28px;
  width: 100%;
  height: 100%;
  content:''; flex:0 0 18px; background: no-repeat center / 28px 28px; filter: saturate(.9);
}
.date-col:nth-child(1)::before{ background-image:url('../icons/calendar.svg'); }
.date-col:nth-child(2)::before{ background-image:url('../icons/clock.svg'); }

/* days left chip */
.dates-row .date-col:last-child .val{
padding:6px 8px; font-weight:600;
font-size: 12px;
  background: color-mix(in srgb, var(--grad-pink-start) 60%, transparent);
  color:var(--bg);
  border-radius: 15px;
  line-height: 1;
}

/* inputs row */
.inputs-row{
  display:flex; gap:8px; align-items: center;
  background: #F4F7F8; border: 1px solid var(--surface-border); padding: 8px 16px; border-radius: 15px;
}
.inputs-row label{ direction: ltr;white-space: nowrap;font-weight: 500; color: var(--muted);} 
.inp{
  width:100%; background: var(--soft); border:1px solid var(--line); border-radius:16px;
  padding:10px 12px; font-weight:600; color:#333; outline: none;
}
.inp:read-only{ color: var(--text); background: var(--bg); border: 1px solid var(--surface-border);border-radius: 5px;}
.inp::placeholder{ color:var(--text); opacity: 1; }
input.inp.iccid {direction: ltr;text-align: right;}
/* Right: country + status + usage */
.pkg-meta{ flex:1 1 30%;display:grid; gap:6px; align-content:space-between; }
.title-row{ position: relative; display:flex; align-items:center; gap:8px; margin-bottom:2px; }
.country { display:flex; flex-direction:column; align-items:flex-start; gap:8px; margin:0; font-size:16px; font-weight:800; }
span.country-name { font-size: clamp(18px, 1.17vw, 30px); font-weight: 600; }
img.flag { width: clamp(36px, 1.48vw, 38px); height: clamp(36px, 1.48vw, 38px); object-fit: cover; border-radius: 50%; }
.plan{ color:var(--text); font-weight:500; }

.title-row .badge{
  display: flex;
  align-items: center;
  gap: 4px;
  margin-inline-start:8px;
  border-radius:16px;
  padding:4px 8px;
font-size:12px;
  font-weight:600;
  position: absolute; left: 0; top:0;
  line-height: 1;
}
.pkg-meta span.badge:before {
    content: "";
    width: 16px;
    height: 16px;
    display: block;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    background-image:url('../icons/check.svg');
}
span.badge.active:before {
  background-image:url('../icons/check.svg');
}
span.badge.pending:before {
  width: 18px;
  height: 18px;
  background-image:url('../icons/icon-pause.svg');
}
span.badge.paused:before {
  width: 18px;
  height: 18px;
  background-image:url('../icons/icon-pause.svg');
}
span.badge.expired:before {
  background-image:url('../icons/expired.svg');
}
.badge.active  { background-color: var(--badge-green-bg);  color: var(--badge-green); }
.badge.pending { background-color: var(--badge-yellow-bg); color: var(--badge-yellow); }
.badge.paused  { background-color: var(--badge-gray-bg);   color: var(--badge-gray); }
.badge.expired { background-color: var(--badge-red-bg);    color: var(--badge-red); }

/* usage */
.usage{ display:flex; gap:16px; align-items: end; }
.usage-top{ display:flex; align-items:center; gap:10px; }
.usage-left { text-align: center; }

.usage .pct{
  background: linear-gradient(72.4deg, var(--grad-pink-start) 12.77%, var(--grad-pink-end) 34.55%, var(--grad-cyan) 66.06%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
  display: inline-flex; align-items: baseline;
  font-weight: 600; font-size: clamp(25px, 1.33vw, 34px);
}
.usage .pct .pct-sym{ font-weight:600; }
.usage .used{ color:var(--muted); font-weight:600; }
span.use-label { font-weight: 600; }
span.use-val { font-weight: 500; }

.bar-box { flex: 1 1 60%; }
.bar{ height:8px; background:#eaf3f7; border-radius: 15px; overflow:hidden; }
.bar-fill{
  display:block; height:100%;
  background: linear-gradient(90deg, var(--progress-start), var(--progress-end));
  width:0%; transition: width .3s ease;
}

/* QR panel / actions */
.btn.btn-grad.btn-show-qr {
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 97.6%);
  border-radius: 30px; color: var(--bg);
  display: flex;
  align-items: center;
  font-weight: 500;
}
a.btn.btn-link.btn-invoice {
  font-weight: 500;
}
.btn.btn-cyan.btn-extend {
  width: 100%;background: var(--grad-cyan); border-radius: 30px; color: var(--bg); border: none;font-weight: 600;
  
}

a.link-toShop {
    margin: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: max-content;
    display: inline-block;
    font-size: clamp(20px, 0.98vw, 25px);
    font-weight: 700;
    padding: .5rem 3rem;
    text-align: center;
    transition: all .3s;
    background: var(--grad-cyan);
    border-radius: 30px; color: var(--bg);
    border: 1px solid var(--grad-cyan);
    transition: all 0.3 ease;
}
a.link-toShop:hover {
    border: 1px solid var(--grad-cyan);
    background: none;
    color: var(--grad-cyan);
}

.qr-panel {
  display: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.qr-panel.is-open{
  display:block;
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}


.qr-panel.is-open {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.qr-title{ font-family: "coherentic", Sans-serif; font-weight:800; text-align:center; margin-bottom:10px; }
.qr-card{
  margin:auto; max-width: 400px; padding: 15px 30px; border-radius:15px;
  background: linear-gradient(67.29deg, rgba(183, 9, 76, 0.16) 0.97%, rgba(237, 76, 92, 0.12) 45.78%, rgba(0, 145, 173, 0.12) 96.65%);
 text-align:center;
}

.qr-card .esi-hr-grad {
  margin-top: 8px;
}
.qr-box{
  max-width: 250px;
  padding: 16px;
  margin:0 auto 10px; background:var(--bg); border-radius:15px;
  display:flex;flex-direction: column;gap: 8px; align-items:center; justify-content:center; box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
 .qr-box img{
    width:180px; height:180px;object-fit: contain;
 }
.qr-iccid{ font-weight:500; }
.qr-hint{ color:var(--muted); font-size:13px; }
.qr-actions{ display:flex; gap:10px; justify-content:center; margin-top:6px; }

.empty-state{ padding:12px; color:var(--muted); text-align:center; }



/* ---------- Personal Details tab ---------- */
.esimax-personal .esi-header-row { margin-bottom: 3.13vw; color: var(--muted); }
.esimax-personal .esi-customer-chip { display:flex; gap:.5rem; align-items:center; font-size:.9rem; }

.esimax-personal .esi-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 28px; }

.esi-header-row {
  padding: 15px 30px; display: flex; gap: 8px; align-items: center; border-radius: 15px;
  box-shadow: 0 0 20px rgba(183, 9, 76, 0.2);background: #fff;
}
.esi-avatar {
  width: clamp(24px, 2.89vw, 74px); height: clamp(24px, 2.89vw, 74px);
  display:flex; justify-content:center; align-items:center;
  font-weight: 500; font-size: clamp(24px, 1.09vw, 28px);
  color: var(--bg); border-radius: 50%;
  background: linear-gradient(40.95deg, var(--grad-pink-start) 4.55%, var(--grad-pink-end) 100%);
}
.esimax-personal .esi-avatar {
width: clamp(56px, 2.89vw, 74px); height: clamp(56px, 2.89vw, 74px);
}
.esi-name { font-size: clamp(20px, 1.17vw, 30px); color: var(--text); font-weight: 600; }

.esimax-personal .esi-card{ padding: 15px; position: relative; }
.esi-card-wrapper {
  padding: clamp(20px, 1.95vw, 50px) clamp(15px, 1.17vw, 30px) clamp(26px, 2.34vw, 60px);
  position: relative; border-radius: var(--pkg-radius);
}
.esi-card-wrapper::before {
  content:""; position:absolute; inset:0; padding:1px; border-radius: inherit;
  background: linear-gradient(72.4deg, var(--pkg-b1) 12.77%, var(--pkg-b2) 34.55%, var(--pkg-b3) 66.06%) border-box;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events:none;
}
span.esi-sep { margin: 0 16px; }
a.btn.dosnload-invoice {
  color:var(--accent-pink)
}
.esimax-personal .esi-card-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.esi-personal-form .esi-card-title,
.esi-personal-form .esi-invoice-title,
.esi-security .esi-card-title {
  display:flex; align-items:center; gap:8px; font-weight:600;
  font-size: clamp(20px, 0.86vw, 22px); line-height: 1;
}
.esi-personal-form .esi-card-title.small {
  margin:30px 0; font-size: clamp(18px, 0.7vw, 18px);
}
.esi-personal-form .esi-card-title.small .title-icon { width:19px; height:19px; }

.title-icon {
  display:inline-block; background-repeat:no-repeat; background-position:center; background-size:contain;
  width: clamp(24px, 1.37vw, 35px); height: clamp(24px, 1.37vw, 35px);
}
.title-icon.user   { background-image:url('../icons/user-color.svg'); }
.title-icon.protect{ background-image:url('../icons/protect.svg'); }
.title-icon.edit   { width:14px; height:14px; background-image:url('../icons/edit.svg'); }
.title-icon.doc    { background-image:url('../icons/invoice.svg'); }
.title-icon.book   { background-image:url('../icons/book.svg'); }
.title-icon.save   { width:14px; height:14px; background-image:url('../icons/save.svg'); }

.esimax-personal .esi-btn{
  display:flex; align-items:center; justify-content:center; line-height:1; font-weight:500;
  border-radius:10px; padding:8px 24px; cursor:pointer;
  border: 1px solid transparent; background: var(--bg); color: var(--text);
}
.esimax-personal button.js-esi-save    { background:#D8F8E5; color:#377E60; }
.esimax-personal button.js-esi-cancel  { border:1px solid #827F7F; background:none; color:#9E9D9D; }
.esimax-personal .esi-btn-ghost        { background:var(--bg-btn-gray); border-color: var(--panel-border); color:var(--muted); }
.esimax-personal .esi-btn-ghost:hover  { background:#fafafa; }

.esimax-personal .esi-edit-controls{ display:flex; align-items:center; gap:10px; }
.esimax-personal .esi-save-cancel{ display:none; gap:10px; }
.esimax-personal .esi-personal-form[data-edit="on"]  .js-esi-edit{ display:none; }
.esimax-personal .esi-personal-form[data-edit="on"]  .esi-save-cancel{ display:flex; }
.esimax-personal .esi-personal-form[data-edit="off"] .esi-save-cancel{ display:none; }

/* separators & alerts */
.esi-hr-grad{
  border:0; height:2px; margin:24px 0 !important; opacity:1;
  background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 52%, var(--grad-cyan) 100%);
}
.esi-alert{
  margin:.5rem 0 0; padding:.5rem .75rem; border-radius:8px;
  background:#fff0f0; color:#b20000; font-size:.92rem; border:1px solid #ffd4d4;
}

/* form fields */
.esimax-personal .esi-form .esi-field{ margin-bottom:12px; }
.esimax-personal .esi-form label{
  margin-bottom: 8px; display:block;
  font-size: clamp(18px, 0.86vw, 22px); color:var(--text); font-weight:600;
}
.esimax-personal .esi-form .esi-invoice label { color:#939393; font-size: clamp(16px, 0.78vw, 20px); }
.esimax-personal .esi-form input{
  width:100%; height:43px; border-radius:12px; border:1px solid var(--bg-btn-gray);
  padding:0 6px; outline:none; background: var(--bg); color: var(--text);
}
.esimax-personal .esi-form input:disabled {
  background: #ffffff00; color:#999999; border-color: transparent;
}
.esimax-personal .esi-form .esi-invoice input:disabled { color:var(--text); }
.esimax-personal input#phone,
.esimax-personal input#billing_phone { text-align: right; }

.esimax-personal .esi-two{ padding-right:24px; display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.esimax-personal .esi-actions{ display:flex; gap:10px; margin-top:6px; }

.esimax-personal .esi-note{ margin-top:4px; display:flex; align-items:center; gap:10px; }
.esimax-personal .esi-muted{ color: var(--text); font-size:.92rem; }

.esimax-personal .esi-switch{ position:relative; width:54px; height:26px; display:inline-block; }
.esimax-personal .esi-switch input{ display:none; }
.esimax-personal .esi-slider{ position:absolute; inset:0; background:#d7dbe3; border-radius:999px; transition:.25s; }
.esimax-personal .esi-slider:before{
  content:""; position:absolute; width:20px; height:20px; top:3px; right:3px;
  border-radius:50%; background:var(--bg); box-shadow:0 1px 4px rgba(0,0,0,.15); transition:.25s;
}
.esimax-personal .esi-switch input:checked + .esi-slider{ background:var(--grad-pink-end); }
.esimax-personal .esi-switch input[name="marketing_optin"]:checked + .esi-slider{ background:var(--pkg-b3); }
.esimax-personal .esi-switch input:checked + .esi-slider:before{ transform: translateX(-26px); }

.esimax-personal .esi-preview{ margin-top:12px; border-top:1px dashed var(--panel-border); padding-top:12px; }
.esimax-personal .esi-row{ display:flex; justify-content:space-between; padding:8px 0; }
.esimax-personal .esi-row .k{ color: var(--muted); }
.esimax-personal .esi-subtitle{ margin-top:10px; font-weight:600; }

.esimax-personal .esi-accordion{ display:flex; flex-direction:column; gap:30px; }
.esi-acc-item { padding:16px; border:1px solid var(--bg-btn-gray); border-radius:15px; cursor:pointer; }
.esimax-personal .esi-acc-toggle{
  padding:0; width:100%; display:flex; align-items:center; gap:8px; background: var(--bg); border:none;
}
.esi-invoice-toggle{
  padding:0; margin-bottom:16px; display:inline-flex; align-items:center; gap:.5rem; white-space:nowrap;
}
.esimax-personal .esi-acc-toggle::after{
  content:""; inline-size:22px; block-size:22px; margin-inline-start:auto;
  background: url('../icons/arrow-left.svg') no-repeat center/contain; opacity:.55;
}
.esimax-personal .esi-acc-title {
  text-align:right; font-size: clamp(18px, 0.86vw, 22px); color:var(--text); line-height:1.2;
}
.esi-acc-lock, .esi-acc-doc{
  inline-size:24px; block-size:24px; flex:0 0 auto; opacity:.9;
  background-size:contain; background-repeat:no-repeat;
}
.esi-acc-lock{ background-image:url('../icons/lock.svg'); }
.esi-acc-doc { background-image:url('../icons/wallet.svg'); }
.esimax-personal .esi-acc-panel{ display:none; }
.no-js .esimax-personal .esi-acc-panel { display:none; }
.esimax-personal .esi-acc-item.is-open > .esi-acc-panel { margin-top: 16px; display:block;}
.esimax-personal .esi-acc-item.is-open .esi-acc-toggle:after {
  visibility: hidden;
}
.esimax-personal .esi-link-row{ display:flex; justify-content:flex-start; }
.esimax-personal .esi-toast{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  background:#111; color:var(--bg); padding:10px 14px; border-radius:10px;
  opacity:0; pointer-events:none; transition:.25s; z-index: 9999;
}
.esimax-personal .esi-toast.is-show{ opacity:1; pointer-events:auto; }

.esimax-personal .text-grad{
  background: linear-gradient(72.4deg, var(--grad-pink-start) 12.77%, var(--grad-pink-end) 34.55%, var(--pkg-b3) 66.06%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}
input#user_email, input#billing_email{
        direction: ltr;
}
/* ---------- Password inline form ---------- */
#acc-password button {
  border:none;
}
.esi-form-password-inline .pw-inline{
  display:flex; gap:12px; align-items:center;
}
#acc-password button.esi-btn.esi-btn-primary{
  padding: 14px 20px; border-radius: var(--chip-radius); font-weight: 600; color:var(--bg);
  background: linear-gradient(90deg,var(--g1) 0% ,var(--g2) 97.6%);
  border:0; box-shadow: 0 2px 10px rgba(0,0,0,.06);
}
.esimax-personal label.pill-input{
margin: 0;
  position: relative; display:flex; align-items:center; block-size:44px;
  background: var(--surface-muted); border-radius: var(--chip-radius);
  border: 1px solid transparent; padding-inline: 16px 36px;
}
.esimax-personal .pill-input input{
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
  direction: rtl;
  inline-size: 100%;
  font-size: 16px;
  font-weight: 400;
  color: var(--pill-text);
  border:none;
  background: var(--surface-muted);
}
.esimax-personal .pill-input .input-text:focus {
  border:none;
  outline: none;
}
.pill-input input[type="password"]{
  -webkit-text-security: disc; 
  text-security: disc;        
}
.esimax-personal .pill-input input::placeholder{ color: var(--pill-muted); }
.pw-eye{
  position:absolute;
  inset-block:4px;
  inset-inline-end:6px;
  inline-size:36px; block-size:36px; border-radius:50%; background: var(--circle);
  border:none; cursor:pointer; padding:0;
}
.pw-eye span{
  position:absolute; inset:0; background-repeat:no-repeat; background-position:center; background-size: 18px;
}
.pw-eye .icon-eye{ 
  display: none;
  border: none;
  background-image: url('../icons/eye.svg');
  background-position:center;
  width: clamp(16px, 0.78vw, 20px);
 }
.pw-eye .icon-eye-off{  display: inline-block; width: clamp(16px, 0.78vw, 20px); background-image: url('../icons/eye-off.svg');background-position:center;  }
.pw-eye.is-on .icon-eye{ display:block; }
.pw-eye.is-on .icon-eye-off{ display:none; }
.pill-input:has(input:focus-visible),
.pw-eye:focus-visible{ outline: 3px solid #0091AD33; outline-offset: 2px; }


.esimax-payments .mini-tabs{display:flex;align-items:center;gap:10px;padding:10px 12px 14px;border-bottom:1px solid var(--surface-border,#e9e9ee)}
.esimax-payments .mini-tab{appearance:none;border:0;background:#f3f4f7;color:var(--text-strong);padding:8px 16px;border-radius:999px;cursor:pointer;font-weight:600}
.esimax-payments .mini-tab.active{color:#fff;background:linear-gradient(90deg,var(--accent-purple,#B7094C),var(--accent-pink,#ED4C5C),var(--accent-cyan,#0091AD))}
.esimax-payments .mini-tools{margin-inline-start:auto;display:flex;gap:8px;align-items:center}
.esimax-payments .mini-panel{display:none}
.esimax-payments .mini-panel.is-active{display:block}

.shadow-list{display:grid;gap:18px;padding:18px 8px}

#panel-orders .acc-item {
  position: relative;
    padding: clamp(15px, 1.17vw, 30px) 0 clamp(40px, 2.34vw, 60px);
    position: relative;
    border-radius: var(--pkg-radius);
    border: none;
    background: #fff;
}
#panel-orders .acc-item::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(72.4deg, var(--pkg-b1) 12.77%, var(--pkg-b2) 34.55%, var(--pkg-b3) 66.06%) border-box;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}
.mini-tabs, .mini-panel {
    padding: 0 clamp(15px, 1.17vw, 30px);
}
.mini-tabs {
    display: flex;
    gap: 16px;
}
.mini-panel.is-active {
    display: block;
}

.mini-panel {
    display: none;
}
.mini-tools {
    display: block; 
    margin-right: auto;
}
h3.mini-tab-title {
    display: none;
}
[data-mini-panel="cards"].is-active ~ .mini-tools {
  display: none;
}
select.js-pay-year {
    padding: 8px 16px;
    border-radius: 15px;
    border: 1px solid #939393;
}
button.mini-tab {
    color: #000;
    border: none;
    border-radius: 15px;
    display: flex;
    align-items: center;
    gap: 8px;
   transition: all .3s;
}

button.mini-tab.active, 
button.mini-tab:hover, 
button.mini-tab:focus-visible {
    background: #0091AD !important;
    color: #fff !important;
}

button.mini-tab.active .btn-ico, 
button.mini-tab:hover .btn-ico {
   filter: invert(1) brightness(2); 
}
.pay-card {
    background: #fff;
    border-radius: 15px;
    padding: 16px;
    box-shadow: 0px 0px 20px 0px #B7094C33;
}
.pay-content {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.pay-head{display:flex;gap:16px;}
.pay-title{margin:0;font-size:clamp(18px,1.1vw,24px); font-weight: 600;}
.pay-iccid{display:flex;align-items:center;gap:8px}
.pay-iccid input{height:40px;background:#fff;border:1px solid var(--surface-border);border-radius:10px;padding:0 12px;direction:ltr}
.pay-iccid .tag{background:#eef2f5;border:1px solid var(--surface-border);border-radius:999px;padding:6px 10px;font-weight:600;color:#7b8a97}
.pay-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:10px;color:#5e6b78}
.pay-meta .flag{display:inline-block;width:18px;height:18px;background-size:cover;border-radius:50%;vertical-align:-3px}
.pay-content a.btn {
    padding: 8px 20px;
    border-radius: var(--chip-radius);
    font-weight: 400;
    color: var(--bg);
    background: linear-gradient(90deg, var(--g1) 0%, var(--g2) 97.6%);
    border: 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .06);
}
span.meta {
    display: flex;
    align-items: center;
    gap: 4px;
}
.pay-content span.meta.country {
    font-weight: 400;
}
.pay-card span.sep {
    display: inline-block;
    width: 2px;
    height: 18px;
    background: linear-gradient(180deg, var(--divider-start) 0%, var(--divider-end) 100%);
    border-radius: 2px;
}
.pay-card.pay-card--group .pay-content:not(:last-child) {
  margin-bottom: 30px;
}
.pay-card.pay-card--group > .pay-head .pay-title {
  color:var(--text);
  font-weight: 500;
      background: none;
    -webkit-text-fill-color: unset;
}
.pay-card.pay-card--group >  .pay-head {
  align-items: end;
}
.pay-card.pay-card--group .pay-head a {
    margin-right: auto;
    background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 97.6%);
    border-radius: 30px;
    color: var(--bg);
    display: flex;
    align-items: center;
    font-weight: 400;
    line-height: 1;
}
.pay-card.pay-card--group .pay-head .pay-meta {
  margin: 0;
}
.pay-card.pay-card--group .pay-content {
  flex-direction: column;
  align-items: flex-start;
}
.meta.iccid input {
    border: 1px solid #E6E6E6;
    border-radius: 8px;
}


.orders-list { display:flex; flex-direction:column; gap:12px; }
.order-row { border:1px solid var(--bg-btn-gray); border-radius:16px; }
.order-link{ display:flex; flex-wrap:wrap;align-items:center; gap:12px; justify-content:space-between; padding:14px 16px; text-decoration:none; color:inherit; }
.order-link .flag{ width:28px; height:28px; border-radius:50%; object-fit:cover; margin-inline-start:8px; }
.order-link .row-left{ display:flex; align-items:center; gap:10px; }
.order-link .row-right{ display:flex;flex-wrap:wrap; align-items:center; gap:8px; color:#A7A7A7; font-weight:600; }
.order-link .sum{ color:#111827; }
.order-link .sep{ opacity:.4; margin:0 6px; }
.badge{ padding:6px 10px; border-radius:999px; font-weight:600; background:#eee; }
.badge.finished{ background:#f3e8ff; color:#6b21a8; }
.badge.canceled{ background:#fee2e2; color:#b91c1c; }
.badge.refunded{ background:#dcfce7; color:#166534; }
.badge.failed{ background:#fee2e2; color:#991b1b; }
.country{ font-weight:800; font-size:1.1rem; }
.order-link .line1 {
    width: 100%;
}

.order-link .line2 {
    height: 100%;
}

.order-link span.ord-item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 16px;
}

/* Rewards "Coming soon" */
.esimax-rewards-soon .rs-card{
  background:#fff;
  border-radius:18px;
  padding:22px;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  border:1px solid rgba(0,0,0,.06);
}

.esimax-rewards-soon .rs-head{
  display:flex; align-items:center; gap:10px; margin-bottom:8px;
}
.esimax-rewards-soon .rs-ico{ font-size:22px; line-height:1; }
.esimax-rewards-soon .rs-title{ margin:0; font-size:20px; font-weight:800; }
.esimax-rewards-soon .rs-badge{
  margin-inline-start:auto;
  font-size:12px; padding:.2rem .55rem; border-radius:999px;
  background:linear-gradient(90deg,#f43f5e,#ec4899);
  color:#fff; font-weight:600;
  line-height: 1;
}

.esimax-rewards-soon .rs-lead{
  margin:8px 0 14px;
    font-family: "coherentic", Sans-serif;
  color:#4b5563; font-size:15px;
}

.esimax-rewards-soon .rs-list{
  margin:0 0 14px; padding:0 1.2rem; color:#374151; line-height:1.8;
}
.esimax-rewards-soon .rs-actions{ display:flex; gap:10px; align-items:center; }
.esimax-rewards-soon .btn.btn-cyan{
  background:#2b8ca6; color:#fff; border-radius:12px; padding:.55rem 1rem;
  border:none; cursor:not-allowed; opacity:.85;
}
.esimax-rewards-soon .btn.btn-link{
  color:#2563eb; text-decoration:underline; padding:.45rem .25rem;
}

/* animated dots "..." */
.esimax-rewards-soon .rs-dots::after{
  content:'';
  display:inline-block;
  width:1.4em; text-align:left;
  animation:rsDots 1.4s steps(4,end) infinite;
}
@keyframes rsDots{
  0% { content:''; }
  25%{ content:'.'; }
  50%{ content:'..'; }
  75%{ content:'...'; }
  100%{ content:''; }
}

/* ---------- Tab  Payment Methods--------- */


.mini-panel .cards-header{
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 8px;
}
.mini-panel .cards-header h3{
  margin: 0; font-size: 18px; font-weight: 800; color: var(--text);
}
.card-row{
  width: 100%;
  display: flex;
  justify-content: space-between;
  background: #fff;
  border-radius: 15px;
  padding: 16px;
  box-shadow: 0px 0px 20px 0px #B7094C33;
}
.card-row .left{ 
    display:flex; 
    align-items:center; 
    flex-direction: row-reverse;
    gap: 16px;
}
.card-wrapper {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.icon-trash {color:#be123c; border:none; }
.brand{ font-weight: 700; color: var(--text); font-size: 16px; }
.meta.small{ font-size: 12px; color: var(--muted); }
.card-row .card-box .meta.small {
    color: #ADADAD;
}
.card-row .center{ display:flex; flex-direction:column; gap:4px; align-items:flex-end; }
.badge.ok{ display: flex; align-items: baseline;gap: 4px; background:#D8F8E5; border-color:#b7f0c8; color:#377E60;}

.badge{
  display:inline-block; padding:4px 10px; border-radius:999px;
  font-size:12px; line-height:1.4; border:1px solid #e6f4ea; background:#eefcf3; color:#0a7a3b;
}
.btn.btn-cyan{
  margin-right: auto;
    background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 97.6%);
    border-radius: 30px;
    color: var(--bg);
    display: flex;
    align-items: center;
    font-weight: 400;
    line-height: 1; }
.loadbar{ font-size: 14px; color: var(--muted); }

a.set-default {
    position: relative;
    padding: 16px;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border: none;
    border-radius: 30px;
    background: #fff;
    font-weight: 500;
    cursor: pointer;
    z-index: 0;
    text-decoration: none;
    outline: none;
    color:#424242;
    white-space: nowrap;
} 
a.set-default:after {
  content: "";
  position: absolute;
  inset: 0;              
  padding: 1px;    
  border-radius: inherit;
  background:linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 53.85%, var(--grad-cyan) 100%);
  -webkit-mask:
     linear-gradient(#000 0 0) content-box,
     linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;

  pointer-events: none;   
  z-index: -1;
}
a.set-default:hover,
a.set-default:focus-visible{
  text-decoration: none;
   font-weight: 500;
}
a.set-default:hover::after,
a.set-default:focus-visible::after{
  filter: brightness(1.08);
}

button#cards-save-mock {
    color: #fff;
    border-radius: 30px;
}

button#cards-cancel {
    border-radius: 30px;
}
.empty{ color: var(--muted); padding: 12px; }
.card-last4 {
  direction: ltr;
  unicode-bidi: embed;
  display: inline-block;
  margin-left: 4px; 
}
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@media (max-width: 640px){
  .card-row{ grid-template-columns: 36px 1fr; grid-auto-rows:auto; row-gap:8px; }
  .card-row .right{ grid-column: 1 / -1; justify-content:flex-start; }
}
/* ---------- Media queries (all consolidated here) ---------- */
@media (max-width: 1100px){
  .pkg-inner{ grid-template-columns: 260px 1fr 320px; }
}
@media (max-width: 980px){
  .pkg-inner{ grid-template-columns: 1fr; }
}
@media(max-width:768px) {
   
    .hide-mobile {
        display: none;
    }
    .esimax-login {
        padding: 15px;
    }
    div#esimax-app {
        overflow-x: hidden;
    }
    .esimax-login-card {
        margin: 0;
        gap: 60px;
        width: 100%;
    }
    
     .esimax-tabs {
        width:100%;
        justify-content: flex-start; 
        border-radius: 0;
        overflow-x: scroll; 
        -ms-overflow-style: none;  /* IE и Edge */
        scrollbar-width: none; 
    }
    .esimax-tabs::-webkit-scrollbar {
        display: none; /* Chrome, Safari, Opera */
    }
    .esimax-chip {
        min-width: auto;
        padding: 4px 8px;
        gap: 8px;
        box-shadow: 0px 0px 9.50139px 1.90028px rgba(183, 9, 76, 0.2) !important;
    }
    .esimax-chip .chip-avatar{
        width:24px; height:24px; border-radius:8px; flex:0 0 24px;font-size: 10px;
    }
    .esimax-chip .chip-avatar .dot {
        position: absolute;
        bottom: -1px;
        right: -1px;
        width: 9px;
        height: 9px;
        border-radius: 50%;
        border: 1px solid var(--bg);
        background: #bbb;
    }
    .dates-row, .inputs-row {
        padding: 15px;
        border-radius: 10px;
    }
    .dates-row .date-col:last-child .val {
        padding: 3px 5px;
    }
    .dates-row .date-col:last-child .val {
        font-size: 11px;
    }
    .date-col .val {
        font-weight: 400;
    }
    .btn.btn-cyan.btn-extend {
        font-weight: 400;
    }
    .use-ico, .btn-ico {
        width: 26px;
        height: 26px;
        background-size: 26px 26px;
    }
    .date-col:nth-child(1)::before, .date-col:nth-child(2)::before {
       min-width: 24px;
        flex: 0 0 24px;
    }
    .esimax-login-card__head {
        font-weight: 400;
    }
    button.button.esimax-login-btn {
        margin-top: 30px;
        min-width: 200px;

    }
    .esimax-panels {
        padding: 0 15px 60px;
    }
    .tab-btn span {
         font-weight: 400;
    }
    span.tab-icon.user {
        width: 38px;
        height: 38px;
    }
    span.use-label {
        font-weight: 400;
    }
    .dash-accordions {
        gap: 20px;
    }
    .dash-accordions .drop-body {
        padding: 15px 0;
    }
    .pkg-inner {
        flex-wrap: wrap;
    }
    .pkg-meta {
        flex: 1 1 100%;
    }

    .pkg-details {
        flex: 1 1 100%;
    }
    .dates-row {
        display: flex;
        gap: 10px;
    }

    aside.pkg-actions {
        flex: 1 1  100%;
    }

    aside.pkg-actions {
        position: relative;
        margin-top: 15px;
        display: flex;
        flex-wrap: wrap;
    }
     .pkg-details .date-col:last-child {
        position: absolute;
        left: 5px;
        top: 5px;
    }

    aside.pkg-actions button {
        flex: 1 1 45%;
        font-size: 15px;
    }

     aside.pkg-actions  a.btn-invoice {
        width: 100%;
    }
    span.val.chip {
        font-size: 9px;
    }
  .esi-form-password-inline .pw-inline{ 
    grid-template-columns: 1fr; 
   }
  .esi-btn.esi-btn-primary{ order: -1; }
      .esimax-personal .esi-two {
        padding-right: 0;
        grid-template-columns: 1fr 1fr;
    }

    .esimax-personal .esi-header-row {
        padding: 0;
        flex-wrap: wrap;
        border-radius: 0;
        box-shadow: none;
        background: none;
    }
    .esi-header-row:after {
        content: "";
        display: block;
        border: 0;
        height: 1px;
        width: 100%;
        margin: 15px 0 !important;
        opacity: 1;
        background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 52%, var(--grad-cyan) 100%);
    }
    .esimax-personal .esi-card {
        padding: 0 5px;
    }
    .esimax-personal .esi-header-row .esi-name, 
    .esimax-personal .esi-header-row .esi-sep {
        display: none;
    }
    .esimax-personal .esi-header-row .esi-left, 
    .esimax-personal .esi-grid  {
        display: flex;
        flex-direction: column;
    }
    .esi-form-profile hr {
        height: 1px;
        margin: 30px 0 !important;
    }
    .esimax-personal .esi-acc-toggle {
        flex-wrap: wrap;

    }
    .esimax-personal .esi-btn {
        padding: 8px 16px;
    }
    .esi-invoice-toggle {
        white-space: normal;
    }
    span.esi-acc-lock {
        align-self: flex-start;
    }

    /* span.esi-acc-doc {
        align-self: flex-start;
    } */
    span.esi-acc-title {
        width: calc(100% - 80px);
        white-space: normal;
    }
    .esi-personal-form .esi-card-title.small {
        margin: 30px 0;
        font-size: clamp(18px, 0.7vw, 18px);
    }
    .esimax-personal .esi-muted {
        font-size: 18px;
    }
    .esimax-personal .esi-switch {
         width: 54px;
        height: 25px;
    }

    .esimax-personal .esi-slider:before {
        width: 18px;
        height: 18px;
        right: 0px;
    }
    section.esi-card.esi-security .esi-acc-title span {
        font-weight: 400 !important;
    }
     section.esi-card.esi-security .esi-acc-title span:not(:first-child) {
        font-size: 16px;
     }
    .pay-card.pay-card--group > .pay-head {
        align-items: end;
    }

    a.set-default {
        font-size: 8px;
        padding: 5px 6px;
    }
    span.btn-ico.trash-ico {
        width: 20px;
        height: 20px;
        background-size: 20px;
    }
    .pay-head {
        flex-wrap: wrap;
    }
    .pay-card.pay-card--group > .pay-head .pay-title {
        font-size: 13px;
    }
    .mini-tabs {
        display: flex;
        flex-wrap: wrap;
        gap: 0;
    }
    .mini-tabs, .mini-panel {
        padding: 0;
    }
    button.mini-tab {
        border-radius: 30px;
    }
    #panel-orders .acc-item::before {
        display: none;
    }
    .mini-tabs .mini-tab:first-child {
        order: 2;
    }
    .mini-tabs .mini-tab:nth-child(2) {
        order: 3;
    }

    .mini-tools {
        width: 100%;
        order:1;
        margin: 0;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .mini-tools:after {
        content: "";
        display: block;
        border: 0;
        height: 1px;
        width: 100%;
        margin: 24px 0 !important;
        opacity: 1;
        background: linear-gradient(90deg, var(--grad-pink-start) 0%, var(--grad-pink-end) 52%, var(--grad-cyan) 100%);
    }
    h3.mini-tab-title {
        display: block;
        font-weight: 600;
        font-size: clamp(20px, 0.86vw, 22px);
        line-height: 1;
    }
}

