/*
Theme Name: Astra Child
Template: astra
Description: Astra child theme for Secure Entry Commercial landing page.
Version: 1.0.0
*/

:root {
      --black: #101010;
      --dark: #171717;
      --text: #18181b;
      --muted: #60656d;
      --line: #e4e4e7;
      --soft: #f6f6f7;
      --soft-2: #fbfbfb;
      --white: #ffffff;
      --radius-xl: 36px;
      --radius-lg: 28px;
      --radius-md: 20px;
      --shadow: 0 24px 72px rgba(0, 0, 0, 0.10);
      --shadow-soft: 0 14px 36px rgba(0, 0, 0, 0.06);
      --max: 1240px;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color: var(--text);
      background: var(--white);
      line-height: 1.5;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    img {
      display: block;
      max-width: 100%;
    }

    .container {
      width: min(var(--max), calc(100% - 48px));
      margin: 0 auto;
    }

    .topbar {
      position: sticky;
      top: 0;
      z-index: 100;
      backdrop-filter: blur(18px);
      background: rgba(255, 255, 255, 0.93);
      border-bottom: 1px solid rgba(228, 228, 231, 0.92);
    }

    .nav {
      min-height: 84px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 26px;
    }

    .brand {
      display: flex;
      flex-direction: column;
      gap: 3px;
      line-height: 1.08;
      flex-shrink: 0;
    }

    .brand-main {
      font-size: 1.28rem;
      font-weight: 900;
      letter-spacing: -0.04em;
    }

    .brand-sub {
      font-size: 0.72rem;
      letter-spacing: 0.28em;
      text-transform: uppercase;
      color: #63636b;
      font-weight: 850;
    }

    .menu {
      display: flex;
      align-items: center;
      gap: 26px;
      font-size: 0.95rem;
      color: #3f3f46;
      font-weight: 760;
    }

    .menu a {
      transition: color 0.18s ease;
    }

    .menu a:hover {
      color: #000;
    }

    .nav-actions {
      display: flex;
      gap: 12px;
      align-items: center;
      flex-shrink: 0;
    }

    .btn,
    button.btn {
      border: 0;
      cursor: pointer;
      min-height: 50px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      border-radius: 999px;
      padding: 0 24px;
      font-size: 0.98rem;
      font-weight: 850;
      transition:
        transform 0.18s ease,
        background 0.18s ease,
        color 0.18s ease,
        border 0.18s ease,
        box-shadow 0.18s ease;
      white-space: nowrap;
    }

    .btn:hover {
      transform: translateY(-1px);
    }

    .btn-dark {
      background: var(--black);
      color: var(--white);
      box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
    }

    .btn-dark:hover {
      background: #000;
    }

    .btn-light {
      background: var(--white);
      color: var(--black);
      box-shadow: 0 14px 30px rgba(0, 0, 0, 0.16);
    }

    .btn-light:hover {
      background: #f1f1f1;
    }

    .btn-outline-light {
      background: transparent;
      color: var(--white);
      border: 1px solid rgba(255, 255, 255, 0.34);
    }

    .btn-outline-light:hover {
      background: rgba(255, 255, 255, 0.10);
    }

    .btn-outline-dark {
      background: transparent;
      color: var(--black);
      border: 1px solid var(--line);
    }

    .btn-outline-dark:hover {
      background: #f7f7f7;
    }

    .mobile-toggle {
      display: none;
      min-width: 50px;
      height: 50px;
      border-radius: 999px;
      border: 1px solid var(--line);
      background: #fff;
      color: #111;
      cursor: pointer;
      font-size: 1.18rem;
      font-weight: 900;
    }

    .mobile-menu {
      display: none;
      border-top: 1px solid var(--line);
      padding: 0 0 18px;
    }

    .mobile-menu.open {
      display: block;
    }

    .mobile-menu-inner {
      display: grid;
      gap: 5px;
      padding-top: 12px;
    }

    .mobile-menu a {
      padding: 13px 0;
      border-bottom: 1px solid #f1f1f1;
      font-weight: 800;
      color: #3f3f46;
    }

    .mobile-menu .btn {
      width: 100%;
      margin-top: 12px;
    }

    .hero {
      position: relative;
      overflow: hidden;
      background:
        radial-gradient(circle at 88% 12%, rgba(255,255,255,0.18), transparent 30%),
        radial-gradient(circle at 9% 100%, rgba(255,255,255,0.09), transparent 34%),
        linear-gradient(135deg, #0b0b0c 0%, #171717 56%, #232323 100%);
      color: var(--white);
      border-bottom: 1px solid #27272a;
    }

    .hero-grid {
      min-height: 790px;
      display: grid;
      grid-template-columns: 1.03fr 0.97fr;
      align-items: center;
      gap: 56px;
      padding: 82px 0 90px;
    }

    .pill {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 11px 16px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.16);
      background: rgba(255,255,255,0.08);
      color: rgba(255,255,255,0.96);
      font-size: 0.91rem;
      font-weight: 780;
      margin-bottom: 28px;
    }

    .hero h1 {
      margin: 0;
      max-width: 900px;
      font-size: clamp(3rem, 6.1vw, 5.95rem);
      line-height: 0.98;
      letter-spacing: -0.065em;
      font-weight: 900;
    }

    .hero-copy {
      max-width: 820px;
      margin: 28px 0 0;
      font-size: clamp(1.1rem, 1.85vw, 1.36rem);
      line-height: 1.66;
      color: rgba(255,255,255,0.79);
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 38px;
    }

    .mini-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-top: 44px;
    }

    .mini-card {
      border-radius: 24px;
      border: 1px solid rgba(255,255,255,0.12);
      background: rgba(255,255,255,0.06);
      padding: 22px;
      min-height: 136px;
    }

    .mini-card strong {
      display: block;
      font-size: 1.04rem;
      margin-bottom: 8px;
      letter-spacing: -0.02em;
    }

    .mini-card span {
      display: block;
      color: rgba(255,255,255,0.72);
      line-height: 1.56;
      font-size: 0.96rem;
    }

    .hero-media {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-template-rows: 410px 205px;
      gap: 18px;
    }

    .media-image {
      position: relative;
      overflow: hidden;
      border-radius: 30px;
      border: 1px solid rgba(255,255,255,0.14);
      box-shadow: 0 24px 70px rgba(0,0,0,0.24);
      background: #202020;
    }

    .media-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .media-image.hero-main {
      grid-column: 1 / -1;
    }

    .image-label {
      position: absolute;
      left: 18px;
      right: 18px;
      bottom: 18px;
      background: rgba(255,255,255,0.94);
      color: #111;
      padding: 15px 17px;
      border-radius: 18px;
      font-size: 0.92rem;
      font-weight: 850;
      box-shadow: 0 12px 30px rgba(0,0,0,0.16);
    }

    .strip {
      background: #f7f7f8;
      border-bottom: 1px solid var(--line);
    }

    .strip-inner {
      display: grid;
      grid-template-columns: 190px 1fr;
      align-items: center;
      gap: 28px;
      padding: 31px 0;
    }

    .strip-label,
    .eyebrow {
      text-transform: uppercase;
      letter-spacing: 0.23em;
      font-weight: 900;
      font-size: 0.75rem;
      color: #6b7280;
    }

    .eyebrow {
      margin: 0 0 18px;
    }

    .strip p {
      margin: 0;
      color: #374151;
      font-size: 1.12rem;
      line-height: 1.68;
    }

    .section {
      padding: 108px 0;
    }

    .section.soft {
      background: #f7f7f8;
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
    }

    .section.dark {
      background: #111;
      color: #fff;
      border-top: 1px solid #262626;
      border-bottom: 1px solid #262626;
    }

    .section-head {
      max-width: 930px;
      margin-bottom: 52px;
    }

    .section-head h2 {
      margin: 0;
      font-size: clamp(2.3rem, 4vw, 4.35rem);
      line-height: 1.05;
      letter-spacing: -0.055em;
      font-weight: 900;
    }

    .section-head p {
      max-width: 870px;
      margin: 22px 0 0;
      font-size: 1.15rem;
      line-height: 1.78;
      color: #61656b;
    }

    .dark .section-head p {
      color: rgba(255,255,255,0.74);
    }

    .proof-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 18px;
    }

    .proof-card {
      border-radius: 24px;
      border: 1px solid var(--line);
      background: #fff;
      padding: 27px;
      box-shadow: 0 10px 24px rgba(0,0,0,0.035);
    }

    .proof-card strong {
      display: block;
      font-size: 2.16rem;
      line-height: 1;
      letter-spacing: -0.055em;
      font-weight: 950;
      color: #111;
      margin-bottom: 13px;
    }

    .proof-card span {
      display: block;
      color: #59606a;
      font-size: 0.99rem;
      line-height: 1.65;
      font-weight: 660;
    }

    .trust-panel {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 36px;
      align-items: center;
      margin-top: 24px;
      border-radius: var(--radius-xl);
      background: #111;
      color: #fff;
      padding: 40px;
      box-shadow: var(--shadow-soft);
    }

    .trust-panel h3 {
      margin: 0;
      font-size: clamp(1.9rem, 3vw, 2.75rem);
      line-height: 1.1;
      letter-spacing: -0.05em;
      font-weight: 900;
    }

    .trust-panel p {
      margin: 18px 0 0;
      color: rgba(255,255,255,0.75);
      font-size: 1.05rem;
      line-height: 1.74;
    }

    .trust-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .trust-tag {
      display: inline-flex;
      align-items: center;
      min-height: 48px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.18);
      background: rgba(255,255,255,0.08);
      color: rgba(255,255,255,0.95);
      padding: 0 18px;
      font-size: 0.95rem;
      font-weight: 850;
      line-height: 1.35;
    }

    .grid-3,
    .systems-grid,
    .why-grid,
    .process-grid,
    .project-cards {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    .grid-2,
    .detail-grid,
    .contact-grid,
    .faq-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 22px;
    }

    .card,
    .system-card,
    .why-card,
    .process-card,
    .project-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-lg);
      padding: 30px;
      box-shadow: 0 10px 28px rgba(0,0,0,0.035);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .card:hover,
    .system-card:hover,
    .why-card:hover,
    .process-card:hover,
    .project-card:hover {
      transform: translateY(-3px);
      box-shadow: var(--shadow-soft);
    }

    .icon {
      width: 54px;
      height: 54px;
      border-radius: 18px;
      background: #111;
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 1.36rem;
      font-weight: 950;
      margin-bottom: 22px;
    }

    .card h3,
    .system-card h3,
    .why-card h3,
    .project-card h3 {
      margin: 0;
      font-size: 1.48rem;
      line-height: 1.2;
      letter-spacing: -0.03em;
      font-weight: 900;
    }

    .card p,
    .system-card p,
    .why-card p,
    .project-card p,
    .process-card p {
      margin: 15px 0 0;
      color: #5b6067;
      font-size: 1rem;
      line-height: 1.74;
    }

    .detail-card,
    .feature-card,
    .fault-wrap,
    .form-card {
      border-radius: var(--radius-xl);
      border: 1px solid var(--line);
      background: #fff;
      padding: 35px;
      box-shadow: var(--shadow-soft);
    }

    .detail-card h3,
    .feature-card h3,
    .form-card h3,
    .fault-wrap h3 {
      margin: 0;
      font-size: clamp(1.85rem, 2.7vw, 2.1rem);
      line-height: 1.13;
      letter-spacing: -0.045em;
      font-weight: 900;
    }

    .detail-card > p,
    .feature-card p,
    .form-card > p,
    .fault-wrap > p {
      margin: 16px 0 24px;
      color: #5e6369;
      font-size: 1.05rem;
      line-height: 1.74;
    }

    .detail-list {
      display: grid;
      gap: 12px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .detail-list li {
      display: flex;
      gap: 12px;
      align-items: flex-start;
      color: #3f4650;
      font-size: 1rem;
      line-height: 1.62;
    }

    .detail-list li::before {
      content: "✓";
      flex: 0 0 auto;
      width: 22px;
      height: 22px;
      border-radius: 999px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #111;
      color: #fff;
      font-size: 0.78rem;
      font-weight: 950;
      margin-top: 2px;
    }

    .tag-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 24px;
    }

    .tag {
      display: inline-flex;
      align-items: center;
      min-height: 36px;
      border-radius: 999px;
      border: 1px solid var(--line);
      background: #fafafa;
      padding: 0 14px;
      font-size: 0.88rem;
      font-weight: 850;
      color: #3f3f46;
    }

    .split {
      display: grid;
      grid-template-columns: 0.92fr 1.08fr;
      gap: 48px;
      align-items: start;
    }

    .feature-pair {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 22px;
    }

    .feature-card {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 28px;
    }

    .fault-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px;
      margin-top: 28px;
    }

    .fault-item {
      border: 1px solid var(--line);
      background: #fafafa;
      border-radius: 18px;
      padding: 18px 19px;
      color: #374151;
      font-size: 0.98rem;
      line-height: 1.58;
      font-weight: 800;
    }

    .media-grid {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr;
      grid-template-rows: 250px 250px;
      gap: 18px;
    }

    .gallery-tile {
      position: relative;
      overflow: hidden;
      border-radius: 28px;
      border: 1px solid rgba(255,255,255,0.14);
      background: #242424;
    }

    .gallery-tile:first-child {
      grid-row: 1 / span 2;
    }

    .gallery-tile img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .gallery-tile .image-label {
      left: 18px;
      right: 18px;
      bottom: 18px;
    }

    .industries {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 18px;
    }

    .industry {
      min-height: 104px;
      display: flex;
      gap: 16px;
      align-items: center;
      border-radius: 24px;
      border: 1px solid var(--line);
      background: #fff;
      padding: 22px;
      box-shadow: 0 10px 22px rgba(0,0,0,0.03);
    }

    .industry-badge {
      flex: 0 0 auto;
      width: 54px;
      height: 54px;
      border-radius: 18px;
      background: #111;
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 1.23rem;
      font-weight: 950;
    }

    .industry strong {
      font-size: 1.16rem;
      line-height: 1.25;
      letter-spacing: -0.02em;
    }

    .project-feature {
      display: grid;
      grid-template-columns: 0.92fr 1.08fr;
      overflow: hidden;
      margin-bottom: 24px;
      border-radius: 38px;
      border: 1px solid var(--line);
      background: #fff;
      box-shadow: var(--shadow-soft);
    }

    .project-visual {
      min-height: 480px;
      position: relative;
      background: #202020;
    }

    .project-visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .project-body {
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 44px;
    }

    .project-body h3 {
      margin: 0;
      font-size: clamp(2rem, 3.3vw, 3.25rem);
      line-height: 1.08;
      letter-spacing: -0.055em;
      font-weight: 920;
    }

    .project-body > p {
      margin: 18px 0 26px;
      color: #5e6369;
      font-size: 1.08rem;
      line-height: 1.76;
    }

    .project-specs {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 13px;
    }

    .project-spec {
      border-radius: 18px;
      border: 1px solid var(--line);
      background: #fafafa;
      padding: 16px 17px;
    }

    .project-spec strong {
      display: block;
      color: #71717a;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      font-size: 0.82rem;
      line-height: 1.2;
      font-weight: 900;
      margin-bottom: 7px;
    }

    .project-spec span {
      display: block;
      color: #18181b;
      font-size: 1rem;
      line-height: 1.45;
      font-weight: 850;
    }

    .cred-list {
      display: grid;
      gap: 14px;
    }

    .cred {
      display: flex;
      gap: 14px;
      align-items: flex-start;
      border-radius: 20px;
      border: 1px solid var(--line);
      background: #fff;
      padding: 18px 20px;
      color: #3f4650;
      font-size: 1rem;
      line-height: 1.66;
      box-shadow: 0 9px 24px rgba(0,0,0,0.028);
    }

    .tick {
      flex: 0 0 auto;
      width: 24px;
      height: 24px;
      margin-top: 2px;
      border-radius: 999px;
      background: #111;
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 0.82rem;
      font-weight: 950;
    }

    .process-number {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 46px;
      height: 46px;
      border-radius: 999px;
      background: #111;
      color: #fff;
      font-size: 1rem;
      font-weight: 950;
      margin-bottom: 20px;
    }

    .process-card h3 {
      margin: 0;
      font-size: 1.46rem;
      line-height: 1.2;
      letter-spacing: -0.03em;
      font-weight: 900;
    }

    details.faq {
      border-radius: 22px;
      border: 1px solid var(--line);
      background: #fff;
      padding: 0 22px;
      box-shadow: 0 10px 24px rgba(0,0,0,0.03);
    }

    details.faq summary {
      min-height: 90px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      cursor: pointer;
      list-style: none;
      font-size: 1.16rem;
      line-height: 1.35;
      letter-spacing: -0.02em;
      font-weight: 900;
    }

    details.faq summary::-webkit-details-marker {
      display: none;
    }

    details.faq summary::after {
      content: "+";
      flex: 0 0 auto;
      width: 34px;
      height: 34px;
      border-radius: 999px;
      background: #111;
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 1.26rem;
      font-weight: 950;
    }

    details.faq[open] summary::after {
      content: "−";
    }

    details.faq p {
      margin: 0 0 24px;
      padding-right: 16px;
      color: #5e6369;
      font-size: 1rem;
      line-height: 1.74;
    }

    .form-card h3 {
      font-size: 2rem;
    }

    .field-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
    }

    .field {
      display: grid;
      gap: 8px;
      margin-bottom: 16px;
    }

    .field.full {
      grid-column: 1 / -1;
    }

    .field label {
      color: #27272a;
      font-size: 0.9rem;
      font-weight: 850;
    }

    .field input,
    .field select,
    .field textarea {
      width: 100%;
      min-height: 52px;
      border-radius: 16px;
      border: 1px solid #d4d4d8;
      background: #fff;
      color: #18181b;
      padding: 0 16px;
      font: inherit;
      outline: none;
    }

    .field textarea {
      min-height: 130px;
      padding-top: 15px;
      resize: vertical;
    }

    .field input:focus,
    .field select:focus,
    .field textarea:focus {
      border-color: #111;
      box-shadow: 0 0 0 4px rgba(17,17,17,0.08);
    }

    .form-note {
      margin: 16px 0 0;
      color: #666;
      font-size: 0.92rem;
      line-height: 1.62;
    }

    .cta {
      padding: 100px 0 112px;
    }

    .cta-box {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 42px;
      align-items: end;
      border-radius: 40px;
      background:
        radial-gradient(circle at 86% 8%, rgba(255,255,255,0.16), transparent 26%),
        linear-gradient(135deg, #101010, #1b1b1d);
      color: #fff;
      padding: 58px;
      box-shadow: 0 28px 80px rgba(0,0,0,0.16);
    }

    .location-pill {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      min-height: 44px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.16);
      background: rgba(255,255,255,0.09);
      color: rgba(255,255,255,0.93);
      padding: 0 16px;
      font-size: 0.92rem;
      font-weight: 850;
      margin-bottom: 23px;
    }

    .cta-box h2 {
      margin: 0;
      max-width: 920px;
      font-size: clamp(2.3rem, 4vw, 4.15rem);
      line-height: 1.05;
      letter-spacing: -0.055em;
      font-weight: 920;
    }

    .cta-box p {
      max-width: 850px;
      margin: 22px 0 0;
      color: rgba(255,255,255,0.74);
      font-size: 1.14rem;
      line-height: 1.74;
    }

    .cta-actions {
      display: flex;
      flex-direction: column;
      gap: 14px;
      min-width: 300px;
    }

    .footer {
      border-top: 1px solid var(--line);
      background: #fff;
      padding: 42px 0 48px;
    }

    .footer-inner {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 28px;
      align-items: center;
    }

    .footer p {
      margin: 0;
      color: #656b72;
      line-height: 1.68;
      font-size: 0.95rem;
    }

    .footer strong {
      color: #111;
    }

    @media (max-width: 1120px) {
      .menu,
      .desktop-quote {
        display: none;
      }

      .mobile-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
      }

      .hero-grid,
      .split,
      .cta-box,
      .trust-panel,
      .project-feature {
        grid-template-columns: 1fr;
      }

      .hero-grid {
        min-height: auto;
        padding-top: 66px;
      }

      .hero-media {
        max-width: 780px;
      }

      .cta-actions {
        flex-direction: row;
        flex-wrap: wrap;
        min-width: 0;
      }

      .project-visual {
        min-height: 360px;
      }
    }

    @media (max-width: 860px) {
      .container {
        width: min(var(--max), calc(100% - 32px));
      }

      .nav {
        min-height: 76px;
      }

      .hero-grid {
        gap: 42px;
        padding: 56px 0 68px;
      }

      .hero-copy {
        font-size: 1.08rem;
      }

      .mini-grid,
      .proof-grid,
      .grid-3,
      .grid-2,
      .detail-grid,
      .feature-pair,
      .systems-grid,
      .fault-grid,
      .industries,
      .why-grid,
      .project-cards,
      .process-grid,
      .faq-grid,
      .contact-grid,
      .field-grid,
      .project-specs {
        grid-template-columns: 1fr;
      }

      .strip-inner {
        grid-template-columns: 1fr;
        gap: 12px;
      }

      .section {
        padding: 78px 0;
      }

      .hero-media {
        grid-template-columns: 1fr;
        grid-template-rows: 300px 220px 220px;
      }

      .media-image.hero-main {
        grid-column: auto;
      }

      .media-grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
      }

      .gallery-tile,
      .gallery-tile:first-child {
        grid-row: auto;
        min-height: 240px;
      }

      .project-visual {
        min-height: 300px;
      }

      .project-body {
        padding: 30px;
      }

      .cta {
        padding: 76px 0 86px;
      }

      .cta-box {
        padding: 36px;
        border-radius: 32px;
      }

      .cta-actions {
        flex-direction: column;
      }

      .cta-actions .btn {
        width: 100%;
      }

      .footer-inner {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 620px) {
      .brand-main {
        font-size: 1.12rem;
      }

      .brand-sub {
        font-size: 0.64rem;
      }

      .hero h1 {
        font-size: 2.78rem;
      }

      .hero-actions,
      .hero-actions .btn {
        width: 100%;
      }

      .card,
      .system-card,
      .why-card,
      .process-card,
      .project-card,
      .detail-card,
      .feature-card,
      .fault-wrap,
      .form-card {
        padding: 24px;
      }

      .trust-panel {
        padding: 28px;
      }

      .section-head h2,
      .cta-box h2 {
        letter-spacing: -0.048em;
      }

      .media-image,
      .gallery-tile {
        border-radius: 24px;
      }
    }
    /* Final colour + layout overrides */

.entry-content,
.site-content,
.ast-container,
.ast-separate-container .ast-article-single {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}

.entry-content p {
  margin-bottom: 0;
}

.hero,
.hero * {
  color: #fff;
}

.section.dark,
.section.dark * {
  color: #fff;
}

.section.dark p,
.dark .section-head p {
  color: rgba(255,255,255,0.74) !important;
}

.card p,
.system-card p,
.why-card p,
.project-card p,
.process-card p,
.detail-card p,
.form-card p,
.fault-wrap p,
details.faq p,
.section-head p {
  color: #5b6067 !important;
}

.image-label,
.image-label * {
  color: #111 !important;
}

.btn-dark {
  background: #101010 !important;
  color: #fff !important;
}

.btn-light {
  background: #fff !important;
  color: #101010 !important;
}

.btn-outline-light {
  color: #fff !important;
}

.detail-list li,
.cred,
.fault-item,
.industry strong {
  color: #3f4650 !important;
}

.trust-panel,
.trust-panel * {
  color: #fff;
}

.trust-panel p {
  color: rgba(255,255,255,0.75) !important;
}

.trust-tag {
  color: rgba(255,255,255,0.95) !important;
}

.cta-box,
.cta-box * {
  color: #fff;
}

.cta-box p {
  color: rgba(255,255,255,0.74) !important;
}

.footer p {
  color: #656b72 !important;
}

.footer strong,
.footer .brand-main {
  color: #111 !important;
}
.logo-brand {
  display: flex;
  align-items: center;
}

.commercial-logo {
  width: 320px;
  max-width: 100%;
  height: auto;
  display: block;
}

.topbar .nav {
  min-height: 110px;
}

@media (max-width: 768px) {

  .commercial-logo {
    width: 220px;
  }

  .topbar .nav {
    min-height: 88px;
  }

}
.ff-el-form-control {
  border-radius: 16px !important;
  min-height: 52px !important;
  border: 1px solid #d4d4d8 !important;
}

textarea.ff-el-form-control {
  min-height: 140px !important;
}

.ff-btn-submit {
  border-radius: 999px !important;
  background: #101010 !important;
  color: #fff !important;
  padding: 14px 24px !important;
  font-weight: 700 !important;
  border: 0 !important;
}

.ff-btn-submit:hover {
  opacity: 0.92;
}