/***************************************************
  Fake Data Generator Pro - Custom CSS (style.css)
  Authoritative, modern, and accessible industry site
  Bootstrap v5.0.2 is loaded first; this file extends/customizes.
****************************************************/

/* ==================
   Base & Typography
====================*/

html, body {
  background: #F8F9FB;
  color: #2C323C;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  font-size: 1.09rem;
  line-height: 1.68;
  letter-spacing: 0;
}

h1, h2, h3, h4, h5, h6 {
  color: #2C323C;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  font-weight: 700;
  letter-spacing: -1px;
}

h1, .display-1, .display-2, .display-3, .display-4, .display-5 {
  font-weight: 700 !important;
  color: #2C323C;
  letter-spacing: -1.5px;
}

h2, .section-heading {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.6em;
}

a {
  color: #3F6AD8;
  text-decoration: none;
  transition: color 0.13s, text-decoration 0.13s;
  font-weight: 500;
}
a:hover, a:focus {
  color: #254b9e;
  text-decoration: underline;
  outline: none;
}
a:visited {
  color: #3F6AD8;
}

.text-muted {
  color: #768090 !important;
}

.text-primary-accent {
  color: #3F6AD8 !important;
}

.text-neutral {
  color: #2C323C !important;
}

/* ==================
   Buttons & CTA
====================*/

.btn-primary-cta,
.btn-primary-cta:visited {
  background: #3F6AD8;
  color: #fff !important;
  border: none;
  border-radius: 999rem;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  font-weight: 700;
  box-shadow: 0 6px 24px 0 rgba(63,106,216,0.10);
  outline: 2px solid transparent;
  transition: background 0.15s, outline 0.13s, box-shadow 0.13s;
  text-decoration: none;
}
.btn-primary-cta:hover,
.btn-primary-cta:focus {
  background: #254b9e;
  color: #fff !important;
  outline: 2px solid #3F6AD8;
  box-shadow: 0 4px 12px 0 rgba(63,106,216,0.13);
}

.btn:focus,
.btn:active:focus {
  outline: 2px solid #3F6AD8 !important;
  box-shadow: none !important;
}

.btn-secondary-cta {
  background: #F3F6FA;
  color: #3F6AD8 !important;
  border: 1.5px solid #3F6AD8;
  border-radius: 999rem;
  font-weight: 600;
  transition: background 0.14s, color 0.14s;
}
.btn-secondary-cta:hover,
.btn-secondary-cta:focus {
  background: #E2E6EE;
  color: #254b9e !important;
}

/* Remove default Bootstrap button underline */
.btn, .btn:active, .btn:focus, .btn:visited {
  text-decoration: none !important;
}

/* ==================
   Navbar & Branding
====================*/

.navbar {
  background: #fff !important;
  border-bottom: 1.5px solid #E2E6EE !important;
  box-shadow: 0 2px 12px 0 rgba(63,106,216,0.02);
}

.navbar-brand {
  font-size: 1.38rem;
  color: #3F6AD8 !important;
  letter-spacing: -1px;
  font-weight: 700;
  padding-right: 1.5rem;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  transition: color 0.13s;
}
.navbar-brand:hover,
.navbar-brand:focus {
  color: #254b9e !important;
  text-decoration: underline;
}

.navbar-nav .nav-link {
  font-weight: 600;
  color: #2C323C !important;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  font-size: 1.08rem;
  padding: 0.6rem 1.1rem;
  transition: color 0.14s;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
  color: #3F6AD8 !important;
  background: #F3F6FA;
  border-radius: 0.5rem;
}

.navbar .dropdown-menu {
  border-radius: 8px;
  box-shadow: 0 10px 32px 0 rgba(63,106,216,0.08);
  border: 1px solid #E2E6EE;
  margin-top: -3px !important;
  font-size:1.04rem;
  padding: 0.5rem 0.3rem;
}
.navbar .dropdown-item {
  font-weight: 500;
  color: #2C323C;
  border-radius: 0.5rem;
  padding: 0.55rem 1.2rem;
}
.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
  color: #3F6AD8;
  background: #F3F6FA;
}
.navbar-toggler {
  outline: none !important;
  border: none;
}
@media (max-width: 991.98px) {
  .navbar .navbar-brand { font-size: 1.25rem; }
  .navbar .dropdown-menu { box-shadow: 0 6px 24px 0 rgba(63,106,216,0.10);}
}

/* ==================
   Footer
====================*/

.site-footer {
  background: #F8F9FB;
  border-top: 1px solid #E2E6EE;
  padding-top: 56px;
  padding-bottom: 28px;
  font-size: 1.01rem;
  margin-top: 0;
}
.footer-logo {
  font-size: 1.55rem;
  color: #3F6AD8 !important;
  font-family: 'Inter', 'Roboto', 'Montserrat', Arial, sans-serif;
  font-weight: 700;
  letter-spacing: -1px;
  transition: color 0.13s;
}
.footer-logo:hover,
.footer-logo:focus {
  color: #254b9e !important;
  text-decoration: underline;
}
.footer-link {
  color: #3F6AD8 !important;
  text-decoration: none;
  font-weight: 500;
  transition: color 0.13s, text-decoration 0.13s;
}
.footer-link:hover,
.footer-link:focus {
  color: #254b9e !important;
  text-decoration: underline;
}
.footer-link:visited {
  color: #3F6AD8 !important;
}
.footer-col-title {
  font-size: 1.08rem;
  color: #2C323C;
  font-weight: 700;
  margin-bottom: 0.7em;
}
.site-footer .small.text-muted {
  color: #768090 !important;
}
.site-footer .text-center.small.text-muted {
  color: #A0A8BA !important;
  margin-top: 1.5rem;
  font-size: 0.96rem;
}
@media (max-width: 991.98px) {
  .site-footer {
    padding-top: 32px;
    padding-bottom: 14px;
  }
  .footer-logo {
    font-size: 1.25rem;
  }
}

/* ==================
   Resource Cards & Links
====================*/

.resource-link {
  color: #3F6AD8;
  text-decoration: underline;
  font-weight: 600;
  transition: color 0.13s, text-decoration 0.13s;
}
.resource-link:hover,
.resource-link:focus {
  color: #254b9e;
  text-decoration: underline;
}
.resource-link:visited {
  color: #3F6AD8;
}

.resource-cards-section {
  background: #F8F9FB;
  padding: 56px 0;
}
.resource-card {
  background: #fff;
  border-radius: 1.2rem;
  border: none;
  box-shadow: 0 2px 12px 0 rgba(63,106,216,0.06);
  padding: 1.5rem 1.2rem 1.4rem 1.2rem;
  transition: box-shadow 0.14s, border 0.14s;
  border: 2px solid transparent;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.resource-card .fw-semibold {
  color: #3F6AD8;
  font-size: 1.07rem;
  margin-bottom: 0.2em;
}
.resource-card .resource-link {
  color: #3F6AD8;
  text-decoration: underline;
  font-weight: 600;
  margin-top: auto;
  transition: color 0.13s;
}
.resource-card:hover,
.resource-card:focus-within {
  box-shadow: 0 6px 28px 0 rgba(63,106,216,0.09);
  border: 2px solid #3F6AD8;
}
@media (max-width: 991.98px) {
  .resource-card {
    min-height: 180px;
  }
}

/* ==================
   Hero Section
====================*/

.hero-section {
  background: linear-gradient(160deg, #F8F9FB 60%, #E2E6EE 100%);
  min-height: 440px;
  padding: 64px 0 56px 0;
  display: flex;
  align-items: center;
}
.hero-section h1 {
  font-size: 2.55rem;
  font-weight: 800;
  color: #2C323C;
  letter-spacing: -1.5px;
  margin-bottom: 1.2rem;
}
.hero-section .lead {
  color: #768090;
  font-size: 1.28rem;
  max-width: 700px;
  margin: 0 auto 1.5rem auto;
}

/* ==================
   Teaser Utility Widget
====================*/

.teaser-utility-section .card {
  background: #fff;
  border-radius: 1.5rem;
  border: none;
  box-shadow: 0 4px 24px 0 rgba(63,106,216,0.06);
  margin-bottom: 0;
}

.teaser-utility-section .form-label {
  color: #2C323C;
  font-weight: 600;
  font-size: 1.07rem;
}
.teaser-utility-section .form-control,
.teaser-utility-section .form-select {
  border-radius: 0.8rem;
  border: 1.5px solid #E2E6EE;
  box-shadow: none !important;
  font-size: 1.04rem;
  color: #2C323C;
  background: #F8F9FB;
  transition: border 0.1s;
}
.teaser-utility-section .form-control:focus,
.teaser-utility-section .form-select:focus {
  border-color: #3F6AD8;
  background: #fff;
  outline: none;
}
.teaser-utility-section #teaser-results-area {
  min-height: 46px;
  margin-bottom: 0.2rem;
}

.teaser-utility-section .teaser-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin-top: 0.3rem;
  margin-bottom: 0.5rem;
  background: #fff;
  border-radius: 1.1rem;
  overflow: hidden;
  box-shadow: 0 2px 8px 0 rgba(63,106,216,0.04);
}
.teaser-utility-section .teaser-table th,
.teaser-utility-section .teaser-table td {
  border-bottom: 1.5px solid #E2E6EE;
  padding: 0.68em 1em;
  font-size: 1.03rem;
  vertical-align: middle;
}
.teaser-utility-section .teaser-table thead th {
  background: #F3F6FA;
  color: #3F6AD8;
  font-weight: 700;
  border-bottom: 2px solid #E2E6EE;
}
.teaser-utility-section .teaser-table tbody tr:nth-child(odd) {
  background: #F8F9FB;
}
.teaser-utility-section .teaser-table tbody tr:nth-child(even) {
  background: #fff;
}
.teaser-utility-section .teaser-table td {
  color: #2C323C;
}
.teaser-utility-section .teaser-table tr:last-child td {
  border-bottom: none;
}

/* Loader for teaser widget */
.teaser-utility-section .teaser-loader {
  display: inline-block;
  width: 32px; height: 32px;
  border: 3px solid #E2E6EE;
  border-top: 3px solid #3F6AD8;
  border-radius: 50%;
  animation: teaser-spin 0.7s linear infinite;
  margin: 0 auto;
}
@keyframes teaser-spin {
  0% { transform: rotate(0deg);}
  100% { transform: rotate(360deg);}
}

/* ==================
   Feature Highlights
====================*/

.feature-highlights-section {
  background: #fff;
  padding: 56px 0;
}
.feature-card {
  background: #fff;
  border-radius: 1.2rem;
  border: none;
  box-shadow: none;
  padding: 1.5rem 1rem 1.5rem 1rem;
  height: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  border-right: 1.5px solid #E2E6EE;
}
.feature-card:last-child {
  border-right: none;
}
.feature-card .bi {
  font-size: 2.3rem;
  color: #3F6AD8;
  margin-bottom: 0.8rem;
}
.feature-card .fw-semibold {
  font-size: 1.22rem;
  color: #2C323C;
}
.feature-card .text-muted {
  color: #768090 !important;
  font-size: 1rem;
}
@media (max-width: 991.98px) {
  .feature-card {
    border-right: none !important;
    border-bottom: 1.5px solid #E2E6EE;
    margin-bottom: 1.5rem;
  }
  .feature-card:last-child {
    border-bottom: none;
  }
}

/* ==================
   Quick Access Bar
====================*/

.quick-access-bar {
  background: #E2E6EE;
  padding: 1.3em 0 1.3em 0;
  border-top: 1.5px solid #E2E6EE;
  border-bottom: 1.5px solid #E2E6EE;
}
.qa-pill {
  display: inline-block;
  padding: 0.65em 1.5em;
  border-radius: 999rem;
  background: #F3F6FA;
  color: #3F6AD8 !important;
  font-weight: 600;
  font-size: 1.04rem;
  margin: 0 0.23em 0.35em 0.23em;
  transition: background 0.13s, color 0.13s, outline 0.13s;
  outline: 2px solid transparent;
  text-decoration: none;
}
.qa-pill:hover,
.qa-pill:focus {
  background: #3F6AD8;
  color: #fff !important;
  outline: 2px solid #3F6AD8;
  text-decoration: underline;
}
.qa-pill[style*="F7B32B"] {
  background: #F7B32B !important;
  color: #2C323C !important;
}
.qa-pill[style*="F7B32B"]:hover,
.qa-pill[style*="F7B32B"]:focus {
  background: #E2E6EE !important;
  color: #2C323C !important;
  outline: 2px solid #F7B32B;
}

/* ==================
   How It Works Section
====================*/

.how-it-works-section {
  background: #fff;
  padding: 56px 0;
}
.hiw-step {
  margin-bottom: 2.1rem;
}
.hiw-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #F3F6FA;
  border: 1.5px solid #E2E6EE;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  min-width: 38px;
  min-height: 38px;
}
.hiw-icon .bi {
  color: #3F6AD8;
}
.hiw-step .fw-semibold {
  color: #2C323C;
  font-size: 1.09rem;
}
.hiw-step .text-muted {
  color: #768090 !important;
  font-size: 1.01rem;
}

/* ==================
   FAQ Preview (Accordion)
====================*/

.faq-preview-section {
  background: #F8F9FB;
  padding: 56px 0;
}
.faq-accordion .accordion-item {
  border-radius: 0.9rem;
  border: 1.5px solid #E2E6EE;
  overflow: hidden;
  margin-bottom: 1.3rem;
  background: #fff;
}
.faq-accordion .accordion-item[style*="border-left:5px"] {
  border-left: 5px solid #3F6AD8 !important;
  border-radius: 0 .9rem .9rem 0;
}
.faq-accordion .accordion-header {
  margin-bottom: 0;
}
.faq-accordion .accordion-button {
  background: #fff;
  color: #3F6AD8;
  font-weight: 600;
  font-size: 1.06rem;
  border-radius: 0 !important;
  box-shadow: none;
  outline: none;
  border: none;
  transition: background 0.12s, color 0.12s;
}
.faq-accordion .accordion-button:focus,
.faq-accordion .accordion-button:not(.collapsed):focus {
  outline: 2px solid #3F6AD8;
  box-shadow: none;
}
.faq-accordion .accordion-button:not(.collapsed) {
  background: #fff;
  color: #3F6AD8;
  font-weight: 700;
  box-shadow: none;
}
.faq-accordion .accordion-body {
  background: #F3F6FA;
  color: #2C323C;
  font-size: 1.01rem;
  border-top: 1.5px solid #E2E6EE;
}
/* Remove border-radius for colored-border accordion items */
.faq-accordion .accordion-item[style*="border-left:5px"] .accordion-button {
  border-radius: 0 !important;
}
/* Accordion caret customization */
.faq-accordion .accordion-button::after {
  color: #3F6AD8;
  font-size: 1.2em;
  transition: transform 0.1s;
}

/* ==================
   In-Depth Guides
====================*/

.in-depth-guides-section {
  background: #F8F9FB;
  padding: 56px 0;
}
.in-depth-guides-section .p-4 {
  background: #fff;
  border-radius: 1.2rem;
  box-shadow: 0 2px 12px 0 rgba(63,106,216,0.06);
  font-size: 1.03rem;
  min-height: 200px;
}
.in-depth-guides-section .fw-bold {
  color: #2C323C;
  font-size: 1.19rem;
  margin-bottom: 0.7em;
  font-weight: 700;
}
.in-depth-guides-section ul {
  margin-bottom: 0;
  padding-left: 1.1rem;
}
.in-depth-guides-section li {
  margin-bottom: 0.55em;
  font-size: 1.01rem;
}
.in-depth-guides-section a {
  color: #3F6AD8;
  text-decoration: underline;
  font-weight: 600;
}
.in-depth-guides-section a:hover,
.in-depth-guides-section a:focus {
  color: #254b9e;
}

/* ==================
   Accessibility & Misc
====================*/

/* Focus outlines for all interactive elements */
a:focus,
button:focus,
input:focus,
.form-select:focus,
.form-control:focus {
  outline: 2px solid #3F6AD8 !important;
  outline-offset: 2px;
  box-shadow: none !important;
}

::-webkit-input-placeholder { color: #A0A8BA !important; }
::-moz-placeholder { color: #A0A8BA !important; }
:-ms-input-placeholder { color: #A0A8BA !important; }
::placeholder { color: #A0A8BA !important; }

/* Section spacings */
section {
  margin-bottom: 0;
}
@media (max-width: 767.98px) {
  .hero-section {
    padding: 36px 0 28px 0;
  }
  .feature-highlights-section,
  .resource-cards-section,
  .faq-preview-section,
  .how-it-works-section,
  .in-depth-guides-section {
    padding: 32px 0;
  }
  .site-footer {
    padding-top: 20px;
    padding-bottom: 10px;
    font-size: 0.98rem;
  }
}

/* Hide AdSense blocks when not enabled (for graceful fallback) */
.adsense-block {
  display: none;
}

/* ==================
   Utility
====================*/

.border-end-md {
  border-right: 1.5px solid #E2E6EE !important;
}
@media (max-width: 991.98px) {
  .border-end-md {
    border-right: none !important;
  }
}

.rounded-4 {
  border-radius: 1.2rem !important;
}

.shadow-sm {
  box-shadow: 0 2px 12px 0 rgba(63,106,216,0.06) !important;
}
.shadow-lg {
  box-shadow: 0 6px 24px 0 rgba(63,106,216,0.10) !important;
}

/* Remove number input arrows for consistency */
input[type="number"]::-webkit-inner-spin-button, 
input[type="number"]::-webkit-outer-spin-button { 
  -webkit-appearance: none;
  margin: 0;
}
input[type="number"] {
  -moz-appearance: textfield;
}

/* ==================
   Print Styles
====================*/
@media print {
  nav, .site-footer, .btn, .qa-pill, .quick-access-bar, .faq-accordion .accordion-button::after {
    display: none !important;
  }
  body, html {
    background: #fff !important;
    color: #222 !important;
  }
}

/* END style.css */
