:root {
  /* Core palette from your original login.css */
  --main-color: #cab273;            /* gold */
  --main-light-color: #fffbf0;      /* light ivory */
  --secondary-color: #551756;       /* royal plum */

  /* Page/background */
  --page-bg: #faf6f2;

  /* Buttons */
  --button-gradient: linear-gradient(90deg, var(--main-color) 0%, var(--secondary-color) 100%);
  --btn-hover-bg: #473628;          /* dark cocoa on hover */
  --button-text: #fffbe8;

  /* Inputs & tints */
  --field-bg: rgba(255,255,255,0.93);
  --field-border: #cab27370;        /* semi-transparent gold */
  --placeholder-color: #b9a779;     /* muted gold */
  --gold-shadow: #cab27340;
  --gold-shadow-soft: #cab27325;
  --gold-shadow-inset: #cab27322;
  --neutral-border: #ccc;

  /* Background shape colors */
  --shape-a: #f8ecd7;
  --shape-b: #e6e6e6;
  --shape-c: #f2e5bc;
  --shape-d: #e9e6df;

  /* Banner */
  --banner-bg: var(--secondary-color);
  --banner-text: #fffbe8;

  /* Backup/soft borders + focus */
  --soft-border: #e8dcc4;
  --focus-border: #c6a65b;
  --focus-glow: rgba(198,166,91,.2);

  /* Errors */
  --error: #a23a3a;
  --error-strong: #c62828;
}

/* ================================ Reset ================================ */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Work Sans', sans-serif;
}

body {
  min-height: 100vh;
  background: var(--page-bg);
}

.container {
  position: absolute;
  width: 100vw;
  height: 100vh;
  left: 0;
  top: 0;
  overflow: hidden;
  cursor: default;
}

/* ===================== Static background shapes ===================== */
.top:before,
.top:after,
.bottom:before,
.bottom:after {
  content: "";
  display: block;
  position: absolute;
  width: 200vmax;
  height: 200vmax;
  top: 50%;
  left: 50%;
  margin-top: -100vmax;
  margin-left: -100vmax;
  transform-origin: -200px 50%;
  z-index: 10;
  opacity: 0.65;
}
.top:before  { transform: rotate(45deg);  background: var(--shape-a); }
.top:after   { transform: rotate(135deg); background: var(--shape-b); }
.bottom:before{transform: rotate(-45deg); background: var(--shape-c); }
.bottom:after{ transform: rotate(-135deg); background: var(--shape-d); }

/* ============================= Center card ============================= */
.center {
  position: absolute;
  width: 400px;
  max-width: 95vw;
  height: 400px;
  top: 50%;
  left: 50%;
  margin-left: -200px;
  margin-top: -200px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 30px;
  color: var(--secondary-color);
  opacity: 1;
  pointer-events: auto;
  z-index: 20;
}
.center h2 {
  margin: 0 0 24px 0;
  font-weight: 700;
  letter-spacing: 1px;
  font-size: 1.72rem;
  color: var(--main-color);
  text-align: center;
  background: none;
  box-shadow: none;
}

/* =========================== Input Group =========================== */
.input-group {
  position: relative;
  width: 100%;
  margin: 9px 0;
  display: flex;
  align-items: center;
}
.input-group .input-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  color: var(--main-color);
  font-size: 1.3rem;
  pointer-events: none;
  transition: color 0.2s, filter 0.2s;
}
.input-group input {
  width: 100%;
  height: 48px;
  padding-left: 44px !important;
  padding-right: 54px !important;
  border-radius: 12px;
  border: 1.2px solid var(--field-border);
  font-size: 1.08rem;
  outline: none;
  color: var(--secondary-color);
  background: var(--field-bg);
  transition: border-color 0.18s;
  margin: 0;
  line-height: 1.18;
  box-sizing: border-box;
}
.input-group input:focus { border-color: var(--main-color); }
.input-group input:focus ~ .input-icon i {
  color: var(--placeholder-color);
  filter: drop-shadow(0 0 6px var(--gold-shadow));
}

.eye-wrapper {
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  display: flex;
  align-items: center;
}
.eye-icon {
  color: var(--placeholder-color);
  font-size: 1.34rem;
  cursor: pointer;
  transition: color 0.18s;
}
.eye-icon:hover,
.eye-icon:focus {
  color: var(--secondary-color);
  filter: drop-shadow(0 0 5px var(--gold-shadow));
}
.input-group input:focus ~ .eye-wrapper .eye-icon { color: var(--main-color); }

/* =============================== Button =============================== */
.center button {
  width: 100%;
  padding: 14px 0;
  border-radius: 22px;
  border: none;
  background: var(--main-color);
  color: var(--button-text);
  font-size: 1.13rem;
  font-weight: 700;
  cursor: pointer;
  margin: 20px 0 5px 0;
  box-shadow: 0 4px 22px var(--gold-shadow-soft), 0 2px 0 var(--gold-shadow-inset) inset;
  transition: background 0.16s, transform 0.14s;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 8px var(--gold-shadow);
}
.center button:hover,
.center button:focus {
  background: var(--btn-hover-bg);
  color: white;
  transform: translateY(-2px) scale(1.03);
}

/* ============================= Placeholder ============================= */
::placeholder {
  color: var(--placeholder-color);
  opacity: 1;
  font-size: 1.04rem;
}

/* =============================== Responsive =============================== */
@media (max-width: 480px) {
  .center {
    width: 96vw;
    margin-left: -48vw;
    padding: 10px 5vw 16px 5vw;
  }
  .center h2 { font-size: 1.25rem; }
  .center button { font-size: 1.03rem; padding: 12px 0; }
  .input-group input {
    font-size: 1rem;
    height: 44px;
    padding-left: 44px !important;
    padding-right: 48px !important;
  }
}

/* ================================ Logo ================================ */
.login-logo {
  width: 58px;
  height: 58px;
  margin-bottom: 10px;
  margin-top: -10px;
  object-fit: contain;
  border-radius: 12px;
}

/* =========================== Location select =========================== */
.location-select {
  width: 100%;
  height: 48px;
  padding-left: 44px !important;
  padding-right: 20px !important;
  border-radius: 12px;
  border: 1.2px solid var(--field-border);
  font-size: 1.08rem;
  outline: none;
  color: var(--secondary-color);
  background: var(--field-bg);
  appearance: none;
  -webkit-appearance: none;
  /* caret uses encoded #cab273 (gold) */
  background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg width='14' height='10' viewBox='0 0 14 10' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23cab273' d='M7 10L0 0h14z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 14px;
}
.location-select:focus { border-color: var(--main-color); }

/* ================================ Banner ================================ */
.location-banner {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--banner-bg);
  color: var(--banner-text);
  padding: 14px 24px;
  border-radius: 16px;
  font-size: 1rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  z-index: 9999;
}
.location-banner.show { opacity: 1; pointer-events: auto; }
.location-banner.hidden { opacity: 0; pointer-events: none; }

/* =============================== OTP Card =============================== */
.otp-card {
  width: 90vw;
  max-width: 400px;
  padding: 30px;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.05);
  text-align: center;
  color: var(--secondary-color);
  margin: 0;
  background: #fff;
}
.otp-card h2 {
  margin-bottom: 16px;
  font-size: 1.6rem;
  color: var(--main-color);
}
.otp-card p { margin-bottom: 16px; }
.otp-card .masked-email {
  font-size: 0.95rem;
  color: var(--secondary-color);
  margin-bottom: 8px;
}

/* ====================== OTP inputs & buttons ====================== */
.otp-card input#otp-input {
  width: 80%;
  max-width: 250px;
  padding: 12px;
  font-size: 1.25rem;
  text-align: center;
  border: 1px solid var(--neutral-border);
  border-radius: 6px;
  margin-bottom: 16px;
}
.otp-card button {
  display: block;
  margin: 12px auto;
  padding: 10px 24px;
  font-size: 1rem;
  border: none;
  border-radius: 6px;
  background: var(--main-color);
  color: var(--main-light-color);
  cursor: pointer;
  transition: transform .1s;
}
.otp-card button:hover:not(:disabled) { transform: translateY(-2px); }

/* ======================== Countdown & resend ======================== */
#countdown {
  font-size: .95rem;
  color: var(--secondary-color);
  margin-top: 8px;
}
#resend-btn {
  background: none;
  color: var(--main-color);
  font-size: .95rem;
  opacity: .6;
}
#resend-btn:disabled { opacity: .3; cursor: default; }
#resend-btn:not(:disabled):hover { text-decoration: underline; opacity: 1; }

/* ======================= Full-screen flex wrapper ======================= */
#otp-area {
  position: absolute;
  top: 0; left: 0;
  width: 100vw; height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 30;
  pointer-events: none;
}
#otp-area .otp-card { pointer-events: auto; }

/* ================================ Phones ================================ */
@media (max-width: 480px) {
  .otp-card {
    width: 100vw;
    max-width: none;
    padding: 20px;
  }
  .otp-card input#otp-input,
  .otp-card button {
    width: 100%;
    max-width: none;
    margin: 8px 0;
    padding: 12px 0;
  }
  #countdown,
  .otp-card .masked-email { font-size: 0.9rem; }
}

/* ============================ Small tablets ============================ */
@media (min-width: 481px) and (max-width: 768px) {
  .otp-card { width: 80vw; padding: 25px; }
  .otp-card input#otp-input { width: 100%; }
  .otp-card button { width: 80%; }
}

/* ====================== iPads & medium desktops ====================== */
@media (min-width: 769px) and (max-width: 1200px) {
  .otp-card { width: 60vw; max-width: 600px; padding: 32px; }
  .otp-card input#otp-input { width: 100%; max-width: none; }
  .otp-card button { width: 60%; }
}

/* ====================== Segmented inputs container ====================== */
.segmented-inputs {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 12px 0;
}
.otp-segment {
  width: 2em;
  height: 2.5em;
  font-size: 1.5rem;
  text-align: center;
  border: 1px solid var(--neutral-border);
  border-radius: 6px;
}

/* ============================ Inline error ============================ */
.error-msg {
  color: var(--error-strong);
  font-size: 0.9rem;
  min-height: 1.2em;
  margin-bottom: 8px;
}

/* ========================== Attempts counter ========================== */
#attempts-info {
  font-size: 0.85rem;
  color: var(--secondary-color);
  margin-bottom: 8px;
}

/* ===================== Loading state (optional) ===================== */
#verify-otp-btn[disabled] { opacity: .6; cursor: default; }

/* ======================= Backup code UI polish ======================= */
.method-chooser button { min-width: 220px; }
.twofa-panel { margin-top: 12px; display: grid; gap: 10px; }
.field-label { font-weight: 600; opacity: .9; }
.backup-input {
  width: 260px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 600;
  background: #fffdfa;
  border: 2px solid var(--soft-border);
  border-radius: 10px;
  padding: 10px 12px;
  outline: none;
}
.backup-input:focus {
  border-color: var(--focus-border);
  box-shadow: 0 0 0 3px var(--focus-glow);
}

.action-btn {
  background: var(--focus-border);
  color: #fff;
  border: none;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
}
.action-btn:disabled { opacity: .6; cursor: not-allowed; }

.attempts { opacity: .7; margin: 0; }

/* ============================ Center helpers ============================ */
.method-chooser{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  flex-direction:column;
}
.twofa-panel{
  margin-top:12px;
  display:grid;
  gap:10px;
  justify-items:center;
  text-align:center;
}
.backup-input{ margin:0 auto; width:260px; }



/* =========================
   Animations – drop-in pack
   ========================= */

:root{
  --anim-in: .7s;
  --anim-ease: cubic-bezier(.2,.8,.2,1);
}

/* 1) Page-load fade/slide-in */
@keyframes fadeUp {
  from { opacity: 0; transform: translate3d(0, 12px, 0) scale(.98); }
  to   { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
}

.center { animation: fadeUp var(--anim-in) var(--anim-ease) .05s both; }
.center .input-group:nth-of-type(1) { animation: fadeUp var(--anim-in) var(--anim-ease) .15s both; }
.center .input-group:nth-of-type(2) { animation: fadeUp var(--anim-in) var(--anim-ease) .28s both; }
/* if your select isn't inside an .input-group, this still catches it */
.center .location-select { animation: fadeUp var(--anim-in) var(--anim-ease) .41s both; }
.center > button { animation: fadeUp var(--anim-in) var(--anim-ease) .54s both; }

/* 2) Gentle background drift (very slow, subtle) */
@keyframes driftA {
  0%,100% { transform: rotate(45deg) translate3d(0,0,0) scale(1); }
  50%     { transform: rotate(43deg) translate3d(30px,-20px,0) scale(1.02); }
}
@keyframes driftB {
  0%,100% { transform: rotate(135deg) translate3d(0,0,0) scale(1); }
  50%     { transform: rotate(138deg) translate3d(-24px,18px,0) scale(1.015); }
}
@keyframes driftC {
  0%,100% { transform: rotate(-45deg) translate3d(0,0,0) scale(1); }
  50%     { transform: rotate(-47deg) translate3d(26px,16px,0) scale(1.02); }
}
@keyframes driftD {
  0%,100% { transform: rotate(-135deg) translate3d(0,0,0) scale(1); }
  50%     { transform: rotate(-132deg) translate3d(-28px,-16px,0) scale(1.01); }
}

.top:before    { animation: driftA 48s ease-in-out infinite; }
.top:after     { animation: driftB 56s ease-in-out infinite; }
.bottom:before { animation: driftC 54s ease-in-out infinite; }
.bottom:after  { animation: driftD 62s ease-in-out infinite; }

/* 3) Button sheen on hover */
.center > button{ position: relative; overflow: hidden; }
.center > button::after{
  content:"";
  position:absolute; top:0; bottom:0;
  width:32%;
  left:-120%;
  transform: skewX(-20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.45), transparent);
  pointer-events:none;
}
.center > button:hover::after{ animation: sheen .9s ease; }
@keyframes sheen { from{ left:-120%; } to{ left:140%; } }

/* 4) Subtle focus pulse when a field gains focus */
@keyframes ringPulse {
  0%   { box-shadow: 0 0 0 0 var(--focus-glow); }
  100% { box-shadow: 0 0 0 10px transparent; }
}
.input-group input:focus,
.location-select:focus {
  animation: ringPulse 1.1s ease-out 1;
}

/* 5) Optional error shake utility (add/remove the .shake class via JS) */
@keyframes shakeX {
  0%,100%{ transform: translateX(0); }
  15%    { transform: translateX(-8px); }
  30%    { transform: translateX(7px); }
  45%    { transform: translateX(-6px); }
  60%    { transform: translateX(5px); }
  75%    { transform: translateX(-3px); }
  90%    { transform: translateX(2px); }
}
.shake { animation: shakeX .55s cubic-bezier(.36,.07,.19,.97); }

/* 6) Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  * { animation: none !important; transition: none !important; }
}


/* ---- Fix: prevent "Sign In" text from being cut ---- */
.center > button{
  /* center the label properly */
  display: inline-flex;
  align-items: center;
  justify-content: center;

  /* use a fixed min-height instead of big vertical padding */
  min-height: 48px;
  padding: 0 20px;

  line-height: 1;          /* avoids baseline clipping */
  position: relative;
  overflow: hidden;        /* keep the sheen inside */
  isolation: isolate;      /* make a stacking context so ::after sits under text */
}

/* keep the sheen below the text */
.center > button::after{
  z-index: 0;
}

/* ======================= Remember me (compact, right) ======================= */
.remember-row{
  width: 100%;
  display: flex;
  justify-content: flex-end;   /* right align */
  align-items: center;
  gap: 6px;
  margin: 4px 2px 0;
  font-size: 0.85rem;          /* small text */
  color: var(--placeholder-color);
  user-select: none;
}

.remember-row input[type="checkbox"]{
  width: 14px;
  height: 14px;                /* smaller box */
  accent-color: var(--main-color); /* nice gold check (modern browsers) */
  cursor: pointer;
  margin: 0;
}

.remember-row span{
  line-height: 1;
}

@media (max-width: 480px){
  .remember-row{
    font-size: 0.8rem;
    margin-top: 2px;
  }
  .remember-row input[type="checkbox"]{
    width: 13px;
    height: 13px;
  }
}
