@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,400;0,500;0,700;1,300&display=swap");

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

html {
  font-size: 16px;
  color: #000000;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: "Montserrat", sans-serif;
  background: #ffffff;
  color: #000000;
  font-size: 15px;
  background: #fff;
  line-height: 28px;
}

a,
a:hover {
  color: #000;
  text-decoration: none;
}

header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 4;
}

.top-banner {
  margin-bottom: 5rem;
  margin-top: 120px;
}

.top-banner p {
  font-size: 20px;
  font-weight: 500;
}

.head01 {
  font-size: 36px;
  line-height: 44px;
  font-weight: bold;
  margin-bottom: 2rem;
}

.trademark {
  font-size: 0.6em;
  vertical-align: super;
}

.top-banner,
.aboutus,
.key-features,
.manufacturing-revolution-sec,
.default-section {
  padding-left: 5rem;
  padding-right: 5rem;
  margin-bottom: 3rem;
}

.default-section {
  padding-top: 3rem;
}

.bg-grey {
  background: #fafafa;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.top-banner {
  background: rgba(204, 221, 255, 0.1);
}

.navbar-light {
  padding-left: 5rem;
  padding-right: 5rem;
  background: #ffffff 0% 0% no-repeat padding-box;
  /* box-shadow: 0px 3px 6px #00000029; */
  padding-top: 1rem;
}

.nav-link {
  color: rgba(0, 0, 0, 0.85);
  font-weight: 500;
  padding: 0 1rem;
}

.nav-link:hover {
  color: #2848C8;
}

.navbar-expand-md .navbar-collapse {
  flex-grow: inherit;
}

main {
  margin: 90px 0 50px;
}

.banner-content h2 {
  font-size: 28px;
  line-height: 30px;
  font-weight: 700;
  margin-bottom: 1rem;
}

.key-features-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: 2rem;
}

.key-features-item h4 {
  font-weight: bold;
}

.manufacturing-revolution {
  background: url(../assets/images/bg-blue.svg) no-repeat center center;
  background-size: cover;
  /* Ensures full coverage without cutting */
  text-align: center;
  color: #fff;
  padding: 2rem;
  min-height: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border-radius: 15px;
}

.manufacturing-revolution p {
  padding: 0 7rem;
}

.manufacturing-revolution h2 {
  font-size: 36px;
  line-height: 44px;
  font-weight: bold;
  margin-bottom: 2rem;
  margin-top: 1rem;
}

.manufacturing-revolution p {
  margin-bottom: 1rem;
}

footer {
  background: #212121;
  padding: 3rem 5rem;
  color: #fff;
}

footer a {
  color: #fff;
}

footer a:hover {
  color: #fff;
  text-decoration: underline;
}

footer h3 {
  font-size: 35px;
  line-height: 44px;
  font-weight: bold;
  margin-bottom: 2rem;
}

footer h4 {
  font-size: 20px;
  line-height: 30px;
  font-weight: bold;
  margin-bottom: 0.5rem;
}

footer .footer-link ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

footer .learn-more {
  margin-bottom: 5rem;
}

footer .copyright {
  font-size: 12px;
  line-height: 15px;
  font-weight: 500;
  border-top: 1px solid #fff;
  margin: 1rem 0 1rem 0;
  padding-top: 1rem;
  text-align: right;
}

.privacy-policy-list {
  font-weight: 500;
}

.privacy-policy-list>ol>li,
.privacy-policy-list ol .first {
  font-weight: 700;
}

.privacy-policy-list>ol>li>ol>li,
.privacy-policy-list>ol>li p,
.privacy-policy-list ol>li>ol>li,
.privacy-policy-list ol .first p {
  font-weight: 500;
}

.privacy-policy-list h3 {
  font-weight: 700;
  font-size: 20px;
}

.privacy-policy-list ol {
  counter-reset: item;
}

.privacy-policy-list ol>li {
  display: block;
  margin-bottom: 1rem;
}

.privacy-policy-list ol>li:before {
  content: counters(item, ".") " ";
  counter-increment: item
}

.privacy-policy-list ol>li>p {
  margin-top: 1rem;
}

.privacy-policy-list ol>li>ol {
  margin-top: 1rem;
  margin-left: 2rem;
}
.privacy-policy-list ol>li strong {
  font-weight: bold;
}


.custom-lower-roman ul {
  list-style-type: lower-roman !important;
  padding-left: 2rem;
  font-weight: 500;
}

.custom-lower-alpha ul {
  list-style-type: lower-alpha !important;
  padding-left: 2rem;
  font-weight: 500;
}

@media only screen and (min-width: 768px) {}

@media only screen and (max-width: 1023px) {
  .manufacturing-revolution p {
    padding: 0 1rem;
  }
}

@media only screen and (max-width: 768px) {
  body {
    font-size: 14px;
    line-height: 20px;
  }

  .navbar-light {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  .aboutus {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  .navbar-light .container-fluid {
    display: flex;
  }

  .navbar-expand-md .navbar-collapse {
    flex-grow: unset;
    flex-basis: content;
  }

  .navbar-brand img {
    width: 165px;
  }

  .banner-content ul li {
    margin-bottom: 15px;
  }

  footer {
    padding: 2rem 0.5rem 1rem;
  }

  .top-banner,
  .aboutus,
  .key-features,
  .manufacturing-revolution-sec,
  .default-section {
    padding-left: 1rem;
    padding-right: 1rem;
    margin-bottom: 1rem;
  }

  .top-banner p {
    font-size: 18px;
    font-weight: 500;
    line-height: 25px;
  }

  .head01 {
    font-size: 28px;
    line-height: 35px;
    font-weight: bold;
    margin-bottom: 1rem;
  }

  .manufacturing-revolution {
    background-size: auto;
    min-height: auto;
    padding: 2rem 1rem;
  }

  .manufacturing-revolution h2 {
    font-size: 25px;
    line-height: 32px;
    font-weight: bold;
    margin-bottom: 1rem;
    margin-top: 1rem;
  }

  .manufacturing-revolution p {
    padding: 0;
  }

  footer .learn-more {
    margin-bottom: 2rem;
  }

  footer .footer-link {
    margin-top: 2rem;
  }

  footer h3 {
    font-size: 28px;
    line-height: 35px;
  }

  .navbar-light {
    padding-top: 1rem;
  }

  footer h4 {
    font-size: 17px;
    line-height: 25px;
  }
}


/* financial calculator */
.calculator {
  display: grid;
  grid-template-columns: 1.3fr 1.4fr 1.2fr;
  /* Input | Result | Battery */
  gap: 30px;
  /* max-width: 1200px; */
  margin: 0 auto;
}

/* ---- Card Style ---- */
.card {
  background: white;
  padding: 25px;
  border-radius: 15px;
  box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.1);
}

.card h3 {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 12px;
  color: #333;
}

/* ---- Input Section ---- */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px 20px;
  /* row gap | column gap */
}

.form-group {
  margin-bottom: 12px;
}

.form-group label {
  display: block;
  font-size: 14px;
  /* margin-bottom: 4px; */
  color: #444;
  font-weight: 600;
}

.form-group input {
  width: 100%;
  height: 40px;
  padding: 8px;
  border-radius: 8px;
  border: 1px solid #ccc;
  font-size: 14px;
  font-weight: 500;
}

.form-group input:disabled {
  /* color: #0056b3;
  font-weight: 600;
  text-align: right; */
  color: #000;
}

/* ---- Result section ---- */
/* .result {
  border: 1px solid;
} */

.result-summary .card {
  min-height: 335px;
}

.result-row {
  /* border: 1px solid red; */
  display: flex;
  /* align-items: center; */
  justify-content: space-between;
}

.result-row p {
  font-size: 26px;
  line-height: 32px;
  margin-bottom: 0;
}

/* .outputWrap {
  border: 1px solid blue;
} */

.row1,
.row2 {
  display: flex;
  align-items: center;
}

.row1 {
  justify-content: flex-start;
}

.row2 {
  width: 100%;
  justify-content: flex-end;
}


.bg-green {
  background-color: #44DC77;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 7px 15px;
}

.outputB {
  width: 130px;
  height: 50px;
  font-size: 44px;
  line-height: 50px;
  font-weight: 500;
  text-align: right;
}

.outputS {
  font-size: 18px;
  line-height: 25px;
  text-align: center;
}

.small {
  text-align: center;
  line-height: normal;
}

/* ---- Button ---- */
.btn-wrapper {
  /* max-width: 1200px; */
  margin: 20px auto 0;
}

button {
  display: block;
  /* width: 100%; */
  margin: 0 auto;
  padding: 10px 15px;
  border: none;
  border-radius: 20px;
  font-size: 16px;
  font-weight: bold;
  /* background: #007bff; */
  background: #15C11B;
  color: white;
  cursor: pointer;
  transition: 0.3s;
}

button:hover {
  /* background: #0056b3; */
  background: #15C11B;
}

button.calculate-growth {
  margin: 0 auto;
}

button.calculate-growth a {
  color: white;
}

button.advanced-calculator {
  /* color: #000; */
  /* background: #0dcaf0; */
  background: #2848C8;
  /* background: #ffc107; */
}

button.advanced-calculator:hover {
  /* background: #31d2f2; */
  background: #2848C8;
  /* background: #ffca2c; */
}

/* ---- Battery Section ---- */
.battery-wrapper {
  display: flex;
  justify-content: center;
  gap: 3rem;
  /* margin-top: 1rem; */
}

.battery-container {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.battery-segmented {
  width: 130px;
  height: 220px;
  border: 7px solid #8C99CC;
  border-radius: 10px;
  padding: 5px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #e0e0e0;
  position: relative;
}

.withqp.battery-container p {
  color: #2848C8;
}

.withqp .battery-segmented {
  border-color: #2848C8;
}

.battery-segmented::after {
  content: "";
  position: absolute;
  top: -18px;
  /* left: 28px; */
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 12px;
  background: #5468B6;
  border-radius: 2px;
}

.battery-bar {
  flex: 1;
  margin: 2px 0;
  background: #ccc;
  border-radius: 4px;
  transition: background 0.3s;
}

.battery-container p {
  margin: 6px 0 0;
  /* font-weight: bold; */
}

.battery-container p.bhead {
  font-weight: 600;
}

.card.no-padding {
  padding: 0px;
}

.card.no-radius {
  border-radius: 0;
}

.card-title {
  background-color: #2848C8;
  padding: 10px 15px;
}

.card-title p {
  color: #fff;
  margin-bottom: 0;
  text-align: center;
}

.card-body {
  padding: 25px;
}

.bg-prefix {
  background-color: #44DC77;
  width: 50px;
  height: 40px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card.no-padding .form-group input {
  background-color: #44DC77;
  text-align: right;
}


/* General modal styles */
.modal {
  display: none;
  /* Hidden by default */
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.6);
}

/* Modal content */
.modal-content {
  background-color: #fff;
  margin: 15% auto;
  padding: 20px 30px 40px;
  border: 1px solid #888;
  width: 30%;
  min-height: 300px;
  position: relative;
  z-index: 2;
}

.nestedModal .modal-content {
  width: 60%;
}

/* Close button */
/* .close {
    background-color: #FFF;
    box-shadow: 0px 0px 15.7px 0px #00000014;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    position: absolute;
    top: 0;
    right: -80px;
} */
.close:hover,
.close:focus {
  cursor: pointer;
}

#btnClose {
  position: relative;
  margin-bottom: 20px;
}

#btnClose span {
  position: absolute;
  right: 0;
  top: 0;
}

#thankDiv {
  margin: 0 auto;
}

#thankDiv p {
  font-size: 17px;
  line-height: 22px;
  font-weight: 600;
}

/* `xs` returns only a ruleset and no media query */
/* ... { ... } */

/* `sm` applies to x-small devices (portrait phones, less than 576px) */
@media (max-width: 575.98px) {}

/* `md` applies to small devices (landscape phones, less than 768px) */
@media (max-width: 767.98px) {
  .card {
    margin-bottom: 1rem;
  }

  .result-summary.pe-0 {
    padding-right: calc(1.5rem * .5) !important;
  }

  .form-group.mb-0 {
    margin-bottom: 12px !important;
  }

  .result-row p {
    font-size: 18px;
    line-height: 25px;
  }

  .outputB {
    font-size: 30px;
    line-height: 35px;
    width: 100px;
    height: 35px;
  }

  .outputS {
    font-size: 14px;
    line-height: 17px;
  }

  .battery-wrapper {
    margin-top: 1rem;
  }

  .modal-content {
    width: 90%;
  }
}

/* `lg` applies to medium devices (tablets, less than 992px) */
@media (max-width: 991.98px) {
  .card {
    margin-bottom: 1rem;
  }

  .result-summary.pe-0 {
    padding-right: calc(1.5rem * .5) !important;
  }

  .form-group.mb-0 {
    margin-bottom: 12px !important;
  }

  .result-row p {
    font-size: 18px;
    line-height: 25px;
  }

  .outputB {
    font-size: 30px;
    line-height: 35px;
    width: 100px;
    height: 35px;
  }

  .outputS {
    font-size: 14px;
    line-height: 17px;
  }

  .battery-wrapper {
    margin-top: 1rem;
  }

  .modal-content {
    width: 70%;
  }
}

/* `xl` applies to large devices (desktops, less than 1200px) */
@media (max-width: 1199.98px) {
  .battery-wrapper {
    margin-top: 1rem;
  }
  .third {
    margin-top: 1rem;
  }
}

/* `xxl` applies to x-large devices (large desktops, less than 1400px) */
@media (max-width: 1399.98px) {
  .calcFormWrap {
    padding: 0;
  }

  .card {
    padding: 15px;
  }

  .card h3 {
    font-size: 16px;
  }

  .form-group label {
    font-size: 12px;
    /* line-height: 17px; */
  }

  .card.no-padding .card-body .form-group label {
    line-height: 17px;
    margin-top: 7px;
  }

  /* .result-summary {
    padding-left: 0 !important;
  } */
  .result-summary .card {
    min-height: 315px;
  }

  .result-row p {
    font-size: 18px;
    line-height: 23px;
  }

  .outputB {
    width: 100px;
    height: 38px;
    font-size: 36px;
    line-height: 36px;
  }

  .outputS {
    font-size: 15px;
    line-height: 20px;
  }

  /* .arrow {
    width: 28px;
  } */

  .battery-container p,
  .battery-container p.bhead {
    font-size: 16px;
  }

  button.advanced-calculator,
  button.calculate-growth {
    font-size: 15px;
  }

  .card-title p {
    font-size: 18px;
  }

  .modal-content {
    margin: 50% auto;
    width: 90%;
    padding: 20px 30px;
  }
}

.error {
  color: red;
}
.underline {
  text-decoration: underline;
}