/*
  Public Theme (Simple) - ExpressCronJob-inspired
  ------------------------------------------------
  - Simple navbar
  - Clean cards + buttons
  - Shared by index/pricing/about/contact/resellers/login/signup
*/

:root{
  --pub-bg: #f7f9fc;
  --pub-card: #ffffff;
  --pub-text: #0f172a;
  --pub-muted: #64748b;
  --pub-border: rgba(15,23,42,.10);
  --pub-primary: #2563eb;
  --pub-primary-600: #1d4ed8;
  --pub-radius: 14px;
  --pub-shadow: 0 12px 28px rgba(15,23,42,.07);

  /* Alias legacy variable names (used by auth components) */
  --bg: var(--pub-bg);
  --card: var(--pub-card);
  --text: var(--pub-text);
  --muted: var(--pub-muted);
  --border: var(--pub-border);
  --primary: var(--pub-primary);
  --primary-600: var(--pub-primary-600);
  --radius: var(--pub-radius);
  --shadow: var(--pub-shadow);
}

body{
  background: var(--pub-bg);
  color: var(--pub-text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

/* Navbar */
.gsmpk-public-nav{
  background: #fff;
  border-bottom: 1px solid var(--pub-border);
}

.gsmpk-public-nav .navbar-brand{
  font-weight: 800;
  letter-spacing: .2px;
}

.gsmpk-public-logo{
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.gsmpk-public-nav .nav-link{
  font-weight: 600;
  color: #334155;
  border-radius: 10px;
  padding: .5rem .75rem;
}
.gsmpk-public-nav .nav-link:hover{
  background: rgba(37,99,235,.08);
  color: var(--pub-primary);
}
.gsmpk-public-nav .nav-link.active{
  background: rgba(37,99,235,.12);
  color: var(--pub-primary);
}

/* Hero */
.gsmpk-hero{
  padding: 3.2rem 0 2.2rem;
}

.gsmpk-hero-card{
  background: var(--pub-card);
  border: 1px solid var(--pub-border);
  border-radius: calc(var(--pub-radius) + 4px);
  box-shadow: var(--pub-shadow);
  padding: 2.2rem;
}

.gsmpk-hero h1{
  font-weight: 900;
  letter-spacing: .2px;
}

.gsmpk-muted{
  color: var(--pub-muted) !important;
}

/* Cards */
.gsmpk-card{
  background: var(--pub-card);
  border: 1px solid var(--pub-border);
  border-radius: var(--pub-radius);
  box-shadow: var(--pub-shadow);
}

.gsmpk-icon-box{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(37,99,235,.12);
  color: var(--pub-primary);
}

/* Pricing */
.gsmpk-price{
  font-weight: 900;
  letter-spacing: .2px;
}

/* Footer */
.gsmpk-footer{
  border-top: 1px solid var(--pub-border);
  background: #fff;
  padding: 1.25rem 0;
  margin-top: 3rem;
}

/* Auth pages */
.gsmpk-auth-wrap{
  min-height: calc(100vh - 74px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 2.25rem 1rem;
}

.gsmpk-auth-card{
  max-width: 430px;
  width: 100%;
}

/* Buttons */
.btn{
  border-radius: 12px;
}

.btn-primary{
  background: var(--pub-primary);
  border-color: var(--pub-primary);
}

.btn-primary:hover{
  background: var(--pub-primary-600);
  border-color: var(--pub-primary-600);
}


/* -----------------------------------------------------------------------------
   Auth pages (Login / Signup / Forgot Password)
   Style inspired by modern SaaS split layouts.
----------------------------------------------------------------------------- */
.gsmpk-auth-wrap{
  min-height: calc(100vh - 74px);
  background:
    radial-gradient(1200px 600px at 10% 10%, rgba(37,99,235,.14), transparent 60%),
    radial-gradient(1000px 520px at 90% 20%, rgba(34,197,94,.10), transparent 60%),
    radial-gradient(900px 520px at 30% 90%, rgba(99,102,241,.10), transparent 60%),
    var(--bg);
  padding: 48px 0;
}
.gsmpk-auth-left{
  height: 100%;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 28px;
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(10px);
}
.gsmpk-auth-left h1{
  font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 10px 0;
}
.gsmpk-auth-left .lead{
  color: var(--muted);
  margin-bottom: 18px;
}
.gsmpk-auth-points{
  display: grid;
  gap: 10px;
  margin: 18px 0 0 0;
}
.gsmpk-auth-point{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding: 12px 12px;
  border: 1px solid rgba(15,23,42,.07);
  border-radius: 14px;
  background: rgba(255,255,255,.78);
}
.gsmpk-auth-point i{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(37,99,235,.10);
  color: var(--primary);
  flex: 0 0 auto;
}
.gsmpk-auth-point .t{
  font-weight: 700;
  margin: 0;
}
.gsmpk-auth-point .d{
  margin: 0;
  color: var(--muted);
  font-size: .92rem;
}

.gsmpk-auth-card{
  height: 100%;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 26px;
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
}
.gsmpk-auth-card h2{
  font-weight: 800;
  letter-spacing: -0.02em;
}
.gsmpk-auth-sub{
  color: var(--muted);
  margin-bottom: 14px;
}
.gsmpk-auth-meta{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
  margin-top: 8px;
}
.gsmpk-auth-meta a{
  text-decoration:none;
}
.gsmpk-auth-meta a:hover{
  text-decoration:underline;
}

@media (max-width: 991px){
  .gsmpk-auth-wrap{ padding: 28px 0; }
}



/* -----------------------------------------------------------------------------
   OTP UI helpers (Reset OTP / 2FA)
----------------------------------------------------------------------------- */
.otp-meta{
  display:flex;
  justify-content:center;
  gap: 10px;
  margin: 10px 0 14px;
  flex-wrap: wrap;
}
.meta-pill{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.9);
  padding: 8px 10px;
  border-radius: 999px;
  font-size: .9rem;
  color: var(--muted);
}
.otp-inputs{
  display:flex;
  gap: 10px;
  justify-content:center;
  margin: 12px 0 8px;
}
.otp-input{
  width: 48px;
  height: 56px;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 12px;
  text-align:center;
  font-size: 1.45rem;
  font-weight: 800;
  outline:none;
  background:#fff;
}
.otp-input:focus{
  border-color: rgba(37,99,235,.7);
  box-shadow: 0 0 0 4px rgba(37,99,235,.12);
}
.help-text{
  text-align:center;
  color: var(--muted);
  font-size: .92rem;
  margin-top: 4px;
}
.divider{
  height:1px;
  background: rgba(15,23,42,.10);
  margin: 16px 0;
}
.resend-hint{
  text-align:center;
  color: var(--muted);
  font-size: .92rem;
  margin-top: 10px;
}
.footer-links{
  display:flex;
  justify-content:center;
  gap: 14px;
  margin-top: 12px;
  font-size: .95rem;
}
.footer-links a{
  text-decoration:none;
}
.footer-links a:hover{ text-decoration:underline; }

@media (max-width: 420px){
  .otp-input{ width: 42px; height: 52px; }
  .otp-inputs{ gap: 8px; }
}



/* Password requirement helper (Reset Password) */
.password-requirements{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.9);
  border-radius: 14px;
  padding: 14px 14px;
  margin-bottom: 14px;
  font-size: .92rem;
}
.password-requirements h4{
  font-size: 1rem;
  font-weight: 800;
  margin: 0 0 8px 0;
}
.password-requirements ul{
  list-style: none;
  padding-left: 0;
  margin: 0;
}
.password-requirements li{
  display:flex;
  gap: 8px;
  align-items:center;
  margin: 6px 0;
}
.requirement-met{ color: var(--bs-success); }
.requirement-unmet{ color: var(--muted); }

