:root{
 --brand-primary:#0B1F3B;
 --brand-secondary:#1BA6A6;
 --brand-accent:#FFD84D;
 --brand-white:#FFFFFF;
 --page-bg:#f4f6fb;
 --card-border:#e6ebf5;
 --muted:#60708a;
}
html, body { height:100%; }
body {
 min-height:100vh;
 margin:0;
 background:var(--page-bg);
 color:#1f2a44;
 display:flex;
 flex-direction:column;
}

/* Header */
.signup-header{
  width:100%;
  background:var(--brand-white);
  border-bottom:4px solid var(--brand-primary);
 }
.signup-header .inner{
 max-width:1100px;
 margin:0 auto;
 padding:18px 16px;
 display:flex;
 flex-direction:column;
 align-items:center;
 gap:8px;
}
.signup-logo{ height:44px; width:auto; }
.signup-tagline{
 font-size:12px;
 letter-spacing:0.18em;
 text-transform:uppercase;
 color:var(--brand-primary);
 font-weight:700;
 opacity:.85;
}

/* Main */
 main.signup-main{
 flex:1 0 auto;
 width:100%;
 padding:28px 0;
}
.signup-shell{
 max-width:1100px;
 margin:0 auto;
 padding:0 16px;
}

.signup-card{
 width:100%;
 border:1px solid var(--card-border);
 border-radius:16px;
 overflow:hidden;
 background:var(--brand-white);
 box-shadow:0 14px 30px rgba(11,31,59,.10);
}

.signup-card-top{
 height:6px;
 background: linear-gradient(90deg, var(--brand-secondary), var(--brand-accent));
}

.signup-card-body{ padding:26px 26px 18px; }
.otp-input { letter-spacing:0.4em; } /* from your original page :contentReference[oaicite:3]{index=3} */
.resend-disabled { pointer-events:none; opacity:0.5; } /* from your original page :contentReference[oaicite:4]{index=4} */

/* Modern touches */
 .form-control{
 border-radius:12px;
 padding:12px;
 border-color:#d9e1f0;
}
.form-control:focus{
  border-color: rgba(27,166,166,.55);
  box-shadow: 0 0 0 .25rem rgba(27,166,166,.18);
}
.btn-primary{
 background:var(--brand-primary);
 border-color:var(--brand-primary);
 border-radius:12px;
 font-weight:700;
 padding:12px 14px;
}
.btn-success{
 background:var(--brand-secondary);
 border-color:var(--brand-secondary);
 border-radius:12px;
 font-weight:700;
 padding:12px 14px;
 color:#fff;
}

/* Footer: full-width + sticky bottom */
.signup-footer{
 margin-top:auto;
 width:100%;
 background:var(--brand-primary);
 color:rgba(255,255,255,.88);
 flex-shrink:0;
}
.signup-footer .inner{
 max-width:1100px;
 margin:0 auto;
 padding:18px 16px;
 display:flex;
 justify-content:space-between;
 flex-wrap:wrap;
 gap:10px;
 font-size:13px;
}
.signup-footer a{
 color:var(--brand-accent);
 font-weight:600;
 text-decoration:none;
}
.signup-footer a:hover{ text-decoration:underline; }

.navbar .nav-link.fw-semibold {
  color: var(--brand-primary);
}

.navbar .nav-link.fw-semibold:hover {
  text-decoration: underline;
}

@media (max-width:576px){
 .signup-card-body{ padding:22px 18px 16px; }
 .signup-footer .inner{ justify-content:center; text-align:center; }
}

/* ================================
   External Website Header / Mobile
================================ */

.signup-header {
  background: #ffffff;
  border-bottom: 1px solid rgba(11, 31, 59, 0.08);
  position: relative;
  z-index: 1000;
}

.signup-header .header-container {
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0.85rem 1rem;
}

.signup-header .navbar {
  padding: 0;
}

.signup-logo {
  max-height: 46px;
  width: auto;
}

.signup-header .navbar-toggler {
  border: 1px solid rgba(11, 31, 59, 0.18);
  border-radius: 10px;
  padding: 0.45rem 0.6rem;
  box-shadow: none;
}

.signup-header .navbar-toggler:focus {
  box-shadow: 0 0 0 0.15rem rgba(255, 193, 7, 0.35);
}

/* Desktop menu */
.signup-header .navbar-nav .nav-link {
  color: #0b1f3b;
  font-weight: 500;
}

.signup-header .navbar-nav .nav-link:hover,
.signup-header .navbar-nav .nav-link:focus {
  color: #0e2c4f;
  text-decoration: none;
}

/* Mobile menu */
@media (max-width: 991.98px) {

  .signup-header .header-container {
    padding: 0.75rem 1rem;
  }

  .signup-header .navbar {
    align-items: center;
  }

  .signup-header .navbar-collapse {
    margin-top: 0.9rem;
    background: #ffffff;
    border: 1px solid rgba(11, 31, 59, 0.10);
    border-radius: 18px;
    box-shadow: 0 18px 40px rgba(15, 35, 60, 0.12);
    padding: 0.75rem;
    overflow: hidden;
  }

  .signup-header .navbar-nav {
    align-items: stretch !important;
    width: 100%;
  }

  .signup-header .nav-item {
    width: 100%;
  }

  .signup-header .navbar-nav .nav-link {
    display: block;
    width: 100%;
    padding: 0.85rem 1rem !important;
    border-radius: 12px;
    color: #0b1f3b;
    font-size: 1rem;
    line-height: 1.25;
  }

  .signup-header .navbar-nav .nav-link:hover,
  .signup-header .navbar-nav .nav-link:focus {
    background: #f6f8fb;
    color: #0b1f3b;
  }

  .signup-header .navbar-nav .nav-link.fw-semibold {
    margin-top: 0.35rem;
    background: #ffc107;
    color: #0b1f3b;
    text-align: center;
  }

  .signup-header .navbar-nav .nav-link.fw-semibold:hover,
  .signup-header .navbar-nav .nav-link.fw-semibold:focus {
    background: #ffca2c;
    color: #0b1f3b;
  }
}

/* Very small phones */
@media (max-width: 420px) {
  .signup-logo {
    max-height: 38px;
  }

  .signup-header .header-container {
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }

  .signup-header .navbar-collapse {
    border-radius: 14px;
  }
}

/* ================================
   Homepage CRM Preview Carousel
================================ */

.dashboard-preview-wrap {
  width: 100%;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  background: transparent;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175);
}

/* Main carousel */
.dashboard-preview-wrap .carousel {
  width: 100%;
  background: transparent;
  border-radius: 1rem;
  overflow: hidden;
}

/* Image area uses exact screenshot ratio: 1988 x 1229 */
.dashboard-preview-wrap .carousel-inner {
  width: 100%;
  aspect-ratio: 1988 / 1229;
  background: transparent;
  border-radius: 1rem 1rem 0 0;
  overflow: hidden;
}

/* Slides fill the exact ratio area */
.dashboard-preview-wrap .carousel-item {
  width: 100%;
  height: 100%;
  background: transparent;
}

/* Bootstrap active / moving slides */
.dashboard-preview-wrap .carousel-item.active,
.dashboard-preview-wrap .carousel-item-next,
.dashboard-preview-wrap .carousel-item-prev {
  display: block;
}

/* Image fills the correctly-proportioned area */
.dashboard-preview-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  border-radius: 1rem 1rem 0 0;
}

/* Dots below image */
.dashboard-preview-wrap .carousel-indicators {
  position: static !important;
  display: flex !important;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin: 0 !important;
  padding: 12px 0 14px 0 !important;
  background: #0B1F3B;
  list-style: none;
  border-radius: 0 0 1rem 1rem;
}

/* Bootstrap 5 dots */
.dashboard-preview-wrap .carousel-indicators button,
.dashboard-preview-wrap .carousel-indicators [data-bs-target] {
  display: block !important;
  width: 11px !important;
  height: 11px !important;
  min-width: 11px !important;
  min-height: 11px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 50% !important;
  background-color: rgba(255, 255, 255, 0.45) !important;
  opacity: 1 !important;
  text-indent: -999px;
  box-sizing: border-box;
}

.dashboard-preview-wrap .carousel-indicators button.active,
.dashboard-preview-wrap .carousel-indicators .active {
  background-color: #ffc107 !important;
}

/* Controls */
.dashboard-preview-wrap .carousel-control-prev,
.dashboard-preview-wrap .carousel-control-next {
  width: 12%;
  top: 0;
  bottom: 39px;
}

.dashboard-preview-wrap .carousel-control-prev-icon,
.dashboard-preview-wrap .carousel-control-next-icon {
  width: 2rem;
  height: 2rem;
  background-size: 65% 65%;
  background-color: rgba(11, 31, 59, 0.55);
  border-radius: 50%;
}

/* Tablet */
@media (max-width: 991.98px) {
  .dashboard-preview-wrap {
    max-width: 680px;
  }
}

/* Mobile */
@media (max-width: 575.98px) {
  .dashboard-preview-wrap {
    max-width: 100%;
    border-radius: 0.85rem;
  }

  .dashboard-preview-wrap .carousel,
  .dashboard-preview-wrap .carousel-inner,
  .dashboard-preview-img {
    border-radius: 0.85rem 0.85rem 0 0;
  }

  .dashboard-preview-wrap .carousel-indicators {
    padding: 10px 0 12px 0 !important;
    border-radius: 0 0 0.85rem 0.85rem;
  }

  .dashboard-preview-wrap .carousel-control-prev,
  .dashboard-preview-wrap .carousel-control-next {
    width: 16%;
    bottom: 37px;
  }
}

