/*
  Optimized readable stylesheet.
  Same selectors and layout as the original file, with safe performance overrides added near the end.
*/

* {
  margin:0;
  padding:0;
  box-sizing:border-box
}

img {
  max-width:100%;
  display:block
}

html {
  scroll-behavior:smooth;
}

body {
  font-family:Arial, Helvetica, sans-serif;
  background:#ffffff;
  color:#10233d;
  line-height:1.6
}


/* Global link reset: prevents browser default underlines on normal, visited, active, and clicked links */
a,
a:visited,
a:hover,
a:active,
a:focus {
  text-decoration:none;
}

a {
  color:inherit;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline:3px solid rgba(30, 136, 255, 0.35);
  outline-offset:3px;
}



ul {
  list-style:none
}

.container {
  width:min(1120px, 90%);
  margin:0 auto
}

.section {
  padding:80px 0
}

.alt-section {
  background:#f6fbff
}

.section-heading {
  max-width:700px;
  margin-bottom:40px
}

.section-heading h2 {
  font-size:clamp(2rem, 4vw, 2.8rem);
  line-height:1.15;
  margin-bottom:14px;
  color:#10233d
}

.section-heading p {
  color:#5b708b;
  font-size:1rem
}

.section-tag, .eyebrow {
  display:inline-block;
  color:#1e88ff;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.2px;
  font-size:0.82rem;
  margin-bottom:14px
}

.btn {
  display:inline-block;
  padding:14px 22px;
  border-radius:999px;
  font-weight:700;
  transition:0.25s ease
}

.btn-primary {
  background:linear-gradient(135deg, #1e88ff, #4db7ff);
  color:#ffffff;
  box-shadow:0 10px 24px rgba(30, 136, 255, 0.22)
}

.btn-primary:hover {
  transform:translateY(-2px)
}

.btn-secondary {
  border:1px solid #cfe2f7;
  background:#ffffff;
  color:#10233d
}

.btn-secondary:hover {
  background:#f4f9ff
}

.card, .content-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:22px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.card {
  padding:26px
}

.site-header {
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255, 255, 255, 0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #e6eef8
}

.nav-wrapper {
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:82px;
  gap:20px
}

.logo {
  font-size:1.5rem;
  font-weight:800;
  letter-spacing:0.3px;
  white-space:nowrap;
  color:#10233d
}

.logo-accent {
  color:#1e88ff
}

.site-nav {
  margin-left:auto
}

.nav-list {
  display:flex;
  align-items:center;
  gap:24px
}

.nav-list a {
  color:#4d6078;
  font-weight:600;
  transition:0.25s ease
}

.nav-list a:hover {
  color:#1e88ff
}

.nav-cta {
  white-space:nowrap
}

.nav-toggle {
  display:none;
  background:transparent;
  border:none;
  color:#10233d;
  font-size:1.8rem;
  cursor:pointer
}

.mobile-menu-js {
  display:none
}

.hero {
  padding:90px 0 70px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.18), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.hero-grid {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  align-items:center;
  gap:40px
}

.hero-content h1 {
  font-size:clamp(2.5rem, 5vw, 4.4rem);
  line-height:1.05;
  margin-bottom:20px;
  max-width:680px;
  color:#10233d
}

.hero-text {
  font-size:1.08rem;
  color:#4f657f;
  max-width:620px;
  margin-bottom:28px
}

.hero-buttons {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:32px
}

.hero-highlights {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px
}

.highlight-card {
  background:rgba(255, 255, 255, 0.88);
  border:1px solid #dce9f7;
  border-radius:18px;
  padding:18px;
  box-shadow:0 8px 20px rgba(16, 35, 61, 0.04)
}

.highlight-number {
  display:block;
  color:#1e88ff;
  font-weight:800;
  font-size:1.1rem;
  margin-bottom:6px
}

.highlight-label {
  color:#4e627a;
  font-size:0.95rem
}

.hero-image-wrapper {
  display:flex;
  justify-content:center;
  align-items:flex-start;
  position:relative;
  margin-top:8px;
  overflow:visible
}

.hero-image-wrapper::before {
  content:"";
  position:absolute;
  width:420px;
  height:420px;
  background:radial-gradient(circle, rgba(77, 183, 255, 0.18), transparent 65%);
  border-radius:50%;
  filter:blur(14px);
  z-index:0;
  top:20px
}

.hero-image {
  position:relative;
  z-index:1;
  width:min(100%, 430px);
  transform:translateY(-48px);
  background:transparent;
  border:none;
  box-shadow:none;
  border-radius:0;
  -webkit-mask-image:linear-gradient( to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 58%, rgba(0, 0, 0, 0.96) 68%, rgba(0, 0, 0, 0.84) 78%, rgba(0, 0, 0, 0.62) 86%, rgba(0, 0, 0, 0.34) 93%, rgba(0, 0, 0, 0.12) 97%, rgba(0, 0, 0, 0) 100% );
  mask-image:linear-gradient( to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 58%, rgba(0, 0, 0, 0.96) 68%, rgba(0, 0, 0, 0.84) 78%, rgba(0, 0, 0, 0.62) 86%, rgba(0, 0, 0, 0.34) 93%, rgba(0, 0, 0, 0.12) 97%, rgba(0, 0, 0, 0) 100% )
}

.topics-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px
}

.topics-grid .card {
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.topics-grid .card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.12);
  border-color:#b8d8f8
}

.card-icon {
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  border-radius:16px;
  background:linear-gradient(135deg, #e9f5ff, #f5fbff);
  border:1px solid #d6e8fa;
  font-size:1.6rem;
  box-shadow:0 8px 18px rgba(30, 136, 255, 0.08);
  transition:transform 0.28s ease, box-shadow 0.28s ease, background 0.28s ease
}

.topics-grid .card:hover .card-icon {
  transform:scale(1.08);
  box-shadow:0 12px 24px rgba(30, 136, 255, 0.14);
  background:linear-gradient(135deg, #dff1ff, #eef8ff)
}

.card h3 {
  font-size:1.2rem;
  margin-bottom:12px;
  color:#10233d
}

.card p {
  color:#5b708b;
  font-size:0.97rem
}

.content-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px
}

.content-card {
  overflow:hidden;
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.content-card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.12);
  border-color:#b8d8f8
}

.content-thumb {
  min-height:210px;
  display:grid;
  place-items:center;
  padding:20px;
  font-weight:700;
  color:#1d4f8f;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  border-bottom:1px solid #e4eef9;
  transition:transform 0.28s ease, background 0.28s ease
}

.content-card:hover .content-thumb {
  transform:scale(1.03);
  background:linear-gradient(135deg, #dff1ff, #f2faff)
}

.content-body {
  padding:24px
}

.content-body h3 {
  font-size:1.2rem;
  line-height:1.3;
  margin-bottom:12px;
  color:#10233d
}

.content-body p {
  color:#5b708b;
  margin-bottom:16px
}

.content-link {
  color:#1e88ff;
  font-weight:700
}

.content-link:hover {
  color:#0e6fe0
}

.post-meta {
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:0.78rem;
  font-weight:800;
  color:#6f8500;
  text-transform:uppercase;
  letter-spacing:1.8px;
  margin-bottom:14px;
}

.about-grid {
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:36px;
  align-items:center
}

.about-image-box {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  padding:18px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.05)
}

.about-image {
  border-radius:20px;
  width:100%
}

.about-content h2 {
  font-size:clamp(2rem, 4vw, 2.8rem);
  line-height:1.15;
  margin-bottom:18px;
  color:#10233d
}

.about-content p {
  color:#5b708b;
  margin-bottom:16px
}

.benefits-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px
}

.benefits-grid .card {
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.benefits-grid .card:hover {
  transform:translateY(-6px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.10);
  border-color:#b8d8f8
}

.cta-box {
  text-align:center;
  padding:50px 24px;
  border-radius:28px;
  background:linear-gradient(135deg, #eef7ff, #f8fbff);
  border:1px solid #dbe8f7;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.05)
}

.cta-box h2 {
  font-size:clamp(2rem, 4vw, 2.9rem);
  margin-bottom:14px;
  color:#10233d
}

.cta-box p {
  color:#5b708b;
  max-width:680px;
  margin:0 auto 24px
}

.cta-buttons {
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:14px
}

.videos-hero {
  padding:90px 0 70px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.16), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.videos-heading h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1.08;
  margin-bottom:16px;
  color:#10233d
}

.featured-video-box {
  display:grid;
  grid-template-columns:1.2fr 0.8fr;
  gap:28px;
  align-items:center;
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  padding:24px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.video-embed, .video-card-embed {
  position:relative;
  width:100%;
  padding-bottom:56.25%;
  border-radius:18px;
  overflow:hidden;
  background:#dfeefd
}

.video-embed iframe, .video-card-embed iframe {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:none
}

.featured-video-text h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  margin-bottom:14px;
  color:#10233d
}

.featured-video-text p {
  color:#5b708b;
  margin-bottom:18px
}

.videos-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px
}

.video-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.video-card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.12);
  border-color:#b8d8f8
}

.video-card-body {
  padding:22px
}

.video-card-body h3 {
  font-size:1.15rem;
  line-height:1.3;
  margin-bottom:12px;
  color:#10233d
}

.video-card-body p {
  color:#5b708b;
  margin-bottom:14px
}

.blog-hero {
  padding:90px 0 30px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.16), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.blog-heading h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1.08;
  margin-bottom:16px;
  color:#10233d
}

.featured-blog-section {
  padding-top:20px
}

.featured-blog-card {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:center;
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  padding:24px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.featured-blog-image {
  min-height:320px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  color:#1d4f8f;
  font-size:1.2rem;
  font-weight:700;
  border:1px solid #e4eef9
}

.featured-blog-image {
  overflow:hidden;
}

.featured-blog-image img {
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center;
  transform:scale(0.96);
  border-radius:inherit;
}

.featured-blog-content h2 {
  font-size:clamp(1.9rem, 3vw, 2.5rem);
  line-height:1.15;
  margin-bottom:14px;
  color:#10233d
}

.featured-blog-content p {
  color:#5b708b;
  margin-bottom:20px
}

.blog-topics-section {
  padding:10px 0 0
}

.blog-topics {
  display:flex;
  flex-wrap:wrap;
  gap:12px
}

.topic-pill {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 18px;
  border-radius:999px;
  border:1px solid #dce9f7;
  background:#ffffff;
  color:#4f657f;
  font-weight:600;
  font-size:0.95rem;
  transition:0.25s ease;
  cursor:pointer;
  font-family:inherit
}

.topic-pill:hover {
  background:#f3f9ff;
  border-color:#bfdcf8;
  color:#1e88ff
}

.topic-pill.active {
  background:linear-gradient(135deg, #1e88ff, #4db7ff);
  color:#ffffff;
  border-color:transparent
}

.blog-grid-section {
  padding-top:40px
}

.blog-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px
}

.blog-scroll-area {
  max-height:640px;
  overflow-y:auto;
  overflow-x:hidden;
  padding-right:10px;
  scroll-behavior:smooth;
}

.blog-scroll-area::-webkit-scrollbar {
  width:8px;
}

.blog-scroll-area::-webkit-scrollbar-track {
  background:#f3f9ff;
  border-radius:999px;
}

.blog-scroll-area::-webkit-scrollbar-thumb {
  background:#c7ddf5;
  border-radius:999px;
}

.blog-scroll-area::-webkit-scrollbar-thumb:hover {
  background:#9fc8f2;
}

.blog-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:22px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.blog-card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.12);
  border-color:#b8d8f8
}

.blog-card-body {
  padding:24px
}

.blog-card-body h3 {
  font-size:1.18rem;
  line-height:1.3;
  margin-bottom:12px;
  color:#10233d
}

.blog-card-body p {
  color:#5b708b;
  margin-bottom:16px
}

.blog-loader {
  text-align:center;
  padding-top:30px
}

.blog-loader p {
  color:#7a8ea8;
  font-size:0.98rem
}

.about-page-hero {
  padding:90px 0 30px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.16), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.about-page-heading h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1.08;
  margin-bottom:16px;
  color:#10233d
}

.about-story-section {
  padding-top:30px
}

.about-page-grid {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:42px;
  align-items:start
}

.about-page-text {
  min-width:0
}

.about-text-block + .about-text-block {
  margin-top:56px
}

.about-text-block h2 {
  font-size:clamp(2rem, 4vw, 2.9rem);
  line-height:1.12;
  margin-bottom:18px;
  color:#10233d
}

.about-text-block h3 {
  font-size:1.65rem;
  line-height:1.2;
  margin-bottom:16px;
  color:#10233d
}

.about-text-block p {
  color:#5b708b;
  font-size:1.03rem;
  margin-bottom:16px;
  max-width:760px
}

.about-page-sidebar {
  position:relative
}

.about-sticky-card {
  position:sticky;
  top:110px;
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  box-shadow:none
}

.about-sticky-image-wrap {
  position:relative;
  display:flex;
  justify-content:center;
  margin-bottom:18px;
  padding:8px 8px 0
}

.about-sticky-image-wrap::before {
  display:none
}

.about-sticky-image {
  position:relative;
  z-index:1;
  width:min(100%, 360px);
  background:transparent;
  border:none;
  box-shadow:none;
  -webkit-mask-image:none;
  mask-image:none
}

.about-sticky-content h3 {
  font-size:1.45rem;
  line-height:1.2;
  margin-bottom:12px;
  color:#10233d
}

.about-sticky-content p {
  color:#5b708b
}

.site-footer {
  padding-top:40px;
  background:#10233d;
  border-top:1px solid rgba(255, 255, 255, 0.06)
}

.footer-grid {
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:30px;
  padding-bottom:30px
}

.footer-brand .logo {
  color:#ffffff
}

.footer-brand p {
  color:#cbd7e6;
  max-width:380px;
  margin-top:14px
}

.footer-links h4 {
  font-size:1rem;
  margin-bottom:14px;
  color:#ffffff
}

.footer-links li + li {
  margin-top:10px
}

.footer-links a {
  color:#d9e4f2
}

.footer-links a:hover {
  color:#7fc6ff
}

.footer-bottom {
  padding:20px 0;
  border-top:1px solid rgba(255, 255, 255, 0.08)
}

.footer-bottom p {
  text-align:center;
  color:#b9c8db;
  font-size:0.95rem
}

.social-icons {
  display:flex;
  align-items:center;
  gap:16px;
  margin-top:10px
}

.social-icons a {
  color:#ffffff;
  font-size:1.4rem;
  transition:transform 0.25s ease, color 0.25s ease
}

.social-icons a:hover {
  transform:translateY(-2px);
  color:#7fc6ff
}

.tools-hero {
  padding:90px 0 30px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.16), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.tools-heading h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1.08;
  margin-bottom:16px;
  color:#10233d
}

.tools-section {
  padding-top:30px
}

.tools-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px
}

.tool-card {
  display:flex;
  flex-direction:column;
  gap:18px;
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:24px;
  padding:24px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  transition:transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease
}

.tool-card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 35px rgba(16, 35, 61, 0.12);
  border-color:#b8d8f8
}

.tool-card-icon {
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:linear-gradient(135deg, #e9f5ff, #f5fbff);
  border:1px solid #d6e8fa;
  color:#1e88ff;
  font-size:1.4rem;
  box-shadow:0 8px 18px rgba(30, 136, 255, 0.08)
}

.tool-card-body {
  display:flex;
  flex-direction:column;
  gap:10px
}

.tool-tag {
  display:inline-block;
  font-size:0.82rem;
  font-weight:700;
  color:#1e88ff;
  text-transform:uppercase;
  letter-spacing:1px
}

.tool-card-body h3 {
  font-size:1.28rem;
  line-height:1.25;
  color:#10233d
}

.tool-card-body p {
  color:#5b708b;
  font-size:0.98rem
}

.tool-link {
  margin-top:4px;
  color:#1e88ff;
  font-weight:700
}

.muted-link {
  color:#7a8ea8
}

.tool-card-soon {
  cursor:default
}

.tool-card-soon:hover {
  transform:none;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  border-color:#dce9f7
}

.contact-hero {
  padding:90px 0 30px;
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.16), transparent 28%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.contact-heading h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1.08;
  margin-bottom:16px;
  color:#10233d
}

.contact-section {
  padding-top:30px
}

.contact-grid {
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:32px;
  align-items:start
}

.contact-form-card, .contact-info-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.contact-form-card {
  padding:28px
}

.contact-info-card {
  padding:28px;
  position:sticky;
  top:110px
}

.contact-info-card h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  margin-bottom:14px;
  color:#10233d
}

.contact-info-card p {
  color:#5b708b;
  margin-bottom:18px
}

.contact-form {
  display:flex;
  flex-direction:column;
  gap:20px
}

.form-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px
}

.form-group {
  display:flex;
  flex-direction:column;
  gap:8px
}

.form-group label {
  font-size:0.95rem;
  font-weight:700;
  color:#10233d
}

.form-group input, .form-group textarea {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:15px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

.form-group textarea {
  resize:vertical;
  min-height:180px
}

.form-group input::placeholder, .form-group textarea::placeholder {
  color:#8194ab
}

.form-group input:focus, .form-group textarea:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.captcha-placeholder {
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:18px;
  border-radius:20px;
  background:#f6fbff;
  border:1px dashed #bfdcf8
}

.captcha-icon {
  width:48px;
  height:48px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  color:#1e88ff;
  font-size:1.1rem;
  border:1px solid #d6e8fa
}

.captcha-text strong {
  display:block;
  color:#10233d;
  margin-bottom:4px;
  font-size:0.98rem
}

.captcha-text p {
  color:#5b708b;
  margin:0;
  font-size:0.95rem
}

.submit-btn {
  width:100%;
  text-align:center
}

.contact-info-list {
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-top:22px
}

.contact-info-item {
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:16px;
  border-radius:18px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.contact-info-icon {
  width:44px;
  height:44px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg, #e9f5ff, #f5fbff);
  color:#1e88ff;
  font-size:1rem;
  border:1px solid #d6e8fa
}

.contact-info-item h3 {
  font-size:1rem;
  margin-bottom:4px;
  color:#10233d
}

.contact-info-item p {
  margin:0;
  color:#5b708b
}

@media (max-width:1024px) {
  .hero-grid, .about-grid, .about-page-grid, .featured-video-box, .featured-blog-card {
    grid-template-columns:1fr
  }

  .topics-grid, .content-grid, .videos-grid, .blog-grid {
    grid-template-columns:repeat(2, 1fr)
  }

  .benefits-grid {
    grid-template-columns:repeat(2, 1fr)
  }

  .footer-grid {
    grid-template-columns:1fr 1fr
  }

  .footer-brand {
    grid-column:1 / -1
  }

  .hero-content h1 {
    font-size:3.6rem;
    max-width:100%
  }

  .about-sticky-card {
    position:static
  }

  .about-sticky-image {
    width:min(100%, 320px)
  }

  .featured-video-box {
    gap:24px
  }

}

@media (max-width:768px) {
  .site-nav, .nav-cta {
    display:none
  }

  .nav-toggle {
    display:block;
    margin-left:auto
  }

  .site-header {
    padding:0
  }

  .nav-wrapper {
    min-height:78px
  }

  .hero {
    padding:36px 0 48px
  }

  .hero-grid {
    grid-template-columns:1fr;
    gap:24px;
    align-items:start
  }

  .hero-image-wrapper {
    display:none
  }

  .hero-content {
    text-align:left
  }

  .hero-content h1 {
    font-size:3rem;
    line-height:1.02;
    max-width:100%;
    margin-bottom:18px
  }

  .hero-text {
    font-size:1.02rem;
    line-height:1.7;
    max-width:100%;
    margin-bottom:24px
  }

  .eyebrow {
    font-size:0.8rem;
    line-height:1.5;
    margin-bottom:14px
  }

  .hero-buttons, .cta-buttons {
    flex-direction:column;
    gap:12px
  }

  .btn {
    width:100%;
    text-align:center
  }

  .hero-highlights, .topics-grid, .content-grid, .benefits-grid, .footer-grid, .videos-grid, .blog-grid {
    grid-template-columns:1fr
  }

  .highlight-card {
    padding:18px
  }

  .section {
    padding:56px 0
  }

  .section-heading {
    margin-bottom:26px
  }

  .section-heading h2 {
    font-size:2rem;
    line-height:1.15
  }

  .videos-hero, .blog-hero, .about-page-hero {
    padding:70px 0 20px
  }

  .featured-video-box, .featured-blog-card {
    grid-template-columns:1fr;
    gap:20px;
    padding:18px
  }

  .featured-video-text h2 {
    font-size:2rem;
    line-height:1.15
  }

  .video-card {
    width:100%
  }

  .video-card-body {
    padding:20px
  }

  .video-card-body h3 {
    font-size:1.35rem;
    line-height:1.3
  }

  .video-card-body p {
    font-size:1rem;
    line-height:1.7
  }

  .featured-blog-image {
    min-height:220px
  }

  .blog-topics {
    gap:10px
  }

  .topic-pill {
    font-size:0.88rem;
    padding:9px 14px
  }

  .about-text-block + .about-text-block {
    margin-top:42px
  }

  .about-text-block h2 {
    font-size:2.2rem
  }

  .about-text-block h3 {
    font-size:1.4rem
  }

  .about-text-block p {
    font-size:1rem
  }

}

@media (max-width:1024px) {
  .contact-grid {
    grid-template-columns:1fr
  }

  .contact-info-card {
    position:static
  }

}

@media (max-width:768px) {
  .contact-hero {
    padding:70px 0 20px
  }

  .form-row {
    grid-template-columns:1fr
  }

  .contact-form-card, .contact-info-card {
    padding:20px
  }

  .captcha-placeholder {
    flex-direction:column;
    align-items:flex-start
  }

  .contact-heading h1 {
    font-size:2.8rem;
    line-height:1.05
  }

}

@media (max-width:1024px) {
  .tools-grid {
    grid-template-columns:repeat(2, 1fr)
  }

}

@media (max-width:768px) {
  .tools-hero {
    padding:70px 0 20px
  }

  .tools-grid {
    grid-template-columns:1fr
  }

  .tools-heading h1 {
    font-size:2.8rem;
    line-height:1.05
  }

  .tool-card {
    padding:20px
  }

}

.meta-tool-section {
  padding-top:20px
}

.meta-tool-grid {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:28px;
  align-items:start
}

.meta-tool-form-card, .meta-side-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.meta-tool-form-card {
  padding:24px
}

.meta-tool-topbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:26px
}

.meta-tool-topbar h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d
}

.meta-tool-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.meta-tool-block + .meta-tool-block {
  margin-top:28px
}

.meta-tool-block-head {
  margin-bottom:16px
}

.meta-tool-block-head h3 {
  font-size:1.35rem;
  color:#10233d;
  margin-bottom:4px
}

.meta-tool-block-head p {
  color:#5b708b
}

.meta-fields {
  display:grid;
  gap:14px
}

.meta-field {
  display:flex;
  flex-direction:column;
  gap:8px
}

.meta-field label {
  font-size:0.96rem;
  font-weight:700;
  color:#10233d
}

.meta-input {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

textarea.meta-input {
  resize:vertical;
  min-height:92px
}

.meta-input:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.meta-counter {
  font-size:0.9rem;
  color:#5b708b;
  text-align:right
}

.meta-counter.limit-near {
  color:#d98200;
  font-weight:700
}

.meta-counter.limit-max {
  color:#d92f2f;
  font-weight:700
}

.meta-tool-sidebar {
  display:flex;
  flex-direction:column;
  gap:20px
}

.meta-side-card {
  padding:22px
}

.meta-side-card h3 {
  font-size:1.35rem;
  line-height:1.2;
  margin-bottom:14px;
  color:#10233d
}

.meta-side-list {
  display:flex;
  flex-direction:column;
  gap:10px
}

.meta-side-list li {
  color:#5b708b
}

.meta-ad-anatomy {
  border:1px solid #dce9f7;
  border-radius:22px;
  background:#f9fcff;
  padding:16px;
  margin-bottom:16px
}

.anatomy-box, .anatomy-media, .anatomy-headline, .anatomy-description, .anatomy-cta {
  border-radius:14px;
  border:1px solid #d6e8fa;
  background:#ffffff;
  color:#10233d
}

.anatomy-primary {
  padding:12px 14px;
  margin-bottom:12px;
  font-weight:700
}

.anatomy-media {
  min-height:140px;
  display:grid;
  place-items:center;
  margin-bottom:12px;
  color:#5b708b;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff)
}

.anatomy-bottom {
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px
}

.anatomy-copy {
  display:grid;
  gap:8px
}

.anatomy-headline, .anatomy-description {
  padding:10px 12px
}

.anatomy-headline {
  font-weight:700
}

.anatomy-description {
  color:#5b708b
}

.anatomy-cta {
  display:grid;
  place-items:center;
  min-width:84px;
  padding:10px 14px;
  font-weight:700
}

.meta-limit-grid {
  display:grid;
  gap:10px
}

.meta-limit-item {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.meta-limit-item span {
  color:#5b708b
}

.meta-limit-item strong {
  color:#10233d
}

@media (max-width:1024px) {
  .meta-tool-grid {
    grid-template-columns:1fr
  }

}

@media (max-width:768px) {
  .meta-tool-form-card, .meta-side-card {
    padding:20px
  }

  .meta-tool-topbar {
    flex-direction:column;
    align-items:stretch
  }

  .meta-tool-actions {
    flex-direction:column
  }

  .anatomy-bottom {
    grid-template-columns:1fr
  }

}

.google-tool-section {
  padding-top:20px
}

.google-tool-grid {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:28px;
  align-items:start
}

.google-tool-form-card, .google-side-card, .google-preview-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.google-tool-form-card {
  padding:24px
}

.google-tool-topbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:26px
}

.google-tool-topbar h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d
}

.google-tool-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.google-tabs {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:26px
}

.google-tab {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 18px;
  border-radius:999px;
  border:1px solid #dce9f7;
  background:#ffffff;
  color:#4f657f;
  font-weight:700;
  font-size:0.95rem;
  transition:0.25s ease;
  cursor:pointer;
  font-family:inherit
}

.google-tab:hover {
  background:#f3f9ff;
  border-color:#bfdcf8;
  color:#1e88ff
}

.google-tab.active {
  background:linear-gradient(135deg, #1e88ff, #4db7ff);
  color:#ffffff;
  border-color:transparent
}

.google-panel {
  display:none
}

.google-panel.active {
  display:block
}

.google-tool-block + .google-tool-block, .google-preview-card {
  margin-top:28px
}

.google-tool-block-head {
  margin-bottom:16px
}

.google-tool-block-head h3 {
  font-size:1.35rem;
  color:#10233d;
  margin-bottom:4px
}

.google-tool-block-head p {
  color:#5b708b
}

.google-fields {
  display:grid;
  gap:14px
}

.google-fields-2col {
  grid-template-columns:1fr 1fr;
  gap:14px
}

.google-field {
  display:flex;
  flex-direction:column;
  gap:8px
}

.google-field label {
  font-size:0.96rem;
  font-weight:700;
  color:#10233d
}

.google-input {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

textarea.google-input {
  resize:vertical;
  min-height:88px
}

.google-input:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.google-counter {
  font-size:0.9rem;
  color:#5b708b;
  text-align:right
}

.google-counter.limit-near {
  color:#d98200;
  font-weight:700
}

.google-counter.limit-max {
  color:#d92f2f;
  font-weight:700
}

.google-preview-card {
  padding:22px
}

.google-search-preview {
  border:1px solid #dce9f7;
  border-radius:20px;
  background:#f9fcff;
  padding:18px
}

.google-search-url {
  color:#188038;
  font-size:0.92rem;
  margin-bottom:6px
}

.google-search-headlines {
  color:#1a0dab;
  font-size:1.2rem;
  line-height:1.3;
  margin-bottom:8px
}

.google-search-description {
  color:#4d5156
}

.google-display-preview {
  border:1px solid #dce9f7;
  border-radius:20px;
  background:#f9fcff;
  overflow:hidden
}

.google-display-media {
  min-height:180px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  color:#5b708b;
  border-bottom:1px solid #e4eef9
}

.google-display-copy {
  padding:16px
}

.google-display-headline {
  font-size:1.15rem;
  font-weight:700;
  color:#10233d;
  margin-bottom:6px
}

.google-display-long {
  color:#10233d;
  margin-bottom:8px
}

.google-display-description {
  color:#5b708b;
  margin-bottom:14px
}

.google-display-cta {
  display:inline-block;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(135deg, #1e88ff, #4db7ff);
  color:#ffffff;
  font-weight:700;
  font-size:0.92rem
}

.google-tool-sidebar {
  display:flex;
  flex-direction:column;
  gap:20px
}

.google-side-card {
  padding:22px
}

.google-side-card h3 {
  font-size:1.35rem;
  line-height:1.2;
  margin-bottom:14px;
  color:#10233d
}

.google-side-list {
  display:flex;
  flex-direction:column;
  gap:10px
}

.google-side-list li {
  color:#5b708b
}

.google-anatomy-box {
  display:grid;
  gap:14px
}

.google-anatomy-search, .google-anatomy-display {
  padding:16px;
  border:1px solid #dce9f7;
  border-radius:20px;
  background:#f9fcff
}

.google-anatomy-line {
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid #d6e8fa;
  background:#ffffff;
  color:#10233d;
  font-weight:700
}

.google-anatomy-sub {
  margin-top:8px;
  color:#5b708b
}

.google-anatomy-media {
  min-height:80px;
  display:grid;
  place-items:center;
  margin-top:10px;
  border-radius:14px;
  border:1px solid #d6e8fa;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  color:#5b708b
}

.google-limit-grid {
  display:grid;
  gap:10px
}

.google-limit-item {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.google-limit-item span {
  color:#5b708b
}

.google-limit-item strong {
  color:#10233d
}

@media (max-width:1024px) {
  .google-tool-grid {
    grid-template-columns:1fr
  }

}

@media (max-width:768px) {
  .google-tool-form-card, .google-side-card, .google-preview-card {
    padding:20px
  }

  .google-tool-topbar {
    flex-direction:column;
    align-items:stretch
  }

  .google-tool-actions {
    flex-direction:column
  }

  .google-fields-2col {
    grid-template-columns:1fr
  }

}

.reporting-section {
  padding-top:20px
}

.reporting-form-card, .report-preview-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.reporting-form-card {
  padding:24px;
  margin-bottom:26px
}

.reporting-topbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:26px
}

.reporting-topbar h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d
}

.reporting-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.report-tabs {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:26px
}

.report-tab {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 18px;
  border-radius:999px;
  border:1px solid #dce9f7;
  background:#ffffff;
  color:#4f657f;
  font-weight:700;
  font-size:0.95rem;
  transition:0.25s ease;
  cursor:pointer;
  font-family:inherit
}

.report-tab:hover {
  background:#f3f9ff;
  border-color:#bfdcf8;
  color:#1e88ff
}

.report-tab.active {
  background:linear-gradient(135deg, #1e88ff, #4db7ff);
  color:#ffffff;
  border-color:transparent
}

.report-panel {
  display:none
}

.report-panel.active {
  display:block
}

.report-block-head {
  margin-bottom:16px
}

.report-block-head h3 {
  font-size:1.35rem;
  color:#10233d;
  margin-bottom:4px
}

.report-block-head p {
  color:#5b708b
}

.report-fields {
  display:grid;
  gap:14px
}

.report-fields-2col {
  grid-template-columns:1fr 1fr
}

.report-field {
  display:flex;
  flex-direction:column;
  gap:8px
}

.report-field label {
  font-size:0.96rem;
  font-weight:700;
  color:#10233d
}

.report-field input, .report-field textarea {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

.report-field textarea {
  resize:vertical;
  min-height:96px
}

.report-field input:focus, .report-field textarea:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.report-preview-card {
  padding:26px
}

.report-preview-header {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:24px
}

.report-preview-header h2 {
  font-size:clamp(2rem, 4vw, 2.8rem);
  line-height:1.1;
  color:#10233d;
  margin-bottom:10px
}

.report-preview-meta {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  color:#5b708b;
  font-size:0.96rem
}

.report-preview-section + .report-preview-section {
  margin-top:24px
}

.report-preview-section h3 {
  font-size:1.3rem;
  color:#10233d;
  margin-bottom:14px
}

.report-kpi-cards {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px
}

.report-kpi-card {
  padding:18px;
  border-radius:20px;
  background:linear-gradient(135deg, #f8fbff, #eef7ff);
  border:1px solid #dce9f7
}

.report-kpi-card span {
  display:block;
  color:#5b708b;
  font-size:0.92rem;
  margin-bottom:8px
}

.report-kpi-card strong {
  display:block;
  color:#10233d;
  font-size:1.5rem;
  line-height:1.1
}

.report-chart-wide {
  border:1px solid #e2eef9;
  border-radius:22px;
  background:#f9fcff;
  padding:18px;
  min-height:360px
}

.report-preview-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:24px
}

.report-derived-grid {
  display:grid;
  gap:10px
}

.report-derived-item {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.report-derived-item span {
  color:#5b708b
}

.report-derived-item strong {
  color:#10233d
}

.report-insights-box {
  min-height:180px;
  padding:18px;
  border-radius:20px;
  background:#f9fcff;
  border:1px solid #e2eef9;
  color:#5b708b;
  line-height:1.7
}

.report-summary-table-wrap {
  overflow-x:auto;
  border:1px solid #e2eef9;
  border-radius:20px;
  background:#ffffff
}

.report-summary-table {
  width:100%;
  border-collapse:collapse
}

.report-summary-table th, .report-summary-table td {
  padding:14px 16px;
  text-align:left;
  border-bottom:1px solid #eef4fb
}

.report-summary-table th {
  background:#f8fbff;
  color:#10233d;
  font-weight:700
}

.report-summary-table td {
  color:#5b708b
}

@media (max-width:1024px) {
  .report-kpi-cards {
    grid-template-columns:repeat(2, 1fr)
  }

  .report-preview-grid {
    grid-template-columns:1fr
  }

}

@media (max-width:768px) {
  .reporting-form-card, .report-preview-card {
    padding:20px
  }

  .reporting-topbar {
    flex-direction:column;
    align-items:stretch
  }

  .reporting-actions {
    flex-direction:column
  }

  .report-fields-2col, .report-kpi-cards {
    grid-template-columns:1fr
  }

  .report-preview-header h2 {
    font-size:2.2rem
  }

  .report-chart-wide {
    min-height:280px
  }

  .report-preview-meta {
    flex-direction:column;
    gap:6px
  }

}

.calendar-setup-card, .calendar-entry-card, .calendar-preview-card, .calendar-table-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  padding:24px
}

.calendar-setup-card, .calendar-entry-card, .calendar-preview-card {
  margin-bottom:24px
}

.calendar-tool-topbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:24px
}

.calendar-tool-topbar h2, .calendar-entry-head h2, .calendar-preview-head h2, .calendar-table-head h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d
}

.calendar-tool-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.calendar-setup-grid, .calendar-entry-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px
}

.calendar-field {
  display:flex;
  flex-direction:column;
  gap:8px
}

.calendar-field-wide {
  grid-column:span 2
}

.calendar-field label {
  font-size:0.96rem;
  font-weight:700;
  color:#10233d
}

.calendar-field input, .calendar-field select, .calendar-field textarea {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

.calendar-field textarea {
  resize:vertical;
  min-height:100px
}

.calendar-field input:focus, .calendar-field select:focus, .calendar-field textarea:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.calendar-preview-head, .calendar-table-head, .calendar-entry-head {
  margin-bottom:18px
}

.calendar-grid-head {
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:10px;
  margin-bottom:10px
}

.calendar-grid-head div {
  padding:12px;
  border-radius:16px;
  background:#f3f9ff;
  border:1px solid #dce9f7;
  color:#10233d;
  font-weight:700;
  text-align:center
}

.calendar-grid {
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:10px
}

.calendar-day {
  min-height:170px;
  padding:12px;
  border-radius:18px;
  background:#ffffff;
  border:1px solid #dce9f7;
  box-shadow:0 6px 16px rgba(16, 35, 61, 0.04);
  display:flex;
  flex-direction:column;
  gap:10px
}

.calendar-day.empty {
  background:#f9fcff
}

.calendar-day-number {
  font-weight:800;
  color:#10233d;
  font-size:1rem
}

.calendar-day-entries {
  display:flex;
  flex-direction:column;
  gap:8px
}

.calendar-entry-item {
  padding:10px;
  border-radius:14px;
  background:linear-gradient(135deg, #f8fbff, #eef7ff);
  border:1px solid #dce9f7
}

.calendar-entry-top {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:8px
}

.calendar-badge {
  display:inline-flex;
  align-items:center;
  padding:5px 9px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid #dce9f7;
  color:#1e88ff;
  font-size:0.75rem;
  font-weight:700
}

.calendar-entry-title {
  color:#10233d;
  font-size:0.9rem;
  font-weight:700;
  line-height:1.35
}

.calendar-entry-goal {
  color:#5b708b;
  font-size:0.82rem;
  margin-top:4px
}

.calendar-table-wrap {
  overflow-x:auto;
  border:1px solid #e2eef9;
  border-radius:20px;
  background:#ffffff
}

.calendar-detail-table {
  width:100%;
  border-collapse:collapse;
  min-width:980px
}

.calendar-detail-table th, .calendar-detail-table td {
  padding:14px 16px;
  text-align:left;
  border-bottom:1px solid #eef4fb;
  vertical-align:top
}

.calendar-detail-table th {
  background:#f8fbff;
  color:#10233d;
  font-weight:700
}

.calendar-detail-table td {
  color:#5b708b
}

.calendar-delete-btn {
  border:none;
  background:#fff3f3;
  color:#d92f2f;
  border:1px solid #ffd4d4;
  border-radius:12px;
  padding:8px 12px;
  font-weight:700;
  cursor:pointer
}

.calendar-delete-btn:hover {
  background:#ffeaea
}

@media (max-width:1024px) {
  .calendar-setup-grid, .calendar-entry-grid {
    grid-template-columns:repeat(2, 1fr)
  }

  .calendar-grid-head, .calendar-grid {
    grid-template-columns:repeat(7, minmax(150px, 1fr));
    overflow-x:auto
  }

}

@media (max-width:768px) {
  .calendar-setup-card, .calendar-entry-card, .calendar-preview-card, .calendar-table-card {
    padding:20px
  }

  .calendar-tool-topbar {
    flex-direction:column;
    align-items:stretch
  }

  .calendar-tool-actions {
    flex-direction:column
  }

  .calendar-setup-grid, .calendar-entry-grid {
    grid-template-columns:1fr
  }

  .calendar-field-wide {
    grid-column:span 1
  }

  .calendar-grid-head, .calendar-grid {
    display:grid;
    grid-template-columns:1fr
  }

  .calendar-grid-head {
    display:none
  }

  .calendar-day {
    min-height:auto
  }

}

.seo-meta-preview-grid, .seo-meta-lower-grid {
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:24px;
  margin-bottom:24px
}

.seo-preview-card, .seo-meta-form-card, .seo-best-practices-card, .seo-summary-card, .seo-entries-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06);
  padding:24px
}

.seo-serp-desktop, .seo-serp-mobile {
  border:1px solid #e3edf8;
  border-radius:20px;
  background:#fdfefe;
  padding:18px;
  min-height:180px
}

.seo-serp-url-row {
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px
}

.seo-serp-favicon {
  width:14px;
  height:14px;
  border-radius:50%;
  background:#188038;
  display:inline-block
}

.seo-serp-url {
  color:#188038;
  font-size:0.92rem
}

.seo-serp-title {
  color:#1a0dab;
  font-size:1.65rem;
  line-height:1.2;
  margin-bottom:8px
}

.seo-serp-title.mobile {
  font-size:1.35rem
}

.seo-serp-description {
  color:#4d5156;
  line-height:1.55
}

.seo-meta-head, .seo-entries-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:22px
}

.seo-meta-head h2, .seo-best-practices-card h2, .seo-summary-card h2, .seo-entries-head h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d
}

.seo-meta-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.seo-meta-grid {
  display:grid;
  gap:14px
}

.seo-field {
  display:flex;
  flex-direction:column;
  gap:8px
}

.seo-field label {
  font-size:0.96rem;
  font-weight:700;
  color:#10233d
}

.seo-field input, .seo-field textarea {
  width:100%;
  border:1px solid #d7e7f8;
  border-radius:16px;
  background:#ffffff;
  color:#10233d;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  transition:border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease
}

.seo-field textarea {
  resize:vertical;
  min-height:110px
}

.seo-field input:focus, .seo-field textarea:focus {
  outline:none;
  border-color:#9cccf8;
  box-shadow:0 0 0 4px rgba(30, 136, 255, 0.08);
  background:#fcfeff
}

.seo-feedback-line {
  font-size:0.95rem;
  color:#5b708b
}

.seo-feedback-line.good {
  color:#188038;
  font-weight:700
}

.seo-feedback-line.warn {
  color:#d98200;
  font-weight:700
}

.seo-feedback-line.bad {
  color:#d92f2f;
  font-weight:700
}

.seo-practice-list {
  display:grid;
  gap:16px
}

.seo-practice-item {
  padding:16px;
  border-radius:20px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.seo-practice-item h3 {
  color:#10233d;
  margin-bottom:10px;
  font-size:1.1rem
}

.seo-practice-item ul {
  padding-left:18px;
  color:#5b708b;
  display:grid;
  gap:8px
}

.seo-summary-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
  margin-bottom:16px
}

.seo-summary-item {
  padding:16px;
  border-radius:18px;
  background:#f9fcff;
  border:1px solid #e2eef9
}

.seo-summary-item span {
  display:block;
  color:#5b708b;
  font-size:0.9rem;
  margin-bottom:8px
}

.seo-summary-item strong {
  color:#10233d;
  font-size:1.3rem
}

.seo-checklist-box {
  min-height:220px;
  padding:18px;
  border-radius:20px;
  background:#f9fcff;
  border:1px solid #e2eef9;
  color:#5b708b;
  line-height:1.7
}

.seo-checklist-box p + p {
  margin-top:10px
}

.seo-entries-table-wrap {
  overflow-x:auto;
  border:1px solid #e2eef9;
  border-radius:20px;
  background:#ffffff
}

.seo-entries-table {
  width:100%;
  border-collapse:collapse;
  min-width:1000px
}

.seo-entries-table th, .seo-entries-table td {
  padding:14px 16px;
  text-align:left;
  border-bottom:1px solid #eef4fb;
  vertical-align:top
}

.seo-entries-table th {
  background:#f8fbff;
  color:#10233d;
  font-weight:700
}

.seo-entries-table td {
  color:#5b708b
}

.seo-delete-btn {
  border:none;
  background:#fff3f3;
  color:#d92f2f;
  border:1px solid #ffd4d4;
  border-radius:12px;
  padding:8px 12px;
  font-weight:700;
  cursor:pointer
}

.seo-delete-btn:hover {
  background:#ffeaea
}

@media (max-width:1024px) {
  .seo-meta-preview-grid, .seo-meta-lower-grid {
    grid-template-columns:1fr
  }

}

@media (max-width:768px) {
  .seo-preview-card, .seo-meta-form-card, .seo-best-practices-card, .seo-summary-card, .seo-entries-card {
    padding:20px
  }

  .seo-meta-head, .seo-entries-head {
    flex-direction:column;
    align-items:stretch
  }

  .seo-meta-actions {
    flex-direction:column
  }

  .seo-summary-grid {
    grid-template-columns:1fr
  }

  .seo-serp-title {
    font-size:1.35rem
  }

}

.blog-post-page {
  background:radial-gradient(circle at top left, rgba(77, 183, 255, 0.12), transparent 22%), linear-gradient(180deg, #eef7ff 0%, #ffffff 100%)
}

.article-hero {
  padding:90px 0 30px
}

.article-hero-inner {
  max-width:860px
}

.article-back-link {
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#1e88ff;
  font-weight:700;
  margin-bottom:18px
}

.article-category-tag {
  display:block;
  margin:0 0 14px
}

.article-back-link:hover {
  color:#0e6fe0
}

.article-hero h1 {
  font-size:clamp(2.5rem, 5vw, 4.4rem);
  line-height:1.06;
  margin-bottom:18px;
  color:#10233d;
  max-width:900px
}

.article-intro {
  font-size:1.12rem;
  color:#5b708b;
  max-width:760px;
  margin-bottom:22px
}

.article-meta {
  display:flex;
  flex-wrap:wrap;
  gap:10px
}

.article-meta span {
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid #dce9f7;
  color:#4f657f;
  font-weight:600;
  font-size:0.92rem
}

.article-layout {
  display:grid;
  grid-template-columns:1.05fr 0.35fr;
  gap:28px;
  align-items:start
}

.article-content, .article-sidebar-card {
  background:#ffffff;
  border:1px solid #dce9f7;
  border-radius:28px;
  box-shadow:0 10px 30px rgba(16, 35, 61, 0.06)
}

.article-content {
  overflow:hidden
}

.article-feature-box {
  padding:24px 24px 0
}

.article-feature-placeholder {
  min-height:320px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #e9f5ff, #f8fcff);
  color:#1d4f8f;
  font-size:1.3rem;
  font-weight:700;
  border:1px solid #e4eef9
}

.article-body {
  padding:30px 28px 34px
}

.article-body h2, .article-body h3 {
  scroll-margin-top:110px
}

.article-body h2 {
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.15;
  color:#10233d;
  margin:28px 0 12px
}

.article-body h3 {
  font-size:1.35rem;
  line-height:1.2;
  color:#10233d;
  margin:20px 0 8px
}

.article-body p, .article-body li {
  font-size:1.03rem;
  line-height:1.85;
  color:#5b708b
}

.article-body p + p {
  margin-top:14px
}

.article-body strong {
  color:#10233d;
  font-weight:700
}

.article-body ul {
  list-style:disc;
  list-style-position:outside;
  padding-left:26px;
  margin:10px 0 0
}

.article-body ol {
  list-style:decimal;
  list-style-position:outside;
  padding-left:26px;
  margin:10px 0 0
}

.article-body ul + p,
.article-body ol + p {
  margin-top:16px
}

.article-body li {
  display:list-item
}

.article-body li + li {
  margin-top:6px
}

.article-body a {
  color:#1e88ff;
  font-weight:600
}

.article-body a:hover {
  color:#0e6fe0
}

.article-sidebar {
  display:flex;
  flex-direction:column;
  gap:18px
}

.article-sidebar-card {
  padding:22px
}

.article-toc {
  display:grid;
  gap:10px
}

.article-toc a {
  color:#4f657f;
  font-weight:600
}

.article-toc a:hover {
  color:#1e88ff
}

.article-sidebar-card h3 {
  font-size:1.3rem;
  color:#10233d;
  margin-bottom:12px
}

.article-sidebar-card p {
  color:#5b708b
}

.article-sidebar-actions {
  display:grid;
  gap:10px;
  margin-top:18px
}

@media (max-width:1024px) {
  .article-layout {
    grid-template-columns:1fr
  }

  .article-sidebar {
    order:2
  }

}

@media (max-width:768px) {
  .article-hero {
    padding:70px 0 20px
  }

  .article-hero h1 {
    font-size:2.8rem;
    line-height:1.04
  }

  .article-intro {
    font-size:1rem;
    line-height:1.7
  }

  .article-feature-box {
    padding:18px 18px 0
  }

  .article-feature-placeholder {
    min-height:220px;
    font-size:1.05rem
  }

  .article-body {
    padding:24px 20px 28px
  }

  .article-body h2 {
    font-size:1.9rem
  }

  .article-body h3 {
    font-size:1.2rem
  }

  .article-body p, .article-body li {
    font-size:1rem;
    line-height:1.8
  }


  .article-sidebar-card {
    padding:20px
  }

}

.article-infographic {
  margin:24px 0 28px
}

.article-infographic-image {
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  border:1px solid #e4eef9;
  box-shadow:0 10px 24px rgba(16, 35, 61, 0.08)
}



/* Final safety override for link states across the full site */
.logo,
.logo:visited,
.nav-list a,
.nav-list a:visited,
.btn,
.btn:visited,
.content-link,
.content-link:visited,
.tool-link,
.tool-link:visited,
.footer-links a,
.footer-links a:visited,
.social-icons a,
.social-icons a:visited,
.article-back-link,
.article-back-link:visited,
.article-body a,
.article-body a:visited,
.article-toc a,
.article-toc a:visited {
  text-decoration:none;
}

.logo:hover,
.nav-list a:hover,
.btn:hover,
.content-link:hover,
.tool-link:hover,
.footer-links a:hover,
.social-icons a:hover,
.article-back-link:hover,
.article-body a:hover,
.article-toc a:hover {
  text-decoration:none;
}

img, svg, video, canvas {
  max-width:100%
}

img {
  height:auto
}

@supports (content-visibility:auto) {
  .section, .featured-blog-section, .blog-topics-section, .blog-grid-section, .about-story-section, .tools-section, .contact-section, .meta-tool-section, .google-tool-section, .reporting-section, .article-section {
    content-visibility:auto;
    contain-intrinsic-size:1px 800px
  }

}

@media (hover:none), (pointer:coarse) {
  .btn-primary:hover, .topics-grid .card:hover, .content-card:hover, .benefits-grid .card:hover, .video-card:hover, .blog-card:hover, .tool-card:hover, .social-icons a:hover, .topics-grid .card:hover .card-icon, .content-card:hover .content-thumb {
    transform:none
  }

}

@media (max-width:768px) {
  .site-header {
    background:rgba(255, 255, 255, .98);
    -webkit-backdrop-filter:none;
    backdrop-filter:none
  }

  .card, .content-card, .featured-video-box, .featured-blog-card, .video-card, .blog-card, .tool-card, .contact-form-card, .contact-info-card, .meta-tool-form-card, .meta-side-card, .google-tool-form-card, .google-side-card, .google-preview-card, .reporting-form-card, .report-preview-card, .calendar-setup-card, .calendar-entry-card, .calendar-preview-card, .calendar-table-card, .seo-preview-card, .seo-meta-form-card, .seo-best-practices-card, .seo-summary-card, .seo-entries-card {
    box-shadow:0 6px 18px rgba(16, 35, 61, .05)
  }

}

@media (prefers-reduced-motion:reduce) {
  html {
    scroll-behavior:auto
  }

  *, *::before, *::after {
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
    transition-duration:.01ms!important
  }

}

@media (max-width:768px) {
  .blog-scroll-area {
    max-height:720px;
    padding-right:6px;
  }
}

.content-thumb-video {
  padding:20px;
  min-height:210px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.youtube-lite {
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  background:#dfeefd;
}

.youtube-lite-button {
  width:100%;
  height:100%;
  border:0;
  padding:0;
  cursor:pointer;
  position:relative;
  background:#dfeefd;
}

.youtube-lite-button img {
  width:100%;
  height:100%;
  object-fit:cover;
}

.youtube-play-button {
  position:absolute;
  inset:50% auto auto 50%;
  transform:translate(-50%,-50%);
  width:68px;
  height:68px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(30,136,255,.94);
  color:#fff;
  font-size:1.8rem;
  line-height:1;
  box-shadow:0 12px 28px rgba(16,35,61,.22);
}

/* Final visual fixes: mobile captcha, contact overflow, tool icons, and homepage video thumbnail */

/* 1. Contact mobile captcha fix */

.captcha-placeholder {
  overflow: hidden;
  max-width: 100%;
}

.cf-turnstile,
.turnstile,
.captcha-placeholder iframe {
  max-width: 100% !important;
}

@media (max-width: 380px) {
  .cf-turnstile,
  .turnstile {
    transform: scale(.92);
    transform-origin: left top;
    width: 326px;
    margin-bottom: -8px;
  }
}


/* 2. Contact page input/card overflow fix */

.contact-form-card,
.contact-form,
.contact-info-card,
.contact-info-list,
.contact-info-item {
  max-width: 100%;
  min-width: 0;
}

.contact-info-card {
  overflow: visible;
}

.contact-form input,
.contact-form textarea,
.contact-form select,
.contact-form button,
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.contact-info-item > div,
.contact-info-item p,
.contact-info-item a {
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 768px) {
  .contact-form-card,
  .contact-info-card {
    padding-left: 20px;
    padding-right: 20px;
  }

  .contact-form input,
  .contact-form textarea,
  .form-group input,
  .form-group textarea {
    font-size: 16px;
  }
}


/* 3. Tool icons fix after removing Font Awesome */

.tool-card-icon {
  color: #1e88ff;
  background: linear-gradient(135deg, #eef7ff, #f8fcff);
  opacity: 1;
}

.tool-card-icon svg,
.tool-card-icon svg * {
  opacity: 1 !important;
}

.tool-card-icon svg {
  width: 26px;
  height: 26px;
  color: #1e88ff;
  stroke: currentColor;
  stroke-width: 2.2;
}

.tool-card-icon svg path,
.tool-card-icon svg circle,
.tool-card-icon svg line,
.tool-card-icon svg polyline,
.tool-card-icon svg rect {
  stroke: currentColor;
}

.tool-card-icon i,
.tool-card-icon .fa,
.tool-card-icon .fas,
.tool-card-icon .fab {
  color: #1e88ff;
  font-size: 1.45rem;
  opacity: 1;
}


/* 4. Homepage/video thumbnail clean crop fix */

.content-thumb-video,
.content-thumb.video-card-embed,
.content-thumb .youtube-lite,
.content-thumb-video .youtube-lite-button {
  position: relative;
  overflow: hidden;
  border-radius: inherit;
  background: #eaf6ff;
}

.content-thumb-video .youtube-lite-button,
.content-thumb .youtube-lite {
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}

.content-thumb-video .youtube-lite-button img,
.content-thumb.video-card-embed img,
.content-thumb .youtube-lite img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.06);
  transform-origin: center center;
}

/* Final tool icon visibility fix */

.tools-grid .tool-card .tool-card-icon {
  background: #eef7ff !important;
  border: 1px solid #b9dcff !important;
  color: #1e88ff !important;
  opacity: 1 !important;
}

.tools-grid .tool-card .tool-card-icon svg {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
  color: #1e88ff !important;
  opacity: 1 !important;
}

.tools-grid .tool-card .tool-card-icon svg *,
.tools-grid .tool-card .tool-card-icon svg path,
.tools-grid .tool-card .tool-card-icon svg circle,
.tools-grid .tool-card .tool-card-icon svg line,
.tools-grid .tool-card .tool-card-icon svg polyline,
.tools-grid .tool-card .tool-card-icon svg rect {
  opacity: 1 !important;
  color: #1e88ff !important;
  stroke: #1e88ff !important;
  fill: #1e88ff !important;
}

.tools-grid .tool-card .tool-card-icon svg [fill="none"] {
  fill: none !important;
  stroke: #1e88ff !important;
  stroke-width: 2.8 !important;
}

/* SEO title/meta preview realistic truncation fix */

.seo-serp-desktop,
.seo-serp-mobile {
  overflow: hidden;
}

.seo-serp-url,
.seo-serp-title,
.seo-serp-description {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.seo-serp-title {
  color:#1a0dab;
  font-size:1.65rem;
  line-height:1.2;
  margin-bottom:8px;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
  line-clamp:2;
  -webkit-line-clamp:2;
}

.seo-serp-title.mobile {
  font-size: 1.15rem;
  line-height: 1.25;
}

.seo-serp-description {
  color:#4d5156;
  line-height:1.55;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
  line-clamp:3;
  -webkit-line-clamp:3;
}

.seo-serp-description.mobile {
  font-size: 0.9rem;
}

/* =========================================================
   LearnDigital 2026 accessible redesign v2
   Visual system: deep navy + editorial paper + electric lime + warm amber.
   This block intentionally overrides earlier legacy palette rules while preserving:
   layout structure, selectors, responsive behaviour, YouTube lite embeds,
   tool page functionality, and prior performance-related CSS.
   ========================================================= */

:root {
  --ld-navy:#0A0F1E;
  --ld-navy-2:#0E1529;
  --ld-navy-3:#131C33;
  --ld-navy-4:#18223C;

  --ld-paper:#F5F3EE;
  --ld-paper-2:#FFFDF8;
  --ld-paper-3:#ECE8DE;

  --ld-ink:#111111;
  --ld-ink-soft:#242A35;
  --ld-muted-light:#495364;
  --ld-muted-light-2:#667085;

  --ld-white:#FFFFFF;
  --ld-muted-dark:#D9E1EA;
  --ld-muted-dark-2:#B9C4D3;

  --ld-lime:#C8F135;
  --ld-lime-soft:#E4F7A7;
  --ld-lime-ink:#536300;
  --ld-lime-link:#415500;

  --ld-amber:#F4A535;
  --ld-amber-soft:#FFE2B2;
  --ld-amber-ink:#9A5A00;
  --ld-amber-link:#6B4500;

  --ld-good:#166534;
  --ld-warn:#9A5A00;
  --ld-bad:#B42318;

  --ld-line-dark:rgba(200,241,53,.20);
  --ld-line-dark-soft:rgba(255,255,255,.16);
  --ld-line-light:rgba(17,17,17,.14);
  --ld-line-light-strong:rgba(17,17,17,.22);

  --ld-shadow-dark:0 28px 80px rgba(0,0,0,.32);
  --ld-shadow-dark-soft:0 18px 44px rgba(0,0,0,.22);
  --ld-shadow-light:0 18px 46px rgba(10,15,30,.12);
  --ld-shadow-light-soft:0 10px 30px rgba(10,15,30,.08);

  --ld-radius-xl:34px;
  --ld-radius-lg:28px;
  --ld-radius-md:22px;
  --ld-radius-sm:18px;
}

html {
  scroll-behavior:smooth;
}

body {
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  background:var(--ld-navy);
  color:var(--ld-white);
}

::selection {
  background:var(--ld-lime);
  color:var(--ld-ink);
}

h1,h2,h3,h4,h5,h6,
.logo,
.btn,
.highlight-number {
  letter-spacing:-.035em;
}

p,
li {
  text-wrap:pretty;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline:3px solid var(--ld-lime);
  outline-offset:4px;
}

/* ---------- Global section logic ---------- */

main > .section {
  position:relative;
  background:var(--ld-paper);
  color:var(--ld-ink);
}

.home-page .featured-videos,
.home-page .about-preview,
.home-page .cta-section {
  background:
    radial-gradient(circle at 10% 18%,rgba(200,241,53,.12),transparent 24%),
    radial-gradient(circle at 90% 86%,rgba(244,165,53,.12),transparent 20%),
    linear-gradient(180deg,var(--ld-navy) 0%,var(--ld-navy-2) 100%);
  color:var(--ld-white);
}

.hero,
.videos-hero,
.blog-hero,
.about-page-hero,
.tools-hero,
.contact-hero,
.article-hero {
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%,rgba(200,241,53,.18),transparent 26%),
    radial-gradient(circle at 88% 12%,rgba(244,165,53,.16),transparent 22%),
    linear-gradient(180deg,var(--ld-navy) 0%,#0D1428 100%) !important;
  color:var(--ld-white);
}

.hero::before,
.videos-hero::before,
.blog-hero::before,
.about-page-hero::before,
.tools-hero::before,
.contact-hero::before,
.article-hero::before {
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:.22;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.94),transparent 94%);
}

.topics,
.latest-posts,
.benefits,
.featured-blog-section,
.blog-topics-section,
.blog-grid-section,
.about-story-section,
.tools-section,
.contact-section,
.meta-tool-section,
.google-tool-section,
.reporting-section,
.article-section {
  background:var(--ld-paper);
  color:var(--ld-ink);
}

/* ---------- Shared typography ---------- */

.section-heading h2,
.about-content h2,
.cta-box h2,
.featured-video-text h2,
.featured-blog-content h2,
.contact-info-card h2,
.meta-tool-topbar h2,
.google-tool-topbar h2,
.reporting-topbar h2,
.report-preview-header h2,
.calendar-tool-topbar h2,
.calendar-entry-head h2,
.calendar-preview-head h2,
.calendar-table-head h2,
.seo-meta-head h2,
.seo-best-practices-card h2,
.seo-summary-card h2,
.seo-entries-head h2,
.article-sidebar-card h3,
.card h3,
.content-body h3,
.video-card-body h3,
.blog-card-body h3,
.tool-card-body h3,
.about-sticky-content h3 {
  font-weight:900;
  color:var(--ld-ink);
}

.section-heading p,
.card p,
.content-body p,
.video-card-body p,
.blog-card-body p,
.tool-card-body p,
.about-content p,
.about-text-block p,
.about-sticky-content p,
.featured-video-text p,
.featured-blog-content p,
.contact-info-card p,
.captcha-text p,
.contact-info-item p,
.meta-tool-block-head p,
.meta-side-list li,
.google-tool-block-head p,
.google-side-list li,
.google-anatomy-sub,
.reporting-form-card p,
.report-block-head p,
.report-preview-meta,
.report-insights-box,
.calendar-entry-goal,
.seo-feedback-line,
.seo-practice-item ul,
.seo-checklist-box,
.article-intro,
.article-body p,
.article-body li,
.article-sidebar-card p {
  color:var(--ld-muted-light);
}

.hero-content h1,
.videos-heading h1,
.blog-heading h1,
.about-page-heading h1,
.tools-heading h1,
.contact-heading h1,
.article-hero h1 {
  color:var(--ld-white);
  font-weight:950;
  letter-spacing:-.055em;
}

.hero-text,
.videos-heading p,
.blog-heading p,
.about-page-heading p,
.tools-heading p,
.contact-heading p,
.article-intro {
  color:var(--ld-muted-dark);
}

.home-page .featured-videos .section-heading h2,
.home-page .about-preview .about-content h2,
.home-page .cta-box h2,
.home-page .featured-videos .content-body h3 {
  color:var(--ld-white);
}

.home-page .featured-videos .section-heading p,
.home-page .about-preview .about-content p,
.home-page .cta-box p,
.home-page .featured-videos .content-body p {
  color:var(--ld-muted-dark);
}

/* ---------- Editorial tags / micro labels ---------- */

.section-tag,
.eyebrow,
.post-meta,
.tool-tag {
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.78rem;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.14em;
  margin-bottom:16px;
  color:var(--ld-lime-ink);
}

.article-category-tag {
  display:flex;
  align-items:center;
  width:max-content;
  gap:10px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.78rem;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.14em;
  margin:0 0 16px;
  color:var(--ld-lime-ink);
}

.section-tag::before,
.eyebrow::before,
.post-meta::before,
.tool-tag::before,
.article-category-tag::before {
  content:"";
  width:24px;
  height:2px;
  flex:0 0 auto;
  background:currentColor;
}

.hero .eyebrow,
.videos-hero .section-tag,
.blog-hero .section-tag,
.about-page-hero .section-tag,
.tools-hero .section-tag,
.contact-hero .section-tag,
.article-hero .article-category-tag,
.home-page .featured-videos .section-tag,
.home-page .about-preview .section-tag,
.home-page .cta-section .section-tag {
  color:var(--ld-lime);
}

.post-meta,
.blog-card .post-meta,
.content-card .post-meta,
.tool-tag,
.article-category-tag {
  color:var(--ld-lime-ink);
}

.article-hero .article-category-tag {
  color:var(--ld-lime);
}

/* ---------- Header / navigation ---------- */

.site-header {
  background:rgba(10,15,30,.92) !important;
  border-bottom:1px solid var(--ld-line-dark);
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
}

.logo {
  color:var(--ld-white);
  font-weight:950;
  letter-spacing:-.045em;
}

.logo-accent {
  color:var(--ld-lime);
}

.nav-list a {
  color:var(--ld-muted-dark);
  font-weight:750;
  transition:color .22s ease;
}

.nav-list a:hover,
.nav-list a:focus-visible {
  color:var(--ld-lime);
}

.nav-toggle {
  color:var(--ld-white);
}

.mobile-menu-js {
  background:var(--ld-navy) !important;
  border-top:1px solid var(--ld-line-dark) !important;
  border-bottom:1px solid var(--ld-line-dark) !important;
}

.mobile-menu-js .nav-list a {
  color:var(--ld-white) !important;
}

.mobile-menu-js .nav-list a:hover,
.mobile-menu-js .nav-list a:focus-visible {
  color:var(--ld-lime) !important;
}

/* ---------- Buttons ---------- */

.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:14px 24px;
  border-radius:999px;
  font-weight:900;
  transition:
    transform .25s ease,
    box-shadow .25s ease,
    background .25s ease,
    border-color .25s ease,
    color .25s ease;
}

.btn-primary {
  background:var(--ld-lime);
  color:var(--ld-ink);
  box-shadow:0 18px 42px rgba(200,241,53,.18);
}

.btn-primary:hover {
  transform:translateY(-3px);
  background:#D4F45A;
  color:var(--ld-ink);
  box-shadow:0 22px 50px rgba(200,241,53,.26);
}

.btn-secondary {
  border:1px solid var(--ld-line-light-strong);
  background:rgba(17,17,17,.03);
  color:var(--ld-ink);
}

.btn-secondary:hover {
  transform:translateY(-2px);
  background:rgba(17,17,17,.07);
  border-color:rgba(17,17,17,.34);
  color:var(--ld-ink);
}

.hero .btn-secondary,
.videos-hero .btn-secondary,
.blog-hero .btn-secondary,
.about-page-hero .btn-secondary,
.tools-hero .btn-secondary,
.contact-hero .btn-secondary,
.article-hero .btn-secondary,
.home-page .featured-videos .btn-secondary,
.home-page .about-preview .btn-secondary,
.home-page .cta-section .btn-secondary,
.site-footer .btn-secondary {
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.06);
  color:var(--ld-white);
}

.hero .btn-secondary:hover,
.videos-hero .btn-secondary:hover,
.blog-hero .btn-secondary:hover,
.about-page-hero .btn-secondary:hover,
.tools-hero .btn-secondary:hover,
.contact-hero .btn-secondary:hover,
.article-hero .btn-secondary:hover,
.home-page .featured-videos .btn-secondary:hover,
.home-page .about-preview .btn-secondary:hover,
.home-page .cta-section .btn-secondary:hover,
.site-footer .btn-secondary:hover {
  background:rgba(255,255,255,.11);
  border-color:rgba(200,241,53,.46);
  color:var(--ld-white);
}

/* ---------- Hero and homepage ---------- */

.home-page .hero-content,
.home-page .hero-image-wrapper {
  position:relative;
  z-index:1;
}

.home-page .hero-content h1 {
  font-size:clamp(2.8rem,5.6vw,5rem);
  line-height:.98;
  max-width:780px;
}

.home-page .hero-text {
  font-size:1.12rem;
  color:var(--ld-muted-dark);
}

.home-page .highlight-card {
  background:rgba(255,255,255,.06);
  border:1px solid var(--ld-line-dark);
  border-radius:22px;
  box-shadow:var(--ld-shadow-dark-soft);
}

.home-page .highlight-number {
  color:var(--ld-lime);
  font-weight:950;
}

.home-page .highlight-label {
  color:var(--ld-muted-dark);
}

.home-page .hero-image-wrapper {
  min-height:520px;
}

.home-page .hero-image-wrapper::before {
  content:"";
  position:absolute;
  width:min(100%,470px);
  height:min(100%,470px);
  border-radius:36px;
  border:1px solid rgba(200,241,53,.28);
  background:
    radial-gradient(circle at 24% 20%,rgba(200,241,53,.22),transparent 34%),
    linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.02));
  box-shadow:var(--ld-shadow-dark);
}

.home-page .hero-image-wrapper::after {
  content:"[ LEARN DIGITAL ]";
  position:absolute;
  right:16px;
  bottom:38px;
  z-index:2;
  color:var(--ld-ink);
  background:var(--ld-lime);
  padding:10px 14px;
  border-radius:999px;
  font:850 .74rem/1 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  letter-spacing:.12em;
}

.home-page .hero-image {
  transform:translateY(-8px);
  -webkit-mask-image:none;
  mask-image:none;
}

.home-page .topics::before,
.home-page .latest-posts::before,
.home-page .benefits::before,
.featured-blog-section::before,
.blog-grid-section::before,
.tools-section::before,
.contact-section::before {
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.28;
  background-image:
    radial-gradient(circle at 8% 20%,rgba(200,241,53,.24),transparent 24%),
    radial-gradient(circle at 92% 84%,rgba(244,165,53,.16),transparent 22%);
}

.home-page .topics .container,
.home-page .latest-posts .container,
.home-page .benefits .container,
.featured-blog-section .container,
.blog-grid-section .container,
.tools-section .container,
.contact-section .container {
  position:relative;
  z-index:1;
}

/* ---------- Universal card system ---------- */

.card,
.content-card,
.featured-video-box,
.featured-blog-card,
.video-card,
.blog-card,
.tool-card,
.contact-form-card,
.contact-info-card,
.meta-tool-form-card,
.meta-side-card,
.google-tool-form-card,
.google-side-card,
.google-preview-card,
.reporting-form-card,
.report-preview-card,
.calendar-setup-card,
.calendar-entry-card,
.calendar-preview-card,
.calendar-table-card,
.seo-preview-card,
.seo-meta-form-card,
.seo-best-practices-card,
.seo-summary-card,
.seo-entries-card,
.article-content,
.article-sidebar-card {
  position:relative;
  background:rgba(255,253,248,.96);
  color:var(--ld-ink);
  border:1px solid var(--ld-line-light);
  border-radius:var(--ld-radius-lg);
  box-shadow:var(--ld-shadow-light);
}

.card,
.content-card,
.video-card,
.blog-card,
.tool-card {
  overflow:hidden;
}

.card::before,
.content-card::before,
.video-card::before,
.blog-card::before,
.tool-card::before,
.contact-form-card::before,
.contact-info-card::before,
.meta-tool-form-card::before,
.meta-side-card::before,
.google-tool-form-card::before,
.google-side-card::before,
.google-preview-card::before,
.reporting-form-card::before,
.report-preview-card::before,
.calendar-setup-card::before,
.calendar-entry-card::before,
.calendar-preview-card::before,
.calendar-table-card::before,
.seo-preview-card::before,
.seo-meta-form-card::before,
.seo-best-practices-card::before,
.seo-summary-card::before,
.seo-entries-card::before,
.article-content::before,
.article-sidebar-card::before {
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:4px;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--ld-lime),var(--ld-amber));
  pointer-events:none;
}

.topics-grid .card:hover,
.content-card:hover,
.benefits-grid .card:hover,
.video-card:hover,
.blog-card:hover,
.tool-card:hover {
  transform:translateY(-8px);
  border-color:var(--ld-line-light-strong);
  box-shadow:0 24px 54px rgba(10,15,30,.18);
}

.home-page .featured-videos .content-card,
.home-page .about-image-box,
.home-page .cta-box {
  background:rgba(255,255,255,.06);
  color:var(--ld-white);
  border:1px solid var(--ld-line-dark);
  box-shadow:var(--ld-shadow-dark);
}

.home-page .featured-videos .content-card:hover {
  border-color:rgba(200,241,53,.42);
  box-shadow:0 34px 84px rgba(0,0,0,.42);
}

/* ---------- Icons / visual labels ---------- */

.card-icon,
.tool-card-icon,
.contact-info-icon,
.captcha-icon {
  background:var(--ld-lime);
  color:var(--ld-ink);
  border:1px solid rgba(17,17,17,.14);
  box-shadow:none;
}

.topics-grid .card:hover .card-icon {
  background:var(--ld-amber);
  color:var(--ld-ink);
  transform:translateY(-2px) rotate(-2deg);
  box-shadow:none;
}

.tools-grid .tool-card .tool-card-icon {
  background:var(--ld-lime) !important;
  border:1px solid rgba(17,17,17,.14) !important;
  color:var(--ld-ink) !important;
  opacity:1 !important;
}

.tools-grid .tool-card .tool-card-icon svg {
  width:28px !important;
  height:28px !important;
  display:block !important;
  color:var(--ld-ink) !important;
  opacity:1 !important;
}

.tools-grid .tool-card .tool-card-icon svg *,
.tools-grid .tool-card .tool-card-icon svg path,
.tools-grid .tool-card .tool-card-icon svg circle,
.tools-grid .tool-card .tool-card-icon svg line,
.tools-grid .tool-card .tool-card-icon svg polyline,
.tools-grid .tool-card .tool-card-icon svg rect {
  opacity:1 !important;
  color:var(--ld-ink) !important;
  stroke:var(--ld-ink) !important;
  fill:var(--ld-ink) !important;
}

.tools-grid .tool-card .tool-card-icon svg [fill="none"] {
  fill:none !important;
  stroke:var(--ld-ink) !important;
  stroke-width:2.8 !important;
}

/* ---------- Links ---------- */

.content-link,
.tool-link,
.article-back-link,
.article-body a,
.article-toc a {
  color:var(--ld-lime-link);
  font-weight:850;
}

.content-link:hover,
.tool-link:hover,
.article-back-link:hover,
.article-body a:hover,
.article-toc a:hover {
  color:var(--ld-amber-link);
}

.home-page .featured-videos .content-link,
.hero .article-back-link,
.article-hero .article-back-link {
  color:var(--ld-lime);
}

.home-page .featured-videos .content-link:hover,
.hero .article-back-link:hover,
.article-hero .article-back-link:hover {
  color:var(--ld-amber);
}

/* ---------- Media thumbnails and YouTube lite ---------- */

.content-thumb {
  color:var(--ld-ink);
  background:
    linear-gradient(135deg,rgba(200,241,53,.20),rgba(244,165,53,.14)),
    var(--ld-paper-3);
  border-bottom:1px solid var(--ld-line-light);
}

.home-page .featured-videos .content-thumb,
.content-thumb-video,
.youtube-lite,
.youtube-lite-button,
.video-embed,
.video-card-embed {
  background:var(--ld-navy-3);
}

.home-page .featured-videos .content-thumb {
  color:var(--ld-white);
  border-bottom:1px solid var(--ld-line-dark);
}

.youtube-lite {
  border-radius:18px;
  border:1px solid rgba(200,241,53,.20);
}

.youtube-play-button {
  background:var(--ld-lime);
  color:var(--ld-ink);
  box-shadow:0 16px 36px rgba(0,0,0,.34);
}

/* ---------- Blog page and scroll area ---------- */

.featured-blog-image,
.article-feature-placeholder,
.anatomy-media,
.google-display-media,
.google-anatomy-media {
  background:
    linear-gradient(135deg,rgba(200,241,53,.18),rgba(244,165,53,.12)),
    var(--ld-paper-3);
  color:var(--ld-ink);
  border:1px solid var(--ld-line-light);
}

.topic-pill,
.google-tab,
.report-tab {
  border:1px solid var(--ld-line-light-strong);
  background:rgba(255,253,248,.95);
  color:var(--ld-ink-soft);
  font-weight:800;
}

.topic-pill:hover,
.google-tab:hover,
.report-tab:hover {
  background:var(--ld-lime-soft);
  border-color:rgba(83,99,0,.36);
  color:var(--ld-ink);
}

.topic-pill.active,
.google-tab.active,
.report-tab.active {
  background:var(--ld-lime);
  color:var(--ld-ink);
  border-color:rgba(17,17,17,.18);
}

.blog-scroll-area::-webkit-scrollbar-track {
  background:rgba(17,17,17,.08);
}

.blog-scroll-area::-webkit-scrollbar-thumb {
  background:rgba(83,99,0,.52);
}

.blog-scroll-area::-webkit-scrollbar-thumb:hover {
  background:rgba(83,99,0,.72);
}

.blog-loader p {
  color:var(--ld-muted-light);
}

/* ---------- About page ---------- */

.about-image-box {
  background:rgba(255,253,248,.96);
  border:1px solid var(--ld-line-light);
  border-radius:var(--ld-radius-xl);
  box-shadow:var(--ld-shadow-light);
}

.home-page .about-image-box {
  background:rgba(255,255,255,.06);
  border:1px solid var(--ld-line-dark);
  box-shadow:var(--ld-shadow-dark);
}

.about-text-block h2,
.about-text-block h3,
.about-sticky-content h3 {
  color:var(--ld-ink);
  font-weight:900;
}

/* ---------- CTA ---------- */

.cta-box {
  position:relative;
  overflow:hidden;
  text-align:center;
  border-radius:var(--ld-radius-xl);
}

.home-page .cta-box {
  padding:58px 28px;
  background:
    radial-gradient(circle at 20% 22%,rgba(200,241,53,.20),transparent 28%),
    linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
}

.home-page .cta-box::before {
  content:"";
  position:absolute;
  inset:18px;
  height:auto;
  width:auto;
  border-radius:calc(var(--ld-radius-xl) - 10px);
  border:1px dashed rgba(200,241,53,.24);
  background:none;
  pointer-events:none;
}

.home-page .cta-box > * {
  position:relative;
  z-index:1;
}

/* ---------- Forms and inputs ---------- */

.form-group label,
.meta-field label,
.google-field label,
.report-field label,
.calendar-field label,
.seo-field label {
  color:var(--ld-ink);
  font-weight:850;
}

.form-group input,
.form-group textarea,
.meta-input,
.google-input,
.report-field input,
.report-field textarea,
.calendar-field input,
.calendar-field select,
.calendar-field textarea,
.seo-field input,
.seo-field textarea {
  background:var(--ld-paper-2);
  color:var(--ld-ink);
  border:1px solid rgba(17,17,17,.22);
}

.form-group input::placeholder,
.form-group textarea::placeholder,
.meta-input::placeholder,
.google-input::placeholder,
.report-field input::placeholder,
.report-field textarea::placeholder,
.calendar-field input::placeholder,
.calendar-field textarea::placeholder,
.seo-field input::placeholder,
.seo-field textarea::placeholder {
  color:var(--ld-muted-light-2);
}

.form-group input:focus,
.form-group textarea:focus,
.meta-input:focus,
.google-input:focus,
.report-field input:focus,
.report-field textarea:focus,
.calendar-field input:focus,
.calendar-field select:focus,
.calendar-field textarea:focus,
.seo-field input:focus,
.seo-field textarea:focus {
  outline:none;
  border-color:var(--ld-lime-ink);
  box-shadow:0 0 0 4px rgba(200,241,53,.28);
  background:#FFFFFF;
}

.captcha-placeholder,
.contact-info-item,
.meta-ad-anatomy,
.google-search-preview,
.google-display-preview,
.google-anatomy-search,
.google-anatomy-display,
.report-chart-wide,
.report-insights-box,
.report-summary-table-wrap,
.calendar-table-wrap,
.seo-serp-desktop,
.seo-serp-mobile,
.seo-checklist-box,
.seo-entries-table-wrap {
  background:rgba(255,253,248,.92);
  border-color:var(--ld-line-light);
}

.captcha-text strong,
.contact-info-item h3 {
  color:var(--ld-ink);
}

/* ---------- Tool-specific information blocks ---------- */

.anatomy-box,
.anatomy-media,
.anatomy-headline,
.anatomy-description,
.anatomy-cta,
.google-anatomy-line,
.meta-limit-item,
.google-limit-item,
.report-kpi-card,
.report-derived-item,
.calendar-grid-head div,
.calendar-day,
.calendar-entry-item,
.calendar-badge,
.seo-practice-item,
.seo-summary-item {
  background:rgba(255,253,248,.96);
  color:var(--ld-ink);
  border-color:var(--ld-line-light);
}

.anatomy-description,
.google-search-description,
.google-display-description,
.meta-limit-item span,
.google-limit-item span,
.report-kpi-card span,
.report-derived-item span,
.calendar-entry-goal,
.calendar-detail-table td,
.seo-summary-item span,
.seo-entries-table td {
  color:var(--ld-muted-light);
}

.anatomy-headline,
.anatomy-cta,
.meta-limit-item strong,
.google-limit-item strong,
.report-kpi-card strong,
.report-derived-item strong,
.calendar-day-number,
.calendar-entry-title,
.calendar-detail-table th,
.seo-summary-item strong,
.seo-entries-table th {
  color:var(--ld-ink);
}

.google-display-cta {
  background:var(--ld-lime);
  color:var(--ld-ink);
}

.report-summary-table th,
.calendar-detail-table th,
.seo-entries-table th {
  background:rgba(200,241,53,.18);
  color:var(--ld-ink);
}

.report-summary-table td,
.calendar-detail-table td,
.seo-entries-table td {
  color:var(--ld-muted-light);
}

.calendar-badge {
  color:var(--ld-lime-ink);
}

.calendar-delete-btn,
.seo-delete-btn {
  background:#FCE7E5;
  color:var(--ld-bad);
  border:1px solid rgba(180,35,24,.28);
}

.calendar-delete-btn:hover,
.seo-delete-btn:hover {
  background:#F8D2CF;
}

/* ---------- Counters / status colours ---------- */

.meta-counter,
.google-counter {
  color:var(--ld-muted-light);
}

.meta-counter.limit-near,
.google-counter.limit-near,
.seo-feedback-line.warn {
  color:var(--ld-warn);
  font-weight:900;
}

.meta-counter.limit-max,
.google-counter.limit-max,
.seo-feedback-line.bad {
  color:var(--ld-bad);
  font-weight:900;
}

.seo-feedback-line.good {
  color:var(--ld-good);
  font-weight:900;
}

/* ---------- Search preview realism retained, contrast checked against light preview background ---------- */

.google-search-url,
.seo-serp-url {
  color:#166534;
}

.google-search-headlines,
.seo-serp-title {
  color:#1A0DAB;
}

.google-search-description,
.seo-serp-description {
  color:#374151;
}

/* ---------- Article pages ---------- */

.blog-post-page {
  background:
    radial-gradient(circle at top left,rgba(200,241,53,.12),transparent 22%),
    linear-gradient(180deg,var(--ld-navy) 0%,var(--ld-paper) 24%,var(--ld-paper) 100%);
}

.article-meta span {
  background:rgba(255,255,255,.08);
  border:1px solid var(--ld-line-dark);
  color:var(--ld-muted-dark);
}

.article-content,
.article-sidebar-card {
  background:rgba(255,253,248,.97);
}

.article-body h2,
.article-body h3,
.article-body strong,
.article-sidebar-card h3 {
  color:var(--ld-ink);
}

.article-body p,
.article-body li,
.article-sidebar-card p,
.article-toc a {
  color:var(--ld-muted-light);
}

.article-toc a:hover {
  color:var(--ld-lime-link);
}

.article-infographic-image {
  border:1px solid var(--ld-line-light);
  box-shadow:var(--ld-shadow-light-soft);
}

/* ---------- Footer ---------- */

.site-footer {
  background:#070B16;
  border-top:1px solid var(--ld-line-dark);
}

.footer-brand .logo,
.footer-links h4 {
  color:var(--ld-white);
}

.footer-brand p,
.footer-bottom p {
  color:var(--ld-muted-dark-2);
}

.footer-links a {
  color:var(--ld-muted-dark);
}

.footer-links a:hover,
.social-icons a:hover {
  color:var(--ld-lime);
}

.social-icons a {
  color:var(--ld-white);
}

/* ---------- Accessibility hardening for legacy areas ---------- */

.muted-link {
  color:var(--ld-muted-light);
}

.google-display-long,
.google-display-headline,
.captcha-text strong,
.contact-info-item h3,
.report-preview-section h3,
.report-block-head h3,
.google-tool-block-head h3,
.meta-tool-block-head h3,
.seo-practice-item h3 {
  color:var(--ld-ink);
}

.about-page-text,
.about-page-sidebar,
.tools-section,
.contact-section,
.meta-tool-section,
.google-tool-section,
.reporting-section,
.blog-grid-section,
.blog-topics-section,
.featured-blog-section {
  color:var(--ld-ink);
}

/* ---------- Mobile ---------- */

@media (max-width:1024px) {
  .home-page .hero-image-wrapper {
    min-height:auto;
  }
}

@media (max-width:768px) {
  .site-header {
    background:rgba(10,15,30,.98) !important;
    -webkit-backdrop-filter:none;
    backdrop-filter:none;
  }

  .home-page .hero {
    padding:42px 0 56px;
  }

  .home-page .hero-content h1 {
    font-size:3.05rem;
    line-height:.98;
  }

  .home-page .hero-text {
    color:var(--ld-muted-dark);
  }

  .home-page .cta-box {
    padding:38px 20px;
  }

  .card,
  .content-card,
  .featured-video-box,
  .featured-blog-card,
  .video-card,
  .blog-card,
  .tool-card,
  .contact-form-card,
  .contact-info-card,
  .meta-tool-form-card,
  .meta-side-card,
  .google-tool-form-card,
  .google-side-card,
  .google-preview-card,
  .reporting-form-card,
  .report-preview-card,
  .calendar-setup-card,
  .calendar-entry-card,
  .calendar-preview-card,
  .calendar-table-card,
  .seo-preview-card,
  .seo-meta-form-card,
  .seo-best-practices-card,
  .seo-summary-card,
  .seo-entries-card,
  .article-content,
  .article-sidebar-card {
    box-shadow:0 8px 22px rgba(10,15,30,.10);
  }
}

/* Mobile header fix: hide only the top header CTA, keep the menu CTA visible */
@media (max-width:768px) {
  .nav-wrapper > .nav-cta {
    display:none !important;
  }
}

/* =========================================
   CONTACT SUCCESS / ERROR PAGES
  
   ========================================= */

.contact-status-page {
  min-height:100vh;
  background:
    radial-gradient(circle at 12% 18%, rgba(200,241,53,.18), transparent 28%),
    radial-gradient(circle at 88% 14%, rgba(244,165,53,.14), transparent 24%),
    linear-gradient(180deg, #0A0F1E 0%, #0D1428 100%);
  color:#FFFFFF;
}

.status-page-main {
  min-height:100vh;
  width:min(1120px, 90%);
  margin:0 auto;
  display:grid;
  place-items:center;
  padding:48px 0;
}

.status-card {
  position:relative;
  width:min(720px, 100%);
  padding:56px;
  border-radius:36px;
  background:#FFFDF8;
  border:1px solid rgba(17,17,17,.14);
  box-shadow:0 32px 90px rgba(0,0,0,.34);
  text-align:center;
  color:#111111;
  overflow:hidden;
}

.status-card::before {
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:5px;
  background:linear-gradient(90deg, #C8F135 0%, #F4A535 100%);
}

.status-card-badge {
  display:flex;
  justify-content:center;
  margin-bottom:22px;
}

.status-card .section-tag {
  color:#536300;
  margin-bottom:0;
}

.status-card .section-tag::before {
  background:#536300;
}

.status-icon {
  width:88px;
  height:88px;
  margin:0 auto 24px;
  display:grid;
  place-items:center;
  border-radius:28px;
  font-size:2.8rem;
  line-height:1;
  font-weight:950;
  background:#111111;
  color:#C8F135;
  box-shadow:0 18px 36px rgba(10,15,30,.18);
}

.status-card-error .status-icon {
  color:#F4A535;
}

.status-card h1 {
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1;
  letter-spacing:-.055em;
  font-weight:950;
  margin-bottom:18px;
  color:#111111;
}

.status-card p {
  max-width:560px;
  margin:0 auto 28px;
  color:#495364;
  font-size:1.08rem;
  line-height:1.75;
}

.status-actions {
  display:flex;
  justify-content:center;
}

.status-actions .btn {
  min-width:210px;
}

@media (max-width:768px) {
  .status-page-main {
    padding:28px 0;
  }

  .status-card {
    padding:34px 22px;
    border-radius:28px;
  }

  .status-icon {
    width:76px;
    height:76px;
    border-radius:24px;
    font-size:2.35rem;
    margin-bottom:20px;
  }

  .status-card h1 {
    font-size:2.65rem;
    line-height:1.02;
  }

  .status-card p {
    font-size:1rem;
    line-height:1.7;
  }

  .status-actions .btn {
    width:100%;
    min-width:0;
  }
}

/* =========================================================
   CONTACT PAGE FINAL MOBILE CLIPPING FIX
   Keeps the full Contact Info card visible, including
   the third "Response" item, on smaller screens.
   ========================================================= */

.contact-page .contact-section {
  content-visibility: visible !important;
  contain-intrinsic-size: auto !important;
  overflow: visible !important;
}

.contact-page .contact-section .container,
.contact-page .contact-grid,
.contact-page .contact-info-card,
.contact-page .contact-info-list,
.contact-page .contact-info-item {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

.contact-page .contact-info-card {
  align-self: start;
}

.contact-page .contact-info-item > div {
  flex: 1 1 auto;
  min-width: 0;
}

.contact-page .contact-info-item p,
.contact-page .contact-info-item a {
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 1024px) {
  .contact-page .contact-info-card {
    position: static !important;
    top: auto !important;
  }
}

