/* Login Modal (extracted from provided .card design; scoped to avoid global overrides) */
.login-modal{position:fixed;inset:0;z-index:1500;display:none;align-items:center;justify-content:center;padding:24px}
.login-modal.is-open{display:flex}
.login-modal__backdrop{position:absolute;inset:0;background:rgba(10,10,15,0.66);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.login-modal__panel{position:relative;z-index:1;width:100%;max-width:420px}

.login-modal .card{background:rgba(15,15,20,.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:22px;width:100%;box-shadow:0 32px 80px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.03) inset,0 0 60px rgba(240,106,255,.06);position:relative;overflow:hidden}
.login-modal .card::before{content:'';position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(to right,transparent, rgba(240,106,255,.5), rgba(122,179,255,.3), transparent)}

.login-modal .screen{padding:30px 28px 26px;display:none;flex-direction:column}
.login-modal .screen.active{display:flex;animation:lmScreenIn 280ms cubic-bezier(.22,1,.36,1) both}
.login-modal .screen.back-in{animation:lmScreenBack 280ms cubic-bezier(.22,1,.36,1) both}
@keyframes lmScreenIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
@keyframes lmScreenBack{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:none}}

.login-modal .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.login-modal .card-title{font-size:13.5px;font-weight:700;text-align:center;flex:1;letter-spacing:-.1px;color:rgba(244,244,246,0.95)}
.login-modal .btn-back{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.12);background:rgba(0,0,0,0.18);color:rgba(231,231,238,0.92);transition:background 150ms ease,transform 150ms ease;flex-shrink:0}
.login-modal .btn-back:hover{background:rgba(0,0,0,0.28)}
.login-modal .btn-back svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.login-modal .btn-back.hidden{visibility:hidden;pointer-events:none}

.login-modal .brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:26px}
.login-modal .brand-mark{width:52px;height:52px;border-radius:16px;background:transparent;border:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;padding:10px;box-shadow:none}
.login-modal .brand-mark img{width:100%;height:100%;object-fit:contain;display:block}
.login-modal .brand-name{font-family:'Unbounded',system-ui,sans-serif;font-size:19px;font-weight:700;letter-spacing:-.5px;color:#f4f4f6}
.login-modal .brand-name em{background:linear-gradient(135deg,#f06aff,#7ab3ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:normal}
.login-modal .brand-sub{font-size:13px;color:rgba(138,138,158,1);text-align:center}

.login-modal .auth-list{display:flex;flex-direction:column;gap:7px;margin-bottom:8px}
.login-modal .btn-auth{display:flex;align-items:center;gap:11px;width:100%;padding:12px 14px;background:rgba(20,20,25,1);border:1px solid rgba(255,255,255,.08);border-radius:12px;color:#f4f4f6;font-size:13.5px;font-weight:600;transition:background 220ms ease,border-color 220ms ease,transform 220ms ease,box-shadow 220ms ease;text-align:left}
.login-modal .btn-auth:hover{background:rgba(26,26,33,1);border-color:rgba(255,255,255,.13);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.login-modal .btn-auth:active{transform:translateY(0)}
.login-modal .auth-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.login-modal .icon-tg{background:rgba(42,171,238,.12)}
.login-modal .icon-mail{background:rgba(240,106,255,.12)}
.login-modal .icon-google{background:rgba(255,255,255,.06)}
.login-modal .icon-google .gmark{font-weight:900;font-size:14px;letter-spacing:-0.4px;color:#f4f4f6;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial}
.login-modal .chevron{margin-left:auto;color:rgba(69,69,90,1);flex-shrink:0;transition:transform 150ms ease,color 150ms ease}
.login-modal .chevron svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.login-modal .btn-auth:hover .chevron{transform:translateX(3px);color:rgba(138,138,158,1)}

.login-modal .divider{display:flex;align-items:center;gap:10px;color:rgba(69,69,90,1);font-size:11.5px;font-weight:600;margin:10px 0}
.login-modal .divider::before,.login-modal .divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08)}

.login-modal .tabs{display:flex;background:rgba(20,20,25,1);border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:3px;margin-bottom:18px}
.login-modal .tab{flex:1;text-align:center;padding:8px;border-radius:7px;font-size:12.5px;font-weight:600;color:rgba(69,69,90,1);cursor:pointer;transition:background 150ms ease,color 150ms ease,box-shadow 150ms ease;user-select:none}
.login-modal .tabs button.tab{border:none;background:transparent;font:inherit;font-family:inherit;margin:0;width:auto;line-height:inherit;cursor:pointer}
.login-modal .tab.active{background:rgba(26,26,33,1);color:#f4f4f6;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.login-modal .tab:hover:not(.active){color:rgba(138,138,158,1)}
.login-modal .tabs.lm-main-mode-tabs{margin-top:4px}
.login-modal .card-footer.lm-register-terms{text-align:left}
.login-modal .auth-terms-row{display:flex;align-items:center;gap:10px;line-height:1.55}
/* Custom checkbox: invisible native input stacked over drawn box (Telegram WebView / iOS often ignore appearance:none) */
.login-modal .auth-terms-check-label{
  position:relative;
  flex-shrink:0;
  width:18px;
  height:18px;
  margin-top:0;
  align-self:center;
  cursor:pointer;
  display:block;
}
.login-modal .auth-terms-check-input{
  position:absolute;
  inset:0;
  width:18px;
  height:18px;
  margin:0;
  opacity:0;
  z-index:2;
  cursor:pointer;
}
.login-modal .auth-terms-check-input:focus{outline:none}
.login-modal .auth-terms-check-ui{
  position:absolute;
  inset:0;
  border-radius:6px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.05);
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;
}
.login-modal .auth-terms-check-label:hover .auth-terms-check-ui{border-color:rgba(255,255,255,.22)}
/* Checked: solid purple (web-app style), dark thick tick */
.login-modal .auth-terms-check-input:checked + .auth-terms-check-ui{
  background:#a855f7;
  border-color:rgba(126,34,206,.85);
}
.login-modal .auth-terms-check-input:checked + .auth-terms-check-ui::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:11px;
  height:11px;
  transform:translate(-50%,-50%);
  background:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M5%2013l4%204L19%207%22%20stroke%3D%22%2314141a%22%20stroke-width%3D%222.8%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22/%3E%3C%2Fsvg%3E") center / contain no-repeat;
  box-sizing:border-box;
  pointer-events:none;
}
.login-modal .auth-terms-check-input:focus-visible + .auth-terms-check-ui{
  box-shadow:0 0 0 2px rgba(240,106,255,.4),0 0 0 5px rgba(240,106,255,.12);
}
.login-modal .auth-terms-row.is-warn .auth-terms-check-ui{
  border-color:rgba(248,113,113,.8);
  box-shadow:0 0 0 3px rgba(239,68,68,.28);
}
.login-modal .auth-terms-row.is-warn .auth-terms-check-input:focus-visible + .auth-terms-check-ui{
  box-shadow:0 0 0 2px rgba(248,113,113,.5),0 0 0 5px rgba(239,68,68,.15);
}
.login-modal .auth-terms-row-text{font-size:11px;color:rgba(138,138,158,1)}
.login-modal .auth-terms-row-text label{cursor:pointer;color:rgba(138,138,158,1)}
.login-modal .auth-terms-row-text a{color:rgba(138,138,158,1);text-decoration:underline;text-underline-offset:2px}
.login-modal .auth-terms-row-text a:hover{color:rgba(180,180,200,1)}
.login-modal .auth-terms-hint{margin-top:8px;font-size:11px;font-weight:600;color:#fca5a5;line-height:1.45}

.login-modal .form{display:flex;flex-direction:column;gap:11px}
.login-modal .field{display:flex;flex-direction:column;gap:5px}
.login-modal .field label{font-size:10.5px;font-weight:700;color:rgba(69,69,90,1);letter-spacing:.8px;text-transform:uppercase}
.login-modal .input-wrap{position:relative}
.login-modal .input-wrap input{width:100%;padding:11px 13px;background:rgba(20,20,25,1);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#f4f4f6;font-size:13.5px;outline:none}
.login-modal .input-wrap input:focus{border-color:rgba(240,106,255,.3);box-shadow:0 0 0 3px rgba(240,106,255,.06)}
.login-modal input[type="password"]{padding-right:42px}
.login-modal .eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.10);background:rgba(255,255,255,0.04);color:rgba(244,244,246,0.88);transition:background 150ms ease,color 150ms ease,transform 150ms ease}
.login-modal .eye-btn:hover{background:rgba(255,255,255,0.06);color:rgba(244,244,246,0.96)}

.login-modal .btn-primary-lm{width:100%;padding:13px;background:linear-gradient(135deg,#f06aff,#7ab3ff);border:none;border-radius:11px;color:#fff;font-size:14px;font-weight:700;letter-spacing:-.1px;margin-top:4px;transition:filter 220ms ease,transform 220ms ease,box-shadow 220ms ease;box-shadow:none}
.login-modal .btn-primary-lm:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:none}
.login-modal .btn-primary-lm:active{transform:translateY(0)}

.login-modal .restore-link{text-align:center;font-size:12.5px;font-weight:600;color:rgba(69,69,90,1);cursor:pointer;padding:4px 0;transition:color 150ms ease}
.login-modal .restore-link:hover{color:rgba(138,138,158,1)}

.login-modal .card-footer{margin-top:14px;font-size:11px;color:rgba(69,69,90,1);text-align:center;line-height:1.7}
.login-modal .card-footer a{color:rgba(69,69,90,1);text-decoration:underline;text-underline-offset:2px;transition:color 150ms ease}
.login-modal .card-footer a:hover{color:rgba(138,138,158,1)}

.login-modal__close{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:rgba(244,244,246,0.85);display:flex;align-items:center;justify-content:center;cursor:pointer}
.login-modal__close:hover{background:rgba(255,255,255,.06)}

.login-modal .auth-icon img{width:18px;height:18px;display:block;object-fit:contain}


/* Telegram login widget (matches /login card feel) */
.login-modal .tg-widget{width:100%;max-width:420px;border-radius:24px;padding:16px;border:1px solid rgba(255,255,255,0.10);background:rgba(9,9,13,0.55);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 16px 50px rgba(0,0,0,0.55)}
.login-modal .tg-top{display:flex;align-items:center;gap:12px}
.login-modal .tg-logo{width:32px;height:32px;object-fit:contain;display:block}
.login-modal .tg-title{font-size:16px;font-weight:700;color:#f4f4f6}
.login-modal .tg-sub{font-size:12px;color:rgba(138,138,158,1)}
.login-modal .tg-body{margin-top:12px}
.login-modal .tg-hint{font-size:12.5px;color:rgba(244,244,246,0.88);margin-bottom:8px}
.login-modal .tg-code-row{display:flex;align-items:center;gap:10px}
.login-modal .tg-code{flex:1;display:block;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.25);color:#f4f4f6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.login-modal .tg-copy{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,0.10);background:rgba(255,255,255,0.04);color:rgba(244,244,246,0.9);font-weight:700;font-size:12.5px}
.login-modal .tg-copy:hover{background:rgba(255,255,255,0.06)}
.login-modal .tg-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:stretch;margin-top:12px}
.login-modal .tg-actions .btn-primary-lm{width:100%}
.login-modal .tg-openbot{flex:1;justify-content:center}
.login-modal .tg-status{margin-top:10px;font-size:12px;color:rgba(138,138,158,1)}

.login-modal .tg-qr{margin-top:12px;display:flex;justify-content:center}
.login-modal .tg-qr img{width:180px;height:180px;border-radius:18px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.20)}


/* TG screen (screenshot-like) */
.login-modal .tg-topbar{margin-top:-4px;margin-bottom:10px}
.login-modal .tg-topbar-left{display:flex;align-items:center;gap:10px}
.login-modal .tg-topbar-logo{width:22px;height:22px;object-fit:contain;display:block}
.login-modal .tg-topbar-title{font-size:15px;font-weight:700;color:#f4f4f6;letter-spacing:-0.2px}
.login-modal .tg-topbar-sub{font-size:12px;color:rgba(138,138,158,1)}

.login-modal .tg-qr-card{border-radius:18px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.18);padding:14px}
.login-modal .tg-qr-frame{border-radius:16px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.22);padding:14px;display:flex;align-items:center;justify-content:center}
.login-modal .tg-qr-frame img{width:210px;height:210px;border-radius:16px;background:#fff;display:block}
.login-modal .tg-qr-caption{text-align:center;margin-top:10px;font-size:12px;color:rgba(138,138,158,1)}

.login-modal .tg-primary{margin-top:12px}

.login-modal .tg-bot-card{margin-top:12px;border-radius:18px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.18);padding:14px}
.login-modal .tg-bot-title{font-size:13px;font-weight:800;color:#f4f4f6;margin-bottom:6px}
.login-modal .tg-bot-sub{font-size:12px;color:rgba(138,138,158,1);margin-bottom:10px}

.login-modal .tg-cmd-row{display:flex;align-items:center;gap:10px}
.login-modal .tg-cmd{flex:1;display:block;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,0.10);background:rgba(0,0,0,0.22);color:#f4f4f6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.login-modal .tg-timer{font-size:12px;color:rgba(138,138,158,1);min-width:40px;text-align:right}
.login-modal .tg-copy{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,0.10);background:rgba(255,255,255,0.04);color:rgba(244,244,246,0.9);font-weight:700;font-size:12.5px}
.login-modal .tg-copy:hover{background:rgba(255,255,255,0.06)}

.login-modal .tg-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:stretch;margin-top:12px}
.login-modal .tg-actions .btn-primary-lm{width:100%;padding:12px}


/* TG button skin */
.login-modal #screen-tg .btn-primary-lm,
.login-modal #screen-tg .tg-copy{
  box-shadow:none;
}
.login-modal #screen-tg .btn-primary-lm{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  color:rgba(244,244,246,0.92);
  font-weight:700;
  letter-spacing:0;
}
.login-modal #screen-tg .btn-primary-lm:hover{
  background:rgba(255,255,255,0.06);
  transform:none;
  filter:none;
}
.login-modal #screen-tg .btn-primary-lm:active{transform:none}

.login-modal .tg-qr-frame{padding:12px}
.login-modal .tg-qr-imgwrap{background:#fff;border-radius:18px;padding:10px;display:flex;align-items:center;justify-content:center}
.login-modal .tg-qr-imgwrap img{width:210px;height:210px;border-radius:12px;display:block}

/* Mobile tweaks (added) */
@media (max-width: 820px){
  .login-modal{padding:12px;align-items:center;}
  .login-modal__panel{max-width:100%;}
  .login-modal .card{border-radius:18px;}
  .login-modal .screen{padding:22px 18px 18px;}
  .login-modal__close{top:8px;right:8px;}

  /* Header: move title under back button */
  .login-modal .card-header{flex-wrap:wrap !important;row-gap:6px;margin-bottom:14px}
  .login-modal .card-header .card-title{flex:0 0 100% !important;max-width:100% !important;order:2 !important;text-align:center;margin:0 auto}
  .login-modal .card-header .btn-back{order:1 !important}
}

/* Email auth helpers */
.login-modal .lm-msg{font-size:12px;line-height:1.5;color:rgba(231,231,238,.92);padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06)}
.login-modal .lm-msg.error{color:#fecaca;border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.10)}

.login-modal .btn-secondary-lm{
  width:100%;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:rgba(231,231,238,.92);
  font-weight:700;
  cursor:pointer;
}
.login-modal .btn-secondary-lm:hover{background:rgba(255,255,255,.07)}
.login-modal .btn-secondary-lm:active{transform:translateY(1px)}

/* Email buttons: match TG style on main site login modal */
.login-modal #screen-email .btn-primary-lm,
.login-modal #screen-email .btn-primary-lm.tg-primary{
  box-shadow:none;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  color:rgba(244,244,246,0.92);
  font-weight:700;
  letter-spacing:0;
}
.login-modal #screen-email .btn-primary-lm:hover{
  background:rgba(255,255,255,0.06);
  transform:none;
  filter:none;
}
.login-modal #screen-email .btn-primary-lm:active{transform:none}
.login-modal .eye-btn:active{transform:translateY(-50%) scale(0.98)}

/* Full-screen idle state after 10 min (same UX as app.zaryabot.com) */
html.login-modal-open,
html.login-modal-idle-open{
  overflow:hidden;
}
.login-modal-idle-overlay{
  position:fixed;
  inset:0;
  z-index:1600;
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  padding:24px;
  text-align:center;
  background:#090a10;
  box-sizing:border-box;
}
.login-modal-idle-overlay.is-visible{
  display:flex;
}
.login-modal-idle-overlay p{
  max-width:320px;
  margin:0;
  font-size:14px;
  line-height:1.6;
  color:rgba(212,212,216,.95);
}
.login-modal-idle-btn{
  margin:0;
  padding:12px 24px;
  border:none;
  border-radius:12px;
  font-size:14px;
  font-weight:700;
  color:#fff;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  cursor:pointer;
  font-family:inherit;
  transition:filter .15s ease,transform .15s ease;
}
.login-modal-idle-btn:hover{
  filter:brightness(1.06);
}
.login-modal-idle-btn:active{
  transform:translateY(1px);
}
