/* ============================================================
   CloudTV — Minimal Focus login skin
   Drop-in override. Loaded LAST, after cloudtv-mobile.css.
   All rules are scoped to #login and use !important only where
   needed to beat the existing cloudtv-netflix.css login rules.
   Display/visibility of #login itself is left to the existing
   stylesheet + app.js (which toggles #login style.display), so the
   hide-on-sign-in guard keeps working — the panel self-centers.
   ============================================================ */

#login{
  --c:#ff2e43;
  --cglow:rgba(255,46,67,.42);
  background:radial-gradient(120% 85% at 50% -8%, #16121b 0%, #09090d 55%, #050507 100%) !important;
  font-family:Inter,"Segoe UI",Arial,sans-serif;
}
#login .loginWall, #login .loginScrim{ display:none !important; }

/* Plumbing kept in the DOM for app.js compatibility, hidden from the minimal
   surface. #serverInput (in #customServerGroup) and #proxyInput (in
   .connectionDetails) stay in the DOM because login() reads them directly. */
#login .loginModeTabs,
#login .loginAlt,
#login #customServerGroup,
#login .serverSegRow,
#login .loginCustomLink,
#login .connectionDetails,
#login .loginRememberRow{ display:none !important; }

/* panel — self-centers regardless of #login's display (app.js sets it to
   block on logout), so the card stays vertically centered. */
#login .loginPanel{
  position:relative; z-index:2; width:100%; max-width:380px;
  margin:0 auto; min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:max(40px, env(safe-area-inset-top)) 30px calc(34px + env(safe-area-inset-bottom));
}

/* brand */
#login .loginBrandBlock{ text-align:center; margin-bottom:30px; }
#login .loginLogoTile{
  width:56px; height:56px; border-radius:16px; margin:0 auto 16px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg, var(--c), #7a1020);
  box-shadow:0 10px 26px var(--cglow);
}
#login .loginLogoTile svg{ width:24px; height:24px; color:#fff; margin-left:2px; }
#login .loginBrand{
  font-family:Inter,"Segoe UI",Arial,sans-serif; font-weight:800; font-size:28px;
  letter-spacing:-.025em; color:#eef1f7; text-shadow:none;
}
#login .loginBrand span{ color:var(--c); }
#login .loginTagline{
  color:#98a1b3; font-size:13.5px; font-weight:500; margin-top:8px; text-shadow:none;
}

/* field labels */
#login .fieldGroup{ margin-bottom:22px !important; }
#login .fieldLabel{
  font-family:Inter,"Segoe UI",Arial,sans-serif; font-size:10.5px !important; font-weight:700 !important;
  letter-spacing:.08em !important; text-transform:uppercase; color:#98a1b3 !important; margin-bottom:9px !important;
}

/* underlined inputs + select */
#login input, #login select{
  width:100%; background:transparent !important; border:0 !important;
  border-bottom:1.5px solid rgba(255,255,255,.10) !important; border-radius:0 !important;
  min-height:0 !important; padding:10px 2px !important; font-size:16px !important;
  color:#fff !important; box-shadow:none !important; font-family:inherit;
}
#login input:focus, #login select:focus{
  border-bottom-color:var(--c) !important; box-shadow:0 1px 0 0 var(--c) !important; outline:none !important;
}
#login input::placeholder{ color:rgba(255,255,255,.4); }

/* service dropdown (native select, styled) */
#login .loginSelectWrap{ position:relative; }
#login .loginSelect{ -webkit-appearance:none; appearance:none; padding-right:24px !important; cursor:pointer; }
#login .loginSelectChev{
  position:absolute; right:2px; top:50%; transform:translateY(-50%);
  color:#98a1b3; font-size:13px; pointer-events:none;
}
#login select option{ background:#16161d; color:#fff; }

/* password row + reveal */
#login .passwordField{
  display:flex !important; align-items:center; gap:8px;
  border-bottom:1.5px solid var(--c) !important; box-shadow:0 1px 0 0 var(--c);
}
#login .passwordField input{ flex:1; min-width:0; border-bottom:0 !important; box-shadow:none !important; }
#login .passwordToggle{
  flex:0 0 auto; width:auto !important; min-height:0 !important;
  background:transparent !important; border:0 !important; color:#98a1b3 !important; padding:2px !important;
}
#login .passwordToggle svg{ width:20px; height:20px; }
#login .passwordToggle.revealed{ color:var(--c) !important; border:0 !important; }

/* remember (compact check) */
#login .loginRemember{
  display:flex !important; align-items:center; justify-content:center; gap:10px;
  margin:2px 0 0 !important; color:#c4c9d4 !important; font-size:12.5px !important; font-weight:500 !important; cursor:pointer;
}
#login .loginRemember input[type="checkbox"]{
  appearance:none; -webkit-appearance:none; width:18px !important; height:18px !important; min-height:0 !important; flex:0 0 auto;
  border-radius:6px !important; border:1.5px solid rgba(255,255,255,.2) !important; background:transparent !important;
  padding:0 !important; margin:0 !important; position:relative; cursor:pointer;
}
/* Fully override the netflix toggle-switch knob (::after) so this reads as a
   square check, not a round white toggle. */
#login .loginRemember input[type="checkbox"]::after{
  content:none !important; position:static !important; width:auto !important; height:auto !important;
  background:transparent !important; border-radius:0 !important; transform:none !important;
}
#login .loginRemember input[type="checkbox"]:checked{ background:var(--c) !important; border-color:var(--c) !important; }
#login .loginRemember input[type="checkbox"]:checked::after{
  content:"✓" !important; position:absolute !important; inset:0 !important; transform:none !important;
  width:auto !important; height:auto !important; background:transparent !important; border-radius:0 !important;
  display:flex !important; align-items:center; justify-content:center;
  color:#fff !important; font-size:11px; font-weight:900;
}

/* CTA */
#login #loginButton{
  width:100%; min-height:52px; margin-top:24px;
  background:var(--c) !important; color:#fff !important; border:0 !important; border-radius:999px !important;
  font-family:Inter,"Segoe UI",Arial,sans-serif; font-weight:800 !important; font-size:15px !important; letter-spacing:0;
  box-shadow:0 12px 30px var(--cglow) !important; cursor:pointer;
}
#login #loginButton::before{ content:none !important; }
#login #loginButton:hover{ filter:brightness(1.05); }
#login #loginButton:disabled{ opacity:.7; }

/* help / whatsapp */
#login .loginHelp{ text-align:center; margin-top:18px; color:#98a1b3; font-size:12.5px; font-weight:500; }
#login .loginWhatsApp{ color:#fff; font-weight:700; text-decoration:none; }
#login .loginWhatsApp:hover{ color:var(--c); }

/* Profiles — a quiet secondary action under the help line (switch saved logins) */
#login .loginProfilesLink{
  display:block; margin:14px auto 0; padding:6px 10px; background:transparent !important;
  border:0 !important; min-height:0 !important; width:auto !important; cursor:pointer;
  color:#c4c9d4 !important; font-size:12.5px; font-weight:600; font-family:inherit;
}
#login .loginProfilesLink:hover{ color:#fff !important; }

/* error / status message */
#login #loginMessage{
  margin-top:14px !important; border:0 !important; text-align:center; font-size:13px; font-weight:600;
  background:color-mix(in srgb, var(--c) 13%, transparent) !important; color:#ffb9bf !important;
  border-radius:11px !important; padding:11px 14px !important;
}
#login #loginMessage:empty{ display:none !important; }
