/* ==========================================================================
   BRICSCAD INSPIRED THEME — theme.css
   ========================================================================== */

/* ---------- Tokens ---------- */
:root {
    --black:       #000;
    --dark:        #0b0f1c;
    --dark-2:      #111827;
    --dark-3:      #1c2640;
    --blue-dark:   #1a3ecf;
    --blue-mid:    #2f5fff;
    --blue-light:  #5b8aff;
    --lime:        #84e620;
    --cyan:        #1ad4f5;
    --pink:        #e03e7e;
    --neutral-100: #f1f4fa;
    --neutral-200: #dde4f0;
    --neutral-700: #3a4a6b;
    --neutral-800: #1e2b47;
    --neutral-900: #0d1428;
    --white:       #ffffff;
    --text-on-dark:  #e8eeff;
    --text-muted:    #96abcf;
    --radius-sm:  8px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-pill: 999px;
    --shadow-card: 0 4px 24px rgba(0,0,0,.35);
    --transition: 0.2s ease;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: "Manrope", "Inter", system-ui, sans-serif;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--dark);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4,h5,h6,p,ul,ol,li { margin: 0; padding: 0; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
ul { list-style: none; }
button { cursor: pointer; font-family: inherit; }

h1,h2,h3,h4,
.eyebrow,
.btn,
.tabs__btn {
    font-family: "Space Grotesk", "Manrope", system-ui, sans-serif;
}

/* ---------- Layout ---------- */
.container {
    width: min(1200px, calc(100% - 3rem));
    margin-inline: auto;
}
.narrow { width: min(880px, calc(100% - 3rem)); }

/* ---------- Eyebrow ---------- */
.eyebrow {
    display: inline-block;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding-bottom: .4rem;
    border-bottom: 2.5px solid var(--pink);
    color: inherit;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(8, 10, 22, .92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.site-header__utility {
    border-bottom: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.02);
}
.site-header__utility-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 38px;
}
.site-header__utility-links {
    display: flex;
    align-items: center;
    gap: 1.1rem;
}
.site-header__utility-links a {
    color: rgba(200,213,242,.74);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.site-header__utility-links a:hover {
    color: var(--white);
}
.site-header__utility-links--secondary {
    justify-content: flex-end;
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 78px;
}

/* Logo / brand */
.brand {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    flex-shrink: 0;
    color: var(--white);
    font-weight: 800;
    font-size: 1.1rem;
    letter-spacing: -.01em;
}
.brand__logo-image {
    width: min(100%, 210px);
    height: auto;
    display: block;
}
.brand__mark {
    width: 32px; height: 32px;
    border-radius: var(--radius-sm);
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--lime) 0%, var(--cyan) 100%);
    color: var(--dark);
    font-weight: 900;
    font-size: .95rem;
}
.custom-logo { max-height: 38px; width: auto; }

/* Nav */
.main-nav {
    display: flex;
    align-items: center;
    gap: .6rem;
    position: relative;
    margin-left: auto;
}
.main-nav__list {
    display: flex;
    align-items: center;
    gap: .2rem;
}
.main-nav__item {
    position: relative;
}
.main-nav__list--fallback .main-nav__item {
    position: static;
}
.main-nav__list a {
    display: inline-block;
    padding: .45rem .75rem;
    color: #c8d5f2;
    font-size: .9rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    transition: background var(--transition), color var(--transition);
}
.main-nav__list a:hover { background: rgba(255,255,255,.07); color: var(--white); }
.main-nav__trigger {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .75rem;
    border: 0;
    background: transparent;
    color: #c8d5f2;
    font-size: .9rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    transition: background var(--transition), color var(--transition);
}
.main-nav__trigger:hover,
.has-mega-menu.is-open .main-nav__trigger {
    background: rgba(255,255,255,.08);
    color: var(--white);
}
.main-nav__chevron {
    width: 10px;
    height: 10px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transition: transform var(--transition);
}
.has-mega-menu.is-open .main-nav__chevron {
    transform: rotate(-135deg) translateY(-1px);
}
.mega-menu {
    position: absolute;
    top: calc(100% + 4px);
    left: auto;
    right: 0;
    width: min(1320px, calc(100vw - 2rem));
    min-width: 0;
    max-width: 1320px;
    padding: 2rem 2.35rem 2.4rem;
    border-radius: 0 0 18px 18px;
    background: #1f2029;
    border-top: 1px solid rgba(255,255,255,.04);
    box-shadow: 0 24px 44px rgba(0,0,0,.34);
}
.mega-menu::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -18px;
    height: 14px;
}
.mega-menu__layout {
    display: grid;
    gap: 0;
}
.mega-menu__layout--products {
    grid-template-columns: .96fr 2.15fr .9fr;
}
.mega-menu__layout--simple {
    grid-template-columns: 1fr 1fr 1fr 1fr;
}
.mega-menu__panel {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    padding: 0 2rem;
    min-width: 0;
    border-left: 1px solid rgba(255,255,255,.08);
}
.mega-menu__panel:first-child {
    padding-left: 0;
    border-left: 0;
}
.mega-menu__panel--intro {
    justify-content: flex-start;
}
.mega-menu__section-title {
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #19d8f6;
    margin-bottom: .55rem;
}
.mega-menu__section-title--spaced {
    margin-top: 1.5rem;
}
.mega-menu__panel h3,
.mega-menu__panel h4 {
    margin: 0;
    color: var(--white);
    font-size: clamp(1.1rem, 1.6vw, 1.45rem);
    font-weight: 700;
    line-height: 1.25;
}
.mega-menu__panel p {
    margin: .35rem 0 0;
    color: rgba(232,238,255,.9);
    font-size: .96rem;
    line-height: 1.58;
    max-width: 30ch;
}
.mega-menu__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1.6rem;
}
.mega-menu__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 1.25rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: .95rem;
}
.mega-menu__button--primary {
    background: #16e0ef;
    color: #07101f;
}
.mega-menu__button--ghost {
    border: 2px solid #16e0ef;
    color: #16e0ef;
}
.mega-menu__footnote {
    margin-top: auto !important;
    font-size: .9rem !important;
    color: rgba(255,255,255,.78) !important;
}
.mega-menu__product-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.55rem 1.75rem;
}
.mega-menu__product,
.mega-menu__link-list a {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    color: #ffffff;
    padding: 0;
}
.mega-menu__product strong,
.mega-menu__link-list a {
    font-size: clamp(1rem, 1.2vw, 1.05rem);
    font-weight: 700;
    line-height: 1.35;
}
.mega-menu__product span {
    color: rgba(232,238,255,.88);
    font-size: .93rem;
    line-height: 1.45;
}
.mega-menu__link-list {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.mega-menu__product:hover strong,
.mega-menu__link-list a:hover {
    color: #16e0ef;
}

.nav-actions { display: flex; align-items: center; gap: .6rem; }
.btn-nav-login {
    padding: .42rem .9rem;
    border-radius: var(--radius-pill);
    border: 1.5px solid rgba(192,210,255,.35);
    color: #c8d5f2;
    font-size: .88rem;
    font-weight: 600;
    background: transparent;
    transition: border-color var(--transition), color var(--transition);
}
.btn-nav-login:hover { border-color: rgba(192,210,255,.7); color: var(--white); }

/* Hamburger */
.menu-toggle {
    display: none;
    background: transparent;
    border: 0;
    padding: .4rem;
    flex-direction: column;
    gap: 5px;
}
.menu-toggle span {
    display: block;
    width: 22px; height: 2px;
    background: var(--white);
    border-radius: 2px;
    transition: transform var(--transition), opacity var(--transition);
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    border-radius: var(--radius-pill);
    min-height: 50px;
    padding: 0 1.6rem;
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: .01em;
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
    white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }

.btn--primary {
    background: var(--blue-dark);
    color: var(--white);
    border-color: var(--blue-dark);
}
.btn--primary:hover {
    background: #0e2ea0;
    box-shadow: 0 8px 26px rgba(30,70,220,.4);
}

.btn--ghost {
    background: transparent;
    border-color: rgba(192,210,255,.4);
    color: #c8d5f2;
}
.btn--ghost:hover {
    background: rgba(255,255,255,.08);
    color: var(--white);
    border-color: rgba(192,210,255,.7);
}

.btn--dark {
    background: var(--dark);
    color: var(--white);
    border-color: var(--dark);
}
.btn--dark:hover { background: #000; }

.btn--sm { min-height: 40px; padding: 0 1.1rem; font-size: .85rem; }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero {
    position: relative;
    overflow: hidden;
    color: var(--text-on-dark);
    padding: 5.5rem 0 4.5rem;
    background:
        radial-gradient(ellipse 70% 55% at 110% -10%, rgba(26,62,207,.55) 0%, transparent 60%),
        radial-gradient(ellipse 55% 50% at -10% 110%, rgba(26,212,245,.18) 0%, transparent 55%),
        linear-gradient(175deg, #070c1e 0%, #0b1229 55%, #0e1a38 100%);
}

.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
    background-size: 44px 44px;
    pointer-events: none;
}

.hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 3.5rem;
}

.hero__left { display: flex; flex-direction: column; gap: 1.4rem; }

.hero h1 {
    font-size: clamp(2.3rem, 4.2vw, 3.6rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -.025em;
    color: var(--white);
    white-space: pre-line;
}
.hero__subtitle {
    font-size: clamp(1rem, 1.5vw, 1.15rem);
    color: var(--text-muted);
    max-width: 42ch;
    line-height: 1.65;
}
.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    align-items: center;
}

/* ─── OS Compatibility Strip ─────────────────────────────────────────── */
.os-compat {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 18px;
    flex-wrap: wrap;
}
.os-compat__label {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    opacity: .5;
    white-space: nowrap;
}
.os-compat__list {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}
.os-compat__item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .78rem;
    font-weight: 500;
    opacity: .78;
}
.os-compat__item svg { flex-shrink: 0; }

/* Hero dark background variant */
.hero__left .os-compat__label,
.hero__left .os-compat__item          { color: rgba(255,255,255,.75); }
/* GstarCAD page hero (light bg) */
.gs-hero__copy .os-compat             { margin-top: 20px; }
/* Download page hero (colored dark bg) */
.gs-dl-hero__copy .os-compat__label  { color: rgba(255,255,255,.5); }
.gs-dl-hero__copy .os-compat__item   { color: rgba(255,255,255,.85); }

.hero__right {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.hero__screenshot-placeholder {
    width: 100%;
    aspect-ratio: 16/10;
    background: linear-gradient(145deg, #14213d 0%, #0c1527 100%);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,.1);
    position: relative;
    overflow: hidden;
    box-shadow: 0 32px 64px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.05);
    display: flex;
    flex-direction: column;
}
/* fake app chrome */
.hero__screenshot-placeholder::before {
    content: "";
    height: 36px;
    background: rgba(255,255,255,.04);
    border-bottom: 1px solid rgba(255,255,255,.07);
    flex-shrink: 0;
}
.hero__screenshot-placeholder::after {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(26,62,207,.4);
    box-shadow: 0 0 0 16px rgba(26,62,207,.15), 0 0 0 32px rgba(26,62,207,.07);
}

/* Floating badge */
.hero__badge {
    position: absolute;
    bottom: -1rem;
    left: -1rem;
    background: var(--dark-3);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--radius-md);
    padding: .9rem 1.2rem;
    box-shadow: var(--shadow-card);
    min-width: 180px;
    z-index: 2;
}
.hero__badge-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--lime);
}
.hero__badge-title {
    margin-top: .2rem;
    font-size: .9rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.3;
}

/* hero image (when set in Customizer) */
.hero__screenshot-img {
    width: 100%;
    aspect-ratio: 16/10;
    object-fit: cover;
    display: block;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 32px 64px rgba(0,0,0,.6);
}

/* ==========================================================================
   HERO CAROUSEL
   ========================================================================== */

/* The outer .hero becomes the viewport — overflow hidden already present */
.hero.hero-carousel {
    padding: 0;
    overflow: hidden;
}

/* Track: slides laid out horizontally */
.hero-carousel__track {
    display: flex;
    width: 100%;          /* = parent (hero) width */
    will-change: transform;
    transition: transform .6s cubic-bezier(.42, 0, .18, 1);
}

/* Each slide fills exactly the hero width */
.hero-carousel__slide {
    flex: 0 0 100%;       /* flex-shrink: 0; flex-basis: 100% of track */
    min-width: 0;
    padding: 5.5rem 0 4.5rem;
    position: relative;
}

/* Per-slide accent colour via CSS var (set inline from PHP) */
.hero-carousel__slide::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 55% at 110% -10%, color-mix(in srgb, var(--slide-accent, #1a3ecf) 55%, transparent) 0%, transparent 60%),
        radial-gradient(ellipse 55% 50% at -10% 110%, color-mix(in srgb, var(--slide-accent, #1a3ecf) 18%, transparent) 0%, transparent 55%);
    pointer-events: none;
    z-index: 0;
}
.hero-carousel__slide .hero__inner { position: relative; z-index: 1; }

/* Primary button accent per slide */
.hero-carousel__slide .btn--primary {
    background: var(--slide-accent, var(--blue-dark));
    border-color: var(--slide-accent, var(--blue-dark));
}
.hero-carousel__slide .btn--primary:hover {
    filter: brightness(1.15);
    box-shadow: 0 8px 26px color-mix(in srgb, var(--slide-accent, #1a3ecf) 40%, transparent);
}
.hero-carousel__slide .btn--ghost {
    border-color: color-mix(in srgb, var(--slide-accent, #1a3ecf) 60%, white 40%);
    color: color-mix(in srgb, var(--slide-accent, #1a3ecf) 60%, white 40%);
}
.hero-carousel__slide .btn--ghost:hover {
    background: color-mix(in srgb, var(--slide-accent, #1a3ecf) 15%, transparent);
    border-color: color-mix(in srgb, var(--slide-accent, #1a3ecf) 80%, white 20%);
    color: var(--white);
}
.hero-carousel__slide .eyebrow {
    border-bottom-color: color-mix(in srgb, var(--slide-accent, var(--pink)) 80%, white 20%);
}
.hero-carousel__slide .hero__badge-label {
    color: color-mix(in srgb, var(--slide-accent, var(--lime)) 80%, white 20%);
}

/* Prev / Next arrows */
.hero-carousel__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1.5px solid rgba(255,255,255,.22);
    background: rgba(8,10,22,.55);
    color: rgba(255,255,255,.82);
    backdrop-filter: blur(8px);
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition), transform .2s;
}
.hero-carousel__arrow:hover {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.5);
    color: var(--white);
    transform: translateY(-50%) scale(1.1);
}
.hero-carousel__arrow--prev { left: 1.25rem; }
.hero-carousel__arrow--next { right: 1.25rem; }

/* Dot indicators */
.hero-carousel__dots {
    position: absolute;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: .5rem;
    z-index: 10;
}
.hero-carousel__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 0;
    padding: 0;
    cursor: pointer;
    background: rgba(255,255,255,.32);
    transition: background var(--transition), transform var(--transition), width var(--transition);
}
.hero-carousel__dot.is-active {
    width: 24px;
    border-radius: 4px;
    background: var(--white);
}

/* Responsive: hide arrows on small screens */
@media (max-width: 600px) {
    .hero-carousel__arrow { display: none; }
}

/* ==========================================================================
   ANNOUNCEMENT / HIGHLIGHT
   ========================================================================== */
.highlight {
    padding: 1.8rem 0 2.4rem;
    background: var(--dark);
}
.highlight__card {
    border: 1.5px solid rgba(255,255,255,.12);
    border-radius: var(--radius-lg);
    padding: 3rem 3.5rem;
    background: linear-gradient(130deg, #111827 0%, #1a2540 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2.5rem;
    flex-wrap: wrap;
    position: relative;
    overflow: hidden;
}
.highlight__card::before {
    content: "";
    position: absolute;
    top: -60px; right: -60px;
    width: 260px; height: 260px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(26,62,207,.4) 0%, transparent 70%);
    pointer-events: none;
}
.highlight__copy { flex: 1; min-width: 260px; position: relative; }
.highlight__copy .eyebrow { color: var(--lime); border-bottom-color: var(--lime); }
.highlight__copy h2 {
    margin-top: .7rem;
    font-size: clamp(1.5rem, 2.6vw, 2.1rem);
    font-weight: 800;
    color: var(--white);
    max-width: 28ch;
    line-height: 1.2;
    letter-spacing: -.02em;
}
.highlight__actions {
    display: flex;
    align-items: center;
    gap: .8rem;
    flex-wrap: wrap;
    flex-shrink: 0;
    position: relative;
}

/* ==========================================================================
   RESOURCES
   ========================================================================== */
.resources {
    padding: 5rem 0;
    background: var(--dark);
}
.section-head {
    display: flex;
    flex-direction: column;
    gap: .8rem;
    margin-bottom: 2.5rem;
}
.section-head h2 {
    font-size: clamp(1.8rem, 3vw, 2.8rem);
    font-weight: 800;
    letter-spacing: -.025em;
    line-height: 1.1;
    color: var(--white);
    max-width: 22ch;
}
.section-head .eyebrow { color: var(--text-muted); }

.resource-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.card {
    display: flex;
    flex-direction: column;
    background: #101725;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    color: var(--text-on-dark);
    min-height: 260px;
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.card:hover {
    border-color: rgba(91,138,255,.35);
    transform: translateY(-3px);
    box-shadow: 0 16px 40px rgba(0,0,0,.45);
}
.card__icon {
    width: 46px; height: 46px;
    background: rgba(255,255,255,.06);
    border-radius: var(--radius-sm);
    display: grid; place-items: center;
    margin-bottom: 1.1rem;
    flex-shrink: 0;
}
.card__icon svg { width: 22px; height: 22px; stroke: var(--lime); fill: none; stroke-width: 1.8; }
.card__icon img { width: 28px; height: 28px; object-fit: contain; }
.card h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.3;
}
.card p {
    margin-top: .55rem;
    font-size: .9rem;
    line-height: 1.6;
    color: var(--text-muted);
    flex: 1;
}
.card__footer {
    margin-top: 1.2rem;
    padding-top: .9rem;
    border-top: 1.5px solid var(--lime);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .4rem;
}
.card__link {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--lime);
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    transition: gap var(--transition);
}
.card__link:hover { gap: .6rem; }
.card__link svg {
    width: 13px; height: 13px;
    stroke: currentColor; fill: none; stroke-width: 2.5;
    flex-shrink: 0;
}

/* ==========================================================================
   INDUSTRIES (TABS)
   ========================================================================== */
.industries {
    padding: 5rem 0;
    background: #0e1729;
    color: var(--text-on-dark);
}
.industries .section-head h2 { color: var(--white); }

.tabs {
    background: #101725;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.tabs__nav {
    display: flex;
    align-items: center;
    gap: .3rem;
    padding: 1.4rem 1.8rem .6rem;
    overflow-x: auto;
    scrollbar-width: none;
}
.tabs__nav::-webkit-scrollbar { display: none; }
.tabs__btn {
    border: 0;
    background: transparent;
    color: var(--text-muted);
    font-size: .9rem;
    font-weight: 700;
    padding: .55rem .9rem;
    border-radius: var(--radius-pill);
    white-space: nowrap;
    transition: background var(--transition), color var(--transition);
    position: relative;
}
.tabs__btn::after {
    content: "";
    position: absolute;
    bottom: -.6rem; left: 50%;
    transform: translateX(-50%);
    width: 0; height: 3px;
    background: var(--blue-mid);
    border-radius: 2px;
    transition: width var(--transition);
}
.tabs__btn.is-active { color: var(--white); }
.tabs__btn.is-active::after { width: 60%; }
.tabs__btn:hover:not(.is-active) { background: rgba(255,255,255,.06); color: #d0dcff; }

.tabs__divider {
    height: 1px;
    background: rgba(255,255,255,.07);
    margin: .6rem 1.8rem 0;
}

.tabs__panels { padding: 2.4rem 1.8rem 2rem; }
.tabs__panel { display: none; }
.tabs__panel.is-active {
    display: grid;
    grid-template-columns: 80px 1fr 1fr;
    gap: 2.5rem;
    align-items: start;
    animation: panelFade .3s ease;
}

.tabs__panel-icon {
    width: 72px; height: 72px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.06);
    border-radius: var(--radius-md);
    flex-shrink: 0;
    font-size: 2rem;
}
.tabs__panel-copy { display: flex; flex-direction: column; gap: .8rem; }
.tabs__panel-copy h3 {
    font-size: clamp(1.4rem, 2.2vw, 1.85rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.15;
    letter-spacing: -.02em;
}
.tabs__panel-copy p {
    font-size: .95rem;
    line-height: 1.7;
    color: var(--text-muted);
    max-width: 44ch;
}
.tabs__panel-copy a {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--lime);
    font-weight: 700;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    transition: gap var(--transition);
}
.tabs__panel-copy a:hover { gap: .7rem; }
.tabs__panel-copy a svg {
    width: 14px; height: 14px;
    stroke: currentColor; fill: none; stroke-width: 2.5;
    flex-shrink: 0;
}
.tabs__panel-image {
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.18);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.tabs__panel-image img { width: 100%; height: 100%; object-fit: cover; }

/* ==========================================================================
   CLIENTS
   ========================================================================== */
.clients {
    padding: 4.5rem 0;
    background: #e7ebf2;
}
.clients .section-head h2 { color: var(--dark); }
.clients .eyebrow { color: var(--neutral-700); border-bottom-color: var(--neutral-700); }

.logo-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: 2rem;
}
.logo-grid__item {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--white);
    border-radius: var(--radius-md);
    min-height: 80px;
    padding: 1.2rem 1.6rem;
    filter: grayscale(1);
    opacity: .7;
    transition: filter var(--transition), opacity var(--transition), box-shadow var(--transition);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.logo-grid__item:hover {
    filter: grayscale(0);
    opacity: 1;
    box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.logo-grid__item img {
    max-width: 130px;
    max-height: 36px;
    width: auto; height: auto;
    object-fit: contain;
}
.logo-grid__fallback {
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .05em;
    color: var(--neutral-700);
    text-transform: uppercase;
    text-align: center;
}

.clients__cta {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
}

/* ==========================================================================
   FINAL CTA
   ========================================================================== */
.final-cta {
    padding: 6rem 0;
    background: var(--dark);
    color: var(--text-on-dark);
    position: relative;
    overflow: hidden;
}
.final-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 80% at 50% 110%, rgba(26,62,207,.3) 0%, transparent 65%);
    pointer-events: none;
}
.final-cta__inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 2rem;
}
.final-cta__inner h2 {
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    font-weight: 800;
    letter-spacing: -.025em;
    line-height: 1.1;
    color: var(--white);
    max-width: 22ch;
}
.final-cta__inner p {
    color: var(--text-muted);
    max-width: 48ch;
    line-height: 1.65;
}
.final-cta__actions {
    display: flex;
    align-items: center;
    gap: .8rem;
    flex-wrap: wrap;
    justify-content: center;
}

.home-blog {
    padding: 5rem 0 5.5rem;
    background: #f5f7fb;
}
.home-blog__head h2 {
    color: #121212;
    max-width: none;
}
.home-blog__head .eyebrow {
    color: #0a1b5c;
    border-bottom-color: #2e5ace;
}
.home-blog__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-areas:
        "lead lead spotlight"
        "compact-1 compact-2 spotlight"
        "compact-3 compact-4 .";
    gap: 1.75rem;
    align-items: stretch;
}
.home-blog__card {
    min-width: 0;
}
.home-blog__card-link {
    display: block;
    height: 100%;
    color: inherit;
}
.home-blog__card--lead { grid-area: lead; }
.home-blog__card--spotlight { grid-area: spotlight; }
.home-blog__card--compact:nth-of-type(3) { grid-area: compact-1; }
.home-blog__card--compact:nth-of-type(4) { grid-area: compact-2; }
.home-blog__card--compact:nth-of-type(5) { grid-area: compact-3; }
.home-blog__card--compact:nth-of-type(6) { grid-area: compact-4; }
.home-blog__card--lead .home-blog__card-link {
    display: grid;
    grid-template-columns: 1.08fr .92fr;
    background: #ffffff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(17, 28, 50, .08);
}
.home-blog__card--lead .home-blog__media {
    min-height: 100%;
}
.home-blog__card--lead .home-blog__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.home-blog__card--lead .home-blog__content {
    padding: 1.7rem 1.8rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.home-blog__card--spotlight .home-blog__card-link {
    position: relative;
    min-height: 100%;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 14px 28px rgba(17, 28, 50, .12);
    background: linear-gradient(180deg, rgba(7, 12, 30, .05), rgba(7, 12, 30, .82));
}
.home-blog__card--spotlight .home-blog__media,
.home-blog__card--spotlight .home-blog__media img {
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
}
.home-blog__card--spotlight .home-blog__content {
    position: absolute;
    inset: auto 0 0 0;
    padding: 1.7rem;
    color: #ffffff;
    background: linear-gradient(180deg, rgba(7, 12, 30, 0) 0%, rgba(7, 12, 30, .86) 100%);
}
.home-blog__card--spotlight .home-blog__meta,
.home-blog__card--spotlight p {
    color: rgba(255,255,255,.82);
}
.home-blog__card--compact .home-blog__card-link {
    background: #ffffff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(17, 28, 50, .08);
}
.home-blog__card--compact .home-blog__media {
    background: linear-gradient(135deg, #0d1b55, #2e5ace);
    aspect-ratio: 16 / 9;
}
.home-blog__card--compact .home-blog__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.home-blog__card--compact .home-blog__content {
    padding: 1.5rem 1.55rem;
}
.home-blog__card--compact:not(:has(.home-blog__media)) .home-blog__content {
    min-height: 100%;
}
.home-blog__pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 .8rem;
    border-radius: 999px;
    background: #2e5ace;
    color: #ffffff;
    font-family: "Montserrat", "Space Grotesk", sans-serif;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.home-blog__card:nth-child(2n) .home-blog__pill { background: #6ac443; }
.home-blog__card:nth-child(3n) .home-blog__pill { background: #f59b1a; }
.home-blog__card h3 {
    margin-top: .85rem;
    font-family: "Montserrat", "Space Grotesk", sans-serif;
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    font-weight: 700;
    line-height: 1.18;
    color: inherit;
}
.home-blog__card p {
    margin-top: .85rem;
    font-family: "Roboto", "Manrope", sans-serif;
    font-size: 1rem;
    line-height: 1.6;
    color: #515760;
}
.home-blog__meta {
    margin-top: 1.15rem;
    font-family: "Roboto", "Manrope", sans-serif;
    font-size: .88rem;
    color: #7a8089;
}

/* ==========================================================================
   PRODUCT PAGE
   ========================================================================== */
.product-page {
    background: #ffffff;
}
.product-hero {
    padding: 5rem 0 4rem;
    background: linear-gradient(180deg, #07101f 0%, #0e1a38 100%);
    color: var(--white);
}
.product-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}
.product-hero__copy .eyebrow,
.product-section__head .eyebrow,
.product-trial-cta .eyebrow {
    color: var(--lime);
    border-bottom-color: var(--lime);
}
.product-hero h1,
.product-section__head h2,
.product-trial-cta h2 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(2.1rem, 4vw, 3.6rem);
    line-height: 1.05;
    letter-spacing: -.03em;
    margin-top: .8rem;
}
.product-hero__lead {
    margin-top: 1rem;
    font-size: 1.15rem;
    line-height: 1.7;
    color: rgba(255,255,255,.86);
    max-width: 48ch;
}
.product-hero__subnote,
.product-hero__note {
    margin-top: .85rem;
    color: rgba(255,255,255,.62);
    font-size: .92rem;
}
.product-hero__actions,
.product-trial-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    margin-top: 1.5rem;
}
.product-hero__btn-secondary {
    border-color: rgba(255,255,255,.32);
}
.product-hero__visual img {
    width: 100%;
    border-radius: 28px;
    box-shadow: 0 28px 70px rgba(0,0,0,.35);
}
.product-section {
    padding: 5rem 0;
}
.product-section--light {
    background: #ffffff;
    color: #121212;
}
.product-section--dark {
    background: #0d1428;
    color: var(--white);
}
.product-section--accent {
    background: linear-gradient(180deg, #111c37 0%, #0a1330 100%);
    color: var(--white);
}
.product-section__head {
    margin-bottom: 2rem;
}
.product-section__head h2 {
    color: inherit;
    font-size: clamp(1.8rem, 3vw, 2.8rem);
    max-width: 18ch;
}
.product-section__head p {
    margin-top: .95rem;
    max-width: 62ch;
    line-height: 1.75;
    color: inherit;
    opacity: .82;
}
.product-toolset-grid,
.product-benefits__grid,
.product-plugin-grid,
.product-edition-grid,
.product-testimonial-grid {
    display: grid;
    gap: 1.25rem;
}
.product-toolset-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.product-toolset-card,
.product-benefit-card,
.product-edition-card,
.product-testimonial-card {
    border-radius: 22px;
    padding: 1.5rem;
}
.product-toolset-card {
    background: #f5f7fb;
    border: 1px solid #e2e8f2;
}
.product-toolset-card__icon {
    display: inline-flex;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: linear-gradient(135deg, #2e5ace, #70c0ff);
    margin-bottom: 1rem;
}
.product-toolset-card h3,
.product-benefit-card h3,
.product-plugin-card h3,
.product-edition-card h3,
.product-testimonial-card__author {
    font-family: "Montserrat", "Space Grotesk", sans-serif;
    margin: 0;
}
.product-toolset-card p,
.product-benefit-card p,
.product-edition-card p,
.product-testimonial-card__role,
.product-faq__item p {
    margin-top: .8rem;
    line-height: 1.7;
}
.product-benefits {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 2rem;
    align-items: start;
}
.product-benefits__intro img {
    width: 100%;
    margin-top: 1.4rem;
    border-radius: 22px;
}
.product-benefits__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.product-benefit-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.09);
}
.product-feature-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.5rem;
}
.product-feature-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.2rem 1.3rem;
    border-radius: 18px;
    background: #f5f7fb;
    border: 1px solid #e3e9f4;
}
.product-feature-item__check {
    display: inline-flex;
    width: 28px;
    height: 28px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #2e5ace;
    color: #ffffff;
    font-size: .9rem;
    flex-shrink: 0;
}
.product-feature-item p {
    margin: 0;
    line-height: 1.6;
}
.product-plugin-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.product-plugin-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 220px;
    padding: 1.45rem;
    border-radius: 20px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    color: var(--white);
}
.product-plugin-card__label {
    display: inline-flex;
    align-self: flex-start;
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.8);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.product-plugin-card__cta {
    margin-top: 1rem;
    color: var(--lime);
    font-weight: 700;
}
.product-edition-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.product-edition-card {
    background: #f5f7fb;
    border: 1px solid #e2e8f2;
}
.product-testimonial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.product-testimonial-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
}
.product-testimonial-card__quote {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.8;
}
.product-testimonial-card__author {
    margin-top: 1rem;
    font-size: 1rem;
}
.product-testimonial-card__role {
    color: rgba(255,255,255,.72);
}
.product-faq__list {
    display: grid;
    gap: .85rem;
}
.product-faq__item {
    border: 1px solid #dfe6f1;
    border-radius: 18px;
    padding: 1rem 1.2rem;
    background: #f8fafc;
}
.product-faq__item summary {
    cursor: pointer;
    font-family: "Montserrat", "Space Grotesk", sans-serif;
    font-weight: 700;
    list-style: none;
}
.product-faq__item summary::-webkit-details-marker {
    display: none;
}
.product-trial-cta {
    padding: 4.5rem 0 5rem;
    background: linear-gradient(180deg, #091123 0%, #12244f 100%);
    color: var(--white);
}
.product-trial-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer {
    background: transparent;
    color: #121212;
    padding: 2rem 0 0;
    border-top: 0;
}
.site-footer .container {
    width: min(1480px, calc(100% - 1.5rem));
    max-width: 1480px;
}
.site-footer__top {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding-bottom: 2.75rem;
    padding-top: 0;
    padding-left: 80px;
    padding-right: 80px;
    background: #f3f7fb;
    border-radius: 60px 60px 0 0;
}
.site-footer__intro {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: center;
    gap: 0;
    padding: 20px 50px;
}
.site-footer__logo {
    display: inline-flex;
    align-items: center;
}
.site-footer__logo img {
    width: min(100%, 274px);
    height: auto;
}
.site-footer__tagline {
    font-size: 16px;
    max-width: 100%;
    line-height: 1.55;
    color: #333333;
    margin-left: -10%;
    font-family: "Roboto", "Manrope", sans-serif;
}
.site-footer__rule {
    width: 100%;
    height: 5px;
    background: #0a1b5c;
    border-radius: 20px;
    margin-top: -15px;
}
.site-footer__grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1.15fr 1.05fr 1.05fr;
    gap: 0;
    align-items: start;
    margin-top: 20px;
    padding-left: 55px;
    padding-right: 55px;
}
.site-footer__column {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.site-footer__heading {
    font-family: "Montserrat", "Space Grotesk", sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: #0a1b5c;
    letter-spacing: -.01em;
}
.site-footer__heading-rule {
    width: 20%;
    height: 5px;
    background: #0a1b5c;
    border-radius: 20px;
    margin-top: -15px;
    margin-bottom: 0;
}
.site-footer__links,
.site-footer__contact-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 10px;
}
.site-footer__links a,
.site-footer__contact-list a,
.site-footer__contact-list p {
    font-family: "Roboto", "Manrope", sans-serif;
    font-size: 14.5px;
    font-weight: 600;
    line-height: 1.2;
    color: #222222;
    transition: color var(--transition);
    padding-top: 8px;
    padding-bottom: 8px;
}
.site-footer__links a:hover,
.site-footer__contact-list a:hover {
    color: #0a1b5c;
}
.site-footer__contact-row {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding-top: 0;
    padding-bottom: 0;
}
.site-footer__contact-row img {
    width: 25px;
    height: 25px;
    object-fit: contain;
    flex-shrink: 0;
    margin-right: 5px;
    margin-bottom: 15px;
}
.site-footer__contact-list p {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.6;
    padding-top: 0;
    padding-bottom: 0;
}
.site-footer__contact-list a span {
    display: inline-block;
    padding-bottom: 15px;
}
.site-footer__bottom {
    width: 90%;
    margin: 0 auto;
    min-height: 10px;
    padding: 10px 0;
    font-size: 14px;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: #2e5ace;
    border-radius: 50px;
}
.site-footer__bottom p,
.site-footer__bottom a {
    color: #ffffff;
    margin: 0;
}
.site-footer__bottom a:hover {
    color: #d9d9d9;
}

/* ==========================================================================
   BLOG ARCHIVE
   ========================================================================== */
.blog-page {
    padding: 3.5rem 0 5rem;
    background:
        radial-gradient(circle at top left, rgba(34, 71, 255, .08), transparent 24%),
        linear-gradient(180deg, #f5f8ff 0%, #ffffff 38%);
}
.blog-page__hero-inner {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: 2.2rem;
}
.blog-page__hero-copy {
    max-width: 760px;
}
.blog-page__hero-copy h1 {
    margin-top: .85rem;
    font-size: clamp(2.4rem, 4vw, 4.3rem);
    line-height: 1;
    letter-spacing: -.04em;
}
.blog-page__hero-copy p {
    margin-top: 1rem;
    font-size: 1.05rem;
    line-height: 1.75;
    color: #4f6185;
    max-width: 58ch;
}
.blog-page__filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .75rem;
}
.blog-page__filter {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 1.1rem;
    border-radius: 999px;
    border: 1px solid #d9e2f2;
    background: rgba(255,255,255,.84);
    color: #324567;
    font-size: .9rem;
    font-weight: 700;
}
.blog-page__filter.is-active {
    border-color: #1e34f5;
    color: #1e34f5;
    box-shadow: 0 12px 30px rgba(30,52,245,.08);
}
.blog-page__lead-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 0.92fr;
    gap: 1.35rem;
    align-items: stretch;
}
.blog-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    background: #ffffff;
    border: 1px solid #e2e7f1;
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 18px 50px rgba(11, 15, 28, .06);
}
.blog-card__media {
    aspect-ratio: 16/10;
    background: linear-gradient(180deg, #dfe7f4 0%, #eef3fb 100%);
}
.blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.blog-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 1.35rem 1.45rem 1.5rem;
}
.blog-card__pill {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    min-height: 38px;
    padding: 0 .9rem;
    border-radius: 999px;
    border: 2px solid #2f47ff;
    color: #243df3;
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.blog-card__title {
    margin-top: 1rem;
    font-size: clamp(1.55rem, 2.2vw, 2.1rem);
    line-height: 1.18;
    letter-spacing: -.03em;
}
.blog-card__author {
    display: flex;
    align-items: center;
    gap: .85rem;
    margin-top: 1.25rem;
    color: #566784;
}
.blog-card__author-mark {
    display: inline-flex;
    width: 48px;
    height: 48px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, #1c5cff 0%, #2f9df7 100%);
    color: #ffffff;
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
}
.blog-card__author-name {
    display: block;
    color: #20293b;
    font-size: .94rem;
    font-weight: 700;
}
.blog-card__author-date {
    display: block;
    margin-top: .12rem;
    font-size: .9rem;
}
.blog-card__excerpt {
    margin-top: 1.15rem;
    color: #40516f;
    line-height: 1.8;
}
.blog-card__link {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    margin-top: auto;
    padding-top: 1.35rem;
    color: #1d37f4;
    font-size: .95rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .01em;
}
.blog-card__link:hover {
    color: #0f29cc;
}
.blog-card__link-arrow {
    font-size: 1.1rem;
    line-height: 1;
}
.blog-promo {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border-radius: 28px;
    overflow: hidden;
    background: #292942;
    border: 2px solid #2338ff;
    box-shadow: 0 24px 54px rgba(24, 35, 120, .16);
}
.blog-promo__content {
    padding: 2rem 2rem 1.6rem;
    color: #ffffff;
}
.blog-promo__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 .8rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.72);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.blog-promo__title {
    margin-top: 1rem;
    font-size: clamp(1.6rem, 2.1vw, 2.25rem);
    line-height: 1.2;
    letter-spacing: -.03em;
}
.blog-promo__text {
    margin-top: .85rem;
    color: rgba(255,255,255,.78);
    line-height: 1.7;
}
.blog-promo__form {
    display: flex;
    align-items: center;
    gap: .6rem;
    margin-top: 1.5rem;
    padding: .5rem;
    border-radius: 999px;
    background: rgba(10, 16, 36, .44);
    border: 2px solid #16e0ef;
}
.blog-promo__input {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: #ffffff;
    font-size: 1rem;
    padding: 0 .8rem;
}
.blog-promo__input::placeholder {
    color: rgba(255,255,255,.72);
}
.blog-promo__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 1.4rem;
    border-radius: 999px;
    background: #18e0ef;
    color: #0b1427;
    font-size: 1rem;
    font-weight: 800;
    white-space: nowrap;
}
.blog-promo__note {
    margin-top: .9rem;
    color: rgba(255,255,255,.62);
    font-size: .9rem;
}
.blog-promo__gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    min-height: 250px;
    margin-top: auto;
}
.blog-promo__tile {
    background: #161821;
}
.blog-promo__tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.blog-page__recent {
    margin-top: 2rem;
}
.blog-page__section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
}
.blog-page__section-head h2 {
    font-size: clamp(1.6rem, 2.3vw, 2.25rem);
    letter-spacing: -.03em;
}
.blog-page__section-head p {
    color: #5f6f8b;
}
.blog-page__recent-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}
.blog-card--compact .blog-card__media {
    aspect-ratio: 16/9;
}
.blog-card--compact .blog-card__title {
    font-size: 1.35rem;
}

/* ==========================================================================
   INTERNAL ROUTES
   ========================================================================== */
.internal-route {
    padding: 3.6rem 0 5rem;
    background:
        radial-gradient(circle at right top, rgba(21, 224, 239, .08), transparent 22%),
        linear-gradient(180deg, #f5f8ff 0%, #ffffff 40%);
}
.internal-route__hero {
    display: grid;
    grid-template-columns: 1.5fr .85fr;
    gap: 1.4rem;
    margin-bottom: 1.5rem;
}
.internal-route__hero-main,
.internal-route__hero-side,
.internal-route__card,
.single-post__content {
    background: #ffffff;
    border: 1px solid #e2e7f1;
    border-radius: 28px;
    box-shadow: 0 18px 50px rgba(11, 15, 28, .06);
}
.internal-route__hero-main {
    padding: 2.3rem;
}
.internal-route__hero-main h1 {
    margin-top: .8rem;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 1;
    letter-spacing: -.04em;
}
.internal-route__hero-main p {
    margin-top: 1rem;
    max-width: 56ch;
    color: #516480;
    line-height: 1.78;
}
.internal-route__hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1.6rem;
}
.internal-route__hero-side {
    padding: 2rem;
    background: linear-gradient(180deg, #171d31 0%, #232847 100%);
    color: #ffffff;
}
.internal-route__hero-side h2 {
    font-size: 1.35rem;
    line-height: 1.25;
}
.internal-route__hero-side p {
    margin-top: .8rem;
    color: rgba(255,255,255,.74);
}
.internal-route__list {
    display: grid;
    gap: .7rem;
    margin-top: 1.3rem;
}
.internal-route__list li {
    position: relative;
    padding-left: 1.2rem;
    color: rgba(255,255,255,.88);
}
.internal-route__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .62rem;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #16e0ef;
}
.internal-route__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
    margin-top: 1.6rem;
}
.internal-route__card {
    padding: 1.6rem;
}
.internal-route__card h3 {
    font-size: 1.2rem;
    line-height: 1.25;
}
.internal-route__card p {
    margin-top: .8rem;
    color: #53647f;
    line-height: 1.72;
}
.internal-route__cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    margin-top: 1.5rem;
    padding: 1.8rem 2rem;
    border-radius: 28px;
    background: linear-gradient(135deg, #111c37 0%, #213f9a 100%);
    color: #ffffff;
}
.internal-route__cta p {
    color: rgba(255,255,255,.78);
    max-width: 62ch;
}

/* ==========================================================================
   SINGLE POST
   ========================================================================== */
.single-post-page {
    padding: 3.5rem 0 5rem;
    background: linear-gradient(180deg, #f6f8fe 0%, #ffffff 35%);
}
.single-post__hero {
    margin-bottom: 1.6rem;
}
.single-post__hero-card {
    padding: 2.4rem;
    border-radius: 30px;
    background: #ffffff;
    border: 1px solid #e2e7f1;
    box-shadow: 0 18px 50px rgba(11, 15, 28, .06);
}
.single-post__hero-card h1 {
    margin-top: .9rem;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 1;
    letter-spacing: -.04em;
}
.single-post__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.4rem;
    margin-top: 1.3rem;
    color: #576987;
    font-weight: 600;
}
.single-post__summary {
    margin-top: 1rem;
    max-width: 62ch;
    color: #4f6180;
    line-height: 1.8;
}
.single-post__image {
    margin-top: 1.4rem;
    overflow: hidden;
    border-radius: 24px;
}
.single-post__image img {
    width: 100%;
    max-height: 520px;
    object-fit: cover;
}
.single-post__content {
    padding: 2rem;
}
.single-post__content .entry-content {
    line-height: 1.85;
}
.single-post__content .entry-content > * + * {
    margin-top: 1.2rem;
}

/* ==========================================================================
   INNER PAGES
   ========================================================================== */
.site-main--default, .page-content { padding: 4rem 0; }
.entry {
    background: var(--white);
    border: 1px solid var(--neutral-200);
    border-radius: var(--radius-md);
    padding: 2rem;
}
.entry-title {
    font-size: clamp(1.6rem, 2.5vw, 2.2rem);
    margin-bottom: 1rem;
    letter-spacing: -.02em;
}
.entry-content { line-height: 1.75; }

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */
@keyframes panelFade {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
    .resource-grid { grid-template-columns: repeat(2, 1fr); }
    .tabs__panel.is-active {
        grid-template-columns: 64px 1fr;
    }
    .tabs__panel-image { display: none; }
    .mega-menu {
        width: min(1320px, calc(100vw - 2rem));
        max-width: 1320px;
    }
    .mega-menu__layout--products,
    .mega-menu__layout--simple,
    .product-toolset-grid,
    .product-plugin-grid,
    .product-edition-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .product-benefits,
    .product-testimonial-grid,
    .product-hero__inner,
    .product-trial-cta__inner {
        grid-template-columns: 1fr;
        flex-direction: column;
    }
    .product-feature-list {
        grid-template-columns: 1fr;
    }
    .blog-page__hero-inner,
    .blog-page__section-head,
    .internal-route__cta {
        flex-direction: column;
        align-items: flex-start;
    }
    .blog-page__lead-grid,
    .blog-page__recent-grid,
    .internal-route__hero,
    .internal-route__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .blog-promo {
        grid-column: 1 / -1;
    }
    .home-blog__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-areas:
            "lead lead"
            "spotlight spotlight"
            "compact-1 compact-2"
            "compact-3 compact-4";
    }
}

@media (max-width: 860px) {
    .hero__inner { grid-template-columns: 1fr; }
    .hero__right { display: none; }
    .hero { padding: 4.5rem 0 3.5rem; }
    .highlight__card { flex-direction: column; gap: 1.5rem; padding: 2rem 1.5rem; }
    .final-cta__inner { flex-direction: column; gap: 1.5rem; }
    .site-header__utility-inner { flex-direction: column; justify-content: center; padding: .45rem 0; }
    .site-header__utility-links { flex-wrap: wrap; justify-content: center; }
    .site-footer__top { padding-left: 20px; padding-right: 20px; }
    .site-footer__intro { grid-template-columns: 1fr; padding-left: 0; padding-right: 0; }
    .site-footer__tagline { margin-left: 0; max-width: 100%; }
    .site-footer__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .home-blog__card--lead .home-blog__card-link { grid-template-columns: 1fr; }
    .blog-page__lead-grid,
    .blog-page__recent-grid,
    .internal-route__hero,
    .internal-route__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .site-header__utility {
        display: none;
    }
    .main-nav {
        position: fixed;
        top: 72px; left: 0; right: 0;
        background: #0b0f1f;
        border-bottom: 1px solid rgba(255,255,255,.07);
        padding: 1.2rem 1.5rem;
        display: none;
        flex-direction: column;
        align-items: flex-start;
    }
    .main-nav.is-open { display: flex; }
    .main-nav__list { flex-direction: column; width: 100%; gap: .3rem; }
    .main-nav__item,
    .has-mega-menu,
    .main-nav__trigger {
        width: 100%;
    }
    .main-nav__trigger {
        justify-content: space-between;
    }
    .mega-menu {
        position: static;
        min-width: 0;
        width: 100%;
        max-width: none;
        margin-top: .45rem;
        padding: .8rem;
        border-radius: 16px;
    }
    .mega-menu::before {
        display: none;
    }
    .mega-menu__layout--products,
    .mega-menu__layout--simple,
    .mega-menu__product-grid {
        grid-template-columns: 1fr;
    }
    .mega-menu__panel {
        padding: 0;
        border-left: 0;
        padding-top: 1rem;
        margin-top: 1rem;
        border-top: 1px solid rgba(255,255,255,.08);
    }
    .mega-menu__panel:first-child {
        margin-top: 0;
        padding-top: 0;
        border-top: 0;
    }
    .nav-actions { flex-direction: column; align-items: stretch; width: 100%; }
    .btn-nav-login { text-align: center; }
    .menu-toggle { display: flex; }
    .blog-page,
    .internal-route,
    .single-post-page {
        padding-top: 2.5rem;
    }
    .blog-page__hero-copy h1,
    .internal-route__hero-main h1,
    .single-post__hero-card h1 {
        font-size: clamp(2rem, 11vw, 2.9rem);
    }
    .blog-promo__content,
    .internal-route__hero-main,
    .internal-route__hero-side,
    .internal-route__card,
    .single-post__hero-card,
    .single-post__content {
        padding: 1.5rem;
    }
    .blog-promo__form {
        flex-direction: column;
        align-items: stretch;
        border-radius: 24px;
    }
    .blog-promo__button {
        width: 100%;
    }
}

@media (max-width: 600px) {
    .resource-grid { grid-template-columns: 1fr; }
    .logo-grid      { grid-template-columns: repeat(2, 1fr); }
    .tabs__panel.is-active { grid-template-columns: 1fr; }
    .tabs__panel-icon { display: none; }
    .hero__actions { flex-direction: column; align-items: stretch; }
    .hero__actions .btn { text-align: center; }
    .site-footer__grid { grid-template-columns: 1fr; }
    .site-footer__top { border-radius: 32px 32px 0 0; }
    .site-footer__bottom { width: calc(100% - 2rem); padding-left: 1rem; padding-right: 1rem; }
    .home-blog__grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "lead"
            "spotlight"
            "compact-1"
            "compact-2"
            "compact-3"
            "compact-4";
    }
}

/* ==========================================================================
   GSTARCAD PAGE v2 — Modern redesign
   ========================================================================== */

/* ---- Page wrapper ---- */
.gs-page { background: var(--white); }

/* ---- Hero ---- */
.gs-hero {
    position: relative;
    overflow: hidden;
    padding: 5.5rem 0 5rem;
    background:
        radial-gradient(ellipse 65% 60% at 105% -5%, rgba(26,62,207,.5) 0%, transparent 58%),
        radial-gradient(ellipse 50% 45% at -5% 105%, rgba(132,230,32,.1) 0%, transparent 55%),
        linear-gradient(170deg, #060b1c 0%, #0a1228 55%, #0c1735 100%);
    color: var(--white);
}
.gs-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}
.gs-hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3.5rem;
    align-items: center;
}
.gs-perp-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem 1rem;
    border-radius: var(--radius-pill);
    background: rgba(132,230,32,.15);
    border: 1.5px solid rgba(132,230,32,.45);
    color: var(--lime);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    width: fit-content;
}
.gs-hero__copy {
    display: flex;
    flex-direction: column;
    gap: 1.3rem;
}
.gs-hero__copy h1 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(2.4rem, 4.2vw, 3.8rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -.03em;
    color: var(--white);
}
.gs-hero__accent { color: var(--lime); }
.gs-hero__lead {
    font-size: 1.1rem;
    line-height: 1.72;
    color: rgba(255,255,255,.78);
    max-width: 44ch;
}
.gs-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    align-items: center;
}
.gs-btn--lime {
    background: var(--lime) !important;
    border-color: var(--lime) !important;
    color: #07101f !important;
}
.gs-btn--lime:hover {
    background: #a0f528 !important;
    box-shadow: 0 8px 26px rgba(132,230,32,.35) !important;
}
.gs-hero__visual {
    display: flex;
    justify-content: center;
    align-items: center;
}
.gs-hero__screen-wrap {
    position: relative;
    width: 100%;
}
.gs-hero__screen-wrap img {
    width: 100%;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.05);
    display: block;
}
.gs-hero__pill {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1rem;
    border-radius: var(--radius-pill);
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
    backdrop-filter: blur(10px);
}
.gs-hero__pill--top {
    top: -1rem;
    right: -1rem;
    background: rgba(26,62,207,.85);
    border: 1px solid rgba(91,138,255,.4);
    color: #c8d5f2;
}
.gs-hero__pill--bottom {
    bottom: -1rem;
    left: -1rem;
    background: rgba(9,21,44,.9);
    border: 1.5px solid rgba(132,230,32,.5);
    color: var(--lime);
}
.gs-hero__pill-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--lime);
    flex-shrink: 0;
    animation: gsDot 1.4s ease-in-out infinite;
}
@keyframes gsDot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: .4; transform: scale(.7); }
}

/* ---- Trust strip ---- */
.gs-trust-strip {
    background: #0a0f1f;
    border-top: 1px solid rgba(255,255,255,.06);
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: 1.25rem 0;
}
.gs-trust-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem 2rem;
}
.gs-trust-item {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    color: rgba(200,213,242,.7);
    font-size: .85rem;
    font-weight: 600;
    white-space: nowrap;
}
.gs-trust-item svg { color: var(--lime); flex-shrink: 0; }

/* ---- Sections base ---- */
.gs-section { padding: 5rem 0; }
.gs-section--light   { background: #ffffff; color: #121212; }
.gs-section--dark    { background: #0c1223; color: var(--white); }
.gs-section--neutral { background: #f4f7fc; color: #121212; }

.gs-section-head { margin-bottom: 2.5rem; }
.gs-section-head h2 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    font-weight: 800;
    letter-spacing: -.03em;
    line-height: 1.12;
    margin-top: .6rem;
    max-width: 22ch;
}
.gs-section--light   .gs-section-head h2 { color: #0a1228; }
.gs-section--dark    .gs-section-head h2 { color: var(--white); }
.gs-section--neutral .gs-section-head h2 { color: #0a1228; }
.gs-section-head p {
    margin-top: .85rem;
    max-width: 58ch;
    line-height: 1.75;
    opacity: .78;
}
.gs-eyebrow--blue { color: #2e5ace !important; border-bottom-color: #2e5ace !important; }
.gs-eyebrow--lime { color: var(--lime) !important; border-bottom-color: var(--lime) !important; }

/* ---- Toolsets ---- */
.gs-toolset-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
}
.gs-toolset-card {
    background: #f4f7fc;
    border: 1px solid #dde5f3;
    border-radius: 20px;
    padding: 1.6rem;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.gs-toolset-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(10,18,40,.1);
    border-color: #2e5ace;
}
.gs-toolset-card__icon {
    font-size: 2rem;
    margin-bottom: 1rem;
    display: block;
}
.gs-toolset-card h3 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: #0a1228;
}
.gs-toolset-card p {
    margin-top: .6rem;
    font-size: .9rem;
    line-height: 1.65;
    color: #4a5e80;
}

/* ---- DWG section ---- */
.gs-dwg-layout {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 4rem;
    align-items: start;
}
.gs-dwg-intro {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: sticky;
    top: 6rem;
}
.gs-dwg-intro h2 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(2rem, 3.2vw, 3rem);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -.03em;
    color: var(--white);
    margin-top: .4rem;
}
.gs-dwg-intro p {
    font-size: .95rem;
    line-height: 1.78;
    color: rgba(200,213,242,.72);
    max-width: 38ch;
}
.gs-dwg-intro__cta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: .5rem;
}
.gs-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}
.gs-feature-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.3rem 1.4rem;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    transition: background var(--transition), border-color var(--transition);
}
.gs-feature-card:hover {
    background: rgba(255,255,255,.08);
    border-color: rgba(132,230,32,.3);
}
.gs-feature-card__check {
    display: inline-flex;
    width: 28px;
    height: 28px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(132,230,32,.18);
    color: var(--lime);
    flex-shrink: 0;
    margin-top: 1px;
}
.gs-feature-card strong {
    display: block;
    font-size: .95rem;
    font-weight: 700;
    color: var(--white);
}
.gs-feature-card p {
    margin-top: .4rem;
    font-size: .85rem;
    line-height: 1.6;
    color: rgba(200,213,242,.68);
}

/* ---- Perpetual section ---- */
.gs-perp-section {
    padding: 5rem 0;
    background: linear-gradient(160deg, #060f25 0%, #0e1d3e 50%, #071020 100%);
    color: var(--white);
}
.gs-perp-section__inner {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 4rem;
    align-items: center;
}
.gs-perp-section__copy {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.gs-perp-section__copy h2 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(2.1rem, 3.5vw, 3.2rem);
    font-weight: 800;
    line-height: 1.06;
    letter-spacing: -.03em;
    color: var(--white);
    margin-top: .4rem;
}
.gs-perp-section__copy p {
    font-size: .96rem;
    line-height: 1.78;
    color: rgba(200,213,242,.72);
    max-width: 42ch;
}
.gs-perp-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.gs-perp-card { border-radius: 20px; padding: 1.6rem; }
.gs-perp-card--no {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.1);
    opacity: .72;
}
.gs-perp-card--yes {
    background: rgba(132,230,32,.08);
    border: 1.5px solid rgba(132,230,32,.35);
}
.gs-perp-card__badge {
    display: inline-flex;
    padding: .35rem .8rem;
    border-radius: var(--radius-pill);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}
.gs-perp-card__badge--no  { background: rgba(255,255,255,.08); color: rgba(200,213,242,.7); }
.gs-perp-card__badge--yes { background: rgba(132,230,32,.2); color: var(--lime); }
.gs-perp-list { display: flex; flex-direction: column; gap: .75rem; }
.gs-perp-list li {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .9rem;
    line-height: 1.4;
    color: rgba(200,213,242,.85);
}
.gs-perp-list__icon { font-size: 1rem; font-weight: 900; flex-shrink: 0; width: 18px; text-align: center; }
.gs-perp-list__icon--yes { color: var(--lime); }
.gs-perp-list__icon--no  { color: rgba(255,80,80,.75); }

/* ---- Editions ---- */
.gs-edition-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
    align-items: stretch;
}
.gs-edition-card {
    position: relative;
    background: #f4f7fc;
    border: 1px solid #dde5f3;
    border-radius: 22px;
    padding: 1.6rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.gs-edition-card--featured {
    background: #0a1228;
    border-color: var(--lime);
    color: var(--white);
}
.gs-edition-card__badge {
    display: inline-flex;
    align-self: flex-start;
    padding: .3rem .75rem;
    border-radius: var(--radius-pill);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    background: var(--lime);
    color: #07101f;
    margin-bottom: .25rem;
}
.gs-edition-card h3 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: inherit;
    line-height: 1.3;
}
.gs-edition-card h3 strong {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -.02em;
}
.gs-edition-card--featured h3 { color: var(--white); }
.gs-edition-card__desc {
    font-size: .88rem;
    line-height: 1.65;
    opacity: .78;
    margin: 0;
}
.gs-edition-card__feats { display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.gs-edition-card__feats li {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .85rem;
    line-height: 1.35;
}
.gs-edition-card__feats li svg { color: #2e5ace; flex-shrink: 0; }
.gs-edition-card--featured .gs-edition-card__feats li svg { color: var(--lime); }
.gs-edition-card__cta { display: flex; align-items: center; justify-content: center; width: 100%; margin-top: auto; }
.gs-editions-note { margin-top: 2rem; text-align: center; font-size: .9rem; color: #5a6d88; }
.gs-editions-note a { color: #2e5ace; font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }

/* ---- Plugins ---- */
.gs-plugin-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}
.gs-plugin-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 200px;
    padding: 1.4rem;
    border-radius: 18px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    color: var(--white);
    transition: background var(--transition), border-color var(--transition), transform var(--transition);
}
.gs-plugin-card:hover {
    background: rgba(255,255,255,.09);
    border-color: rgba(132,230,32,.35);
    transform: translateY(-3px);
}
.gs-plugin-card__label {
    display: inline-flex;
    align-self: flex-start;
    padding: .3rem .65rem;
    border-radius: var(--radius-pill);
    background: rgba(255,255,255,.1);
    color: rgba(200,213,242,.8);
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.gs-plugin-card h3 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    margin-top: 1rem;
    color: var(--white);
}
.gs-plugin-card__cta { margin-top: 1rem; font-size: .82rem; font-weight: 700; color: var(--lime); }

/* ---- Testimonials ---- */
.gs-testimonial-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}
.gs-testimonial-card {
    background: #f4f7fc;
    border: 1px solid #dde5f3;
    border-radius: 22px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    transition: box-shadow var(--transition), transform var(--transition);
}
.gs-testimonial-card:hover {
    box-shadow: 0 12px 36px rgba(10,18,40,.09);
    transform: translateY(-2px);
}
.gs-testimonial-card__quote {
    font-size: 1rem;
    line-height: 1.8;
    color: #2a3a5c;
    font-style: italic;
    flex: 1;
}
.gs-testimonial-card__author { display: flex; align-items: center; gap: .9rem; }
.gs-testimonial-card__avatar {
    display: inline-flex;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1a3ecf 0%, #2f9df7 100%);
    color: #ffffff;
    font-family: "Space Grotesk", sans-serif;
    font-size: .95rem;
    font-weight: 700;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.gs-testimonial-card__author strong { display: block; font-size: .95rem; color: #0a1228; }
.gs-testimonial-card__author span   { display: block; font-size: .82rem; color: #5a6d88; margin-top: .15rem; }

/* ---- FAQ ---- */
.gs-faq-wrap {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 4rem;
    align-items: start;
}
.gs-faq-list { display: flex; flex-direction: column; gap: .75rem; }
.gs-faq-item {
    border: 1px solid #dde5f3;
    border-radius: 16px;
    background: #ffffff;
    overflow: hidden;
    transition: border-color var(--transition);
}
.gs-faq-item[open] { border-color: #2e5ace; }
.gs-faq-item summary {
    cursor: pointer;
    padding: 1.1rem 1.3rem;
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-weight: 700;
    font-size: .95rem;
    color: #0a1228;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    user-select: none;
}
.gs-faq-item summary::-webkit-details-marker { display: none; }
.gs-faq-item summary::after { content: "+"; font-size: 1.2rem; font-weight: 400; color: #2e5ace; flex-shrink: 0; }
.gs-faq-item[open] summary::after { content: "−"; }
.gs-faq-item p { padding: 0 1.3rem 1.1rem; font-size: .9rem; line-height: 1.72; color: #4a5e80; margin: 0; }

/* ---- CTA final ---- */
.gs-cta-section {
    padding: 5.5rem 0 6rem;
    background: linear-gradient(160deg, #060f25 0%, #0d1c3c 50%, #091222 100%);
    color: var(--white);
    position: relative;
    overflow: hidden;
}
.gs-cta-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 80% at 50% 120%, rgba(132,230,32,.14) 0%, transparent 65%);
    pointer-events: none;
}
.gs-cta-section__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;
    flex-wrap: wrap;
}
.gs-cta-section__inner h2 {
    font-family: "Space Grotesk", "Montserrat", sans-serif;
    font-size: clamp(1.9rem, 3vw, 2.9rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -.03em;
    color: var(--white);
    margin-top: .6rem;
    max-width: 22ch;
}
.gs-cta-section__inner p { margin-top: .8rem; font-size: .95rem; line-height: 1.7; color: rgba(200,213,242,.72); max-width: 44ch; }
.gs-cta-section__actions { display: flex; flex-wrap: wrap; gap: .8rem; flex-shrink: 0; }

/* ---- Responsive ---- */
@media (max-width: 1024px) {
    .gs-hero__inner          { grid-template-columns: 1fr; }
    .gs-hero__visual         { display: none; }
    .gs-toolset-grid         { grid-template-columns: repeat(2, 1fr); }
    .gs-dwg-layout           { grid-template-columns: 1fr; }
    .gs-dwg-intro            { position: static; }
    .gs-perp-section__inner  { grid-template-columns: 1fr; }
    .gs-edition-grid         { grid-template-columns: repeat(2, 1fr); }
    .gs-plugin-grid          { grid-template-columns: repeat(2, 1fr); }
    .gs-faq-wrap             { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .gs-toolset-grid         { grid-template-columns: 1fr; }
    .gs-feature-grid         { grid-template-columns: 1fr; }
    .gs-perp-cards           { grid-template-columns: 1fr; }
    .gs-edition-grid         { grid-template-columns: 1fr; }
    .gs-plugin-grid          { grid-template-columns: 1fr; }
    .gs-testimonial-grid     { grid-template-columns: 1fr; }
    .gs-trust-strip__inner   { justify-content: center; }
    .gs-cta-section__inner   { flex-direction: column; }
}

/* ==========================================================================
   GSTARCAD – DOWNLOAD TRIAL PAGE
   ========================================================================== */

/* ---- Download Hero ---- */
.gs-dl-page { background: #f4f7fc; }

.gs-dl-hero {
    position: relative;
    background: #07101f;
    padding: 2rem 0 0;
    overflow: hidden;
}
.gs-dl-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 60% at 110% 30%, rgba(var(--edition-color, 46,90,206),.18) 0%, transparent 70%);
    pointer-events: none;
}
.gs-dl-hero__inner { position: relative; z-index: 1; }

.gs-dl-hero__breadcrumb {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .82rem;
    color: rgba(200,213,242,.6);
    margin-bottom: 2rem;
}
.gs-dl-hero__breadcrumb a { color: rgba(200,213,242,.7); text-decoration: none; }
.gs-dl-hero__breadcrumb a:hover { color: var(--white); }
.gs-dl-hero__breadcrumb svg { opacity: .5; }

.gs-dl-hero__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
    padding-bottom: 4rem;
}
.gs-dl-hero__badges {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.25rem;
}
.gs-dl-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .3rem .85rem;
    border-radius: var(--radius-pill);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.gs-dl-badge--trial {
    background: rgba(132,230,32,.15);
    color: #84e620;
    border: 1px solid rgba(132,230,32,.3);
}
.gs-dl-badge--pop {
    background: rgba(132,230,32,1);
    color: #07101f;
}
.gs-dl-hero__title {
    font-family: "Space Grotesk","Montserrat",sans-serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    color: rgba(200,213,242,.75);
    line-height: 1.1;
    margin: 0 0 1rem;
}
.gs-dl-hero__edition {
    display: block;
    font-size: clamp(2.8rem, 6vw, 4.5rem);
    font-weight: 900;
    letter-spacing: -.03em;
    color: var(--white);
    background: linear-gradient(135deg, var(--white) 40%, var(--edition-color, #84e620) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.gs-dl-hero__tagline {
    font-size: 1.05rem;
    color: rgba(200,213,242,.75);
    max-width: 520px;
    line-height: 1.65;
    margin: 0 0 1.75rem;
}
.gs-dl-hero__hl {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.gs-dl-hero__hl li {
    display: flex;
    align-items: center;
    gap: .65rem;
    font-size: .95rem;
    color: rgba(200,213,242,.85);
}
.gs-dl-hero__hl li svg { color: #84e620; flex-shrink: 0; }

/* Single screenshot + floating pills */
.gs-dl-hero__visual { display: flex; justify-content: center; align-items: center; }
.gs-dl-shot-wrap {
    position: relative;
    width: 100%;
    max-width: 620px;
}
.gs-dl-shot-single {
    margin: 0;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.18);
    box-shadow: 0 30px 70px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06);
    background: #0e1b31;
    line-height: 0;
}
.gs-dl-shot-single img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center top;
}

/* Pills */
.gs-dl-pill {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1rem;
    border-radius: var(--radius-pill);
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
    backdrop-filter: blur(10px);
    z-index: 4;
}
.gs-dl-pill--top {
    top: -14px;
    right: -14px;
    background: rgba(26,62,207,.85);
    border: 1px solid rgba(91,138,255,.4);
    color: #c8d5f2;
}
.gs-dl-pill--bottom {
    bottom: -14px;
    left: -14px;
    background: rgba(9,21,44,.9);
    border: 1.5px solid rgba(132,230,32,.5);
    color: var(--lime);
}
.gs-dl-pill--side {
    top: 50%;
    right: -18px;
    transform: translateY(-50%);
    background: rgba(9,21,44,.92);
    border: 1px solid rgba(255,255,255,.15);
    color: rgba(200,213,242,.9);
}
.gs-dl-pill__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--lime);
    flex-shrink: 0;
    animation: gsDot 1.4s ease-in-out infinite;
}
.gs-dl-pill svg { flex-shrink: 0; color: #84e620; }
.gs-dl-hero__wave {
    line-height: 0;
    margin-bottom: -2px;
}
.gs-dl-hero__wave svg { width: 100%; height: 60px; }

/* ---- Main layout ---- */
.gs-dl-layout { padding: 3rem 0 5rem; }
.gs-dl-layout__inner {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 3rem;
    align-items: start;
}

/* ---- Section headings ---- */
.gs-dl-section { margin-bottom: 2.5rem; }
.gs-dl-section__title {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-family: "Space Grotesk","Montserrat",sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    color: #0a1228;
    margin: 0 0 1.5rem;
}
.gs-dl-section__title-accent {
    display: inline-block;
    width: 4px;
    height: 22px;
    border-radius: 4px;
    flex-shrink: 0;
}

/* ---- Feature grid ---- */
.gs-dl-feat-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.gs-dl-feat-card {
    display: flex;
    gap: .9rem;
    align-items: flex-start;
    padding: 1.1rem 1.25rem;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    transition: box-shadow var(--transition), transform var(--transition);
}
.gs-dl-feat-card:hover { box-shadow: 0 6px 20px rgba(30,50,100,.08); transform: translateY(-2px); }
.gs-dl-feat-card__icon {
    font-size: 1.4rem;
    line-height: 1;
    flex-shrink: 0;
    margin-top: .15rem;
}
.gs-dl-feat-card strong {
    display: block;
    font-size: .9rem;
    font-weight: 700;
    color: #0a1228;
    margin-bottom: .25rem;
}
.gs-dl-feat-card p {
    margin: 0;
    font-size: .82rem;
    color: #5a6d88;
    line-height: 1.5;
}

/* ---- Requirements table ---- */
.gs-dl-req-table {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    overflow: hidden;
}
.gs-dl-req-row {
    display: flex;
    align-items: center;
    padding: .85rem 1.25rem;
    gap: 1rem;
    border-bottom: 1px solid #eef1f8;
}
.gs-dl-req-row:last-child { border-bottom: none; }
.gs-dl-req-row__label {
    font-size: .82rem;
    font-weight: 700;
    color: #5a6d88;
    text-transform: uppercase;
    letter-spacing: .04em;
    min-width: 110px;
    flex-shrink: 0;
}
.gs-dl-req-row__value {
    font-size: .88rem;
    color: #0a1228;
    font-weight: 500;
}
.gs-dl-req-note {
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    margin-top: .85rem;
    font-size: .8rem;
    color: #7a8eaa;
    line-height: 1.5;
}
.gs-dl-req-note svg { color: #2e5ace; flex-shrink: 0; margin-top: .1rem; }

/* ---- Compare banner ---- */
.gs-dl-compare-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.25rem 1.5rem;
    background: #0a1228;
    border-radius: 16px;
    color: var(--white);
    margin-top: .5rem;
}
.gs-dl-compare-banner strong {
    display: block;
    font-size: .95rem;
    margin-bottom: .3rem;
}
.gs-dl-compare-banner p {
    margin: 0;
    font-size: .82rem;
    color: rgba(200,213,242,.7);
}

/* ---- Form card ---- */
.gs-dl-form-wrap { position: sticky; top: 5rem; }
.gs-dl-form-card {
    background: var(--white);
    border: 1.5px solid #dde5f3;
    border-radius: 22px;
    padding: 2rem;
    box-shadow: 0 8px 40px rgba(10,18,40,.08);
}
.gs-dl-form-header { margin-bottom: 1.5rem; }
.gs-dl-form-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .3rem .85rem;
    border-radius: var(--radius-pill);
    background: rgba(132,230,32,.12);
    color: #3d7a00;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: .75rem;
}
.gs-dl-form-header h3 {
    font-family: "Space Grotesk","Montserrat",sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
    color: #0a1228;
    margin: 0 0 .4rem;
    line-height: 1.3;
}
.gs-dl-form-sub {
    font-size: .85rem;
    color: #5a6d88;
    margin: 0;
    line-height: 1.55;
}
.gs-dl-form-alert {
    padding: .75rem 1rem;
    border-radius: 10px;
    background: #fff3f3;
    border: 1px solid #ffcccc;
    color: #c00;
    font-size: .85rem;
    margin-bottom: 1rem;
}

/* ---- Form fields ---- */
.gs-dl-form { display: flex; flex-direction: column; gap: .85rem; }
.gs-form-group { display: flex; flex-direction: column; gap: .35rem; }
.gs-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.gs-form-label {
    font-size: .8rem;
    font-weight: 700;
    color: #2a3a55;
    letter-spacing: .02em;
}
.gs-form-label span { color: #2e5ace; }
.gs-form-input {
    width: 100%;
    padding: .7rem .95rem;
    background: #f4f7fc;
    border: 1.5px solid #dde5f3;
    border-radius: 10px;
    font-size: .88rem;
    color: #0a1228;
    font-family: inherit;
    transition: border-color var(--transition), box-shadow var(--transition);
    box-sizing: border-box;
}
.gs-form-input::placeholder { color: #9aaabf; }
.gs-form-input:focus {
    outline: none;
    border-color: var(--edition-color, #2e5ace);
    box-shadow: 0 0 0 3px rgba(46,90,206,.12);
}
.gs-form-select { appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%235a6d88' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .85rem center; padding-right: 2.2rem; }
.gs-dl-form__actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: .6rem;
    margin-top: .25rem;
}
.gs-dl-form__submit {
    width: 100%;
    gap: .5rem;
}
.gs-dl-form__price {
    width: 100%;
    justify-content: center;
    text-align: center;
}
.gs-dl-form-privacy {
    display: flex;
    align-items: center;
    gap: .4rem;
    justify-content: center;
    font-size: .75rem;
    color: #9aaabf;
    margin: 0;
}
.gs-dl-form-privacy svg { flex-shrink: 0; color: #9aaabf; }

/* ---- Form success state ---- */
.gs-dl-form-success {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1rem;
    padding: 1rem 0;
}
.gs-dl-form-success h3 {
    font-family: "Space Grotesk","Montserrat",sans-serif;
    font-size: 1.35rem;
    font-weight: 800;
    color: #0a1228;
    margin: 0;
}
.gs-dl-form-success p {
    font-size: .9rem;
    color: #5a6d88;
    margin: 0;
    max-width: 300px;
    line-height: 1.6;
}

/* ---- Trust signals ---- */
.gs-dl-form-trust {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid #eef1f8;
}
.gs-dl-form-trust__item {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8rem;
    color: #7a8eaa;
}
.gs-dl-form-trust__item svg { flex-shrink: 0; color: #84e620; }

/* ---- Responsive ---- */
@media (max-width: 1024px) {
    .gs-dl-hero__content   { grid-template-columns: 1fr; }
    .gs-dl-hero__visual    { display: flex; margin-top: 2.5rem; }
    .gs-dl-shot-wrap       { max-width: 100%; }
    .gs-dl-pill--side      { right: -12px; font-size: .72rem; }
    .gs-dl-layout__inner   { grid-template-columns: 1fr; }
    .gs-dl-form-wrap       { position: static; }
    .gs-dl-feat-grid       { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .gs-dl-pill--side      { display: none; }
    .gs-dl-pill--top       { right: -8px; }
    .gs-dl-pill--bottom    { left: -8px; }
    .gs-dl-feat-grid       { grid-template-columns: 1fr; }
    .gs-form-row           { grid-template-columns: 1fr; }
    .gs-dl-compare-banner  { flex-direction: column; align-items: flex-start; }
}

/* ═══════════════════════════════════════════════════════════════════════
   HOME — NOSSAS SOLUÇÕES  (.hs-solutions)
   ═══════════════════════════════════════════════════════════════════════ */
.hs-solutions {
    padding: 90px 0 80px;
    background: var(--dark-2);
}

/* Section header centered */
.section-head--center {
    text-align: center;
    max-width: 640px;
    margin: 0 auto 56px;
    color: var(--text-on-dark);
}
.section-head--center h2 {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: var(--white);
    margin: 8px 0 0;
}
.section-head__sub {
    margin-top: 14px;
    font-size: .95rem;
    color: var(--text-muted);
    line-height: 1.65;
}

/* Cards grid */
.hs-solutions__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
}

.hs-sol-card {
    position: relative;
    background: var(--dark-3);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: box-shadow .2s, transform .2s, border-color .2s;
}
.hs-sol-card:hover {
    box-shadow: 0 12px 40px rgba(0,0,0,.4);
    border-color: rgba(255,255,255,.14);
    transform: translateY(-4px);
}
.hs-sol-card--featured {
    border-color: rgba(132,230,32,.35);
    box-shadow: 0 4px 32px rgba(132,230,32,.1);
    transform: translateY(-6px);
}
.hs-sol-card--featured:hover {
    border-color: rgba(132,230,32,.6);
    box-shadow: 0 16px 48px rgba(132,230,32,.15);
    transform: translateY(-10px);
}

/* Image area */
.hs-sol-card__img-wrap {
    position: relative;
    height: 200px;
    background: var(--neutral-900);
    overflow: hidden;
}
.hs-sol-card__img-wrap--geo  { background: #0a1a10; }
.hs-sol-card__img-wrap--bim  { background: #120e1f; }
.hs-sol-card__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top left;
    opacity: .9;
    transition: opacity .2s, transform .3s;
}
.hs-sol-card:hover .hs-sol-card__img-wrap img {
    opacity: 1;
    transform: scale(1.03);
}
.hs-sol-card__pill {
    position: absolute;
    bottom: 12px;
    left: 12px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--dark);
    background: var(--lime);
    padding: 4px 10px;
    border-radius: var(--radius-pill);
}
.hs-sol-card__pill--green  { background: #4ade80; color: #052010; }
.hs-sol-card__pill--purple { background: #a78bfa; color: #1a0a3a; }

/* Badge */
.hs-sol-card__badge {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--dark);
    background: var(--lime);
    padding: 3px 10px;
    border-radius: var(--radius-pill);
    margin-bottom: 8px;
}

/* Body */
.hs-sol-card__body {
    padding: 24px 24px 22px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.hs-sol-card__name {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    margin: 0 0 8px;
}
.hs-sol-card__lead {
    font-size: .875rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0 0 16px;
}
.hs-sol-card__feats {
    list-style: none;
    padding: 0;
    margin: 0 0 auto;
    display: flex;
    flex-direction: column;
    gap: 7px;
}
.hs-sol-card__feats li {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: .84rem;
    color: var(--text-on-dark);
}
.hs-sol-card__feats svg { color: var(--lime); flex-shrink: 0; }
.hs-sol-card--featured .hs-sol-card__feats svg { color: #4ade80; }

.hs-sol-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 20px;
    font-size: .875rem;
    font-weight: 600;
    color: var(--lime);
    text-decoration: none;
    transition: gap .2s;
}
.hs-sol-card__cta--green { color: #4ade80; }
.hs-sol-card__cta:hover  { gap: 10px; }

/* Plugins strip */
.hs-plugins-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    margin-top: 48px;
    padding-top: 28px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.hs-plugins-strip__label {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--text-muted);
    white-space: nowrap;
}
.hs-plugins-strip__items {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.hs-plugins-strip__tag {
    font-size: .8rem;
    font-weight: 500;
    color: var(--text-on-dark);
    background: transparent;
    border: 1px solid rgba(255,255,255,.15);
    border-radius: var(--radius-pill);
    padding: 5px 14px;
    text-decoration: none;
    transition: border-color .15s, color .15s;
}
.hs-plugins-strip__tag:hover {
    border-color: var(--lime);
    color: var(--lime);
}
.hs-plugins-strip__tag--more {
    font-weight: 600;
    color: var(--lime);
    border-color: rgba(132,230,32,.4);
}

/* ═══════════════════════════════════════════════════════════════════════
   HOME — SOBRE A EMPRESA  (.hs-about)
   ═══════════════════════════════════════════════════════════════════════ */
.hs-about {
    padding: 90px 0;
    background: var(--dark);
}
.hs-about__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}

/* Left copy */
.hs-about__copy h2 {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: var(--white);
    margin: 8px 0 20px;
    line-height: 1.25;
}
.hs-about__text {
    font-size: .95rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0 0 14px;
}
.hs-about__stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 32px 0 36px;
}
.hs-about__stat {
    background: var(--dark-3);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--radius-md);
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.hs-about__stat-num {
    font-size: 1.9rem;
    font-weight: 800;
    color: var(--lime);
    line-height: 1;
}
.hs-about__stat-label {
    font-size: .78rem;
    color: var(--text-muted);
    font-weight: 500;
}

/* Right column — offices + contact */
.hs-about__offices {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 20px;
}
.hs-about__office {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: var(--dark-3);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: var(--radius-md);
    padding: 16px 18px;
}
.hs-about__office-icon {
    width: 36px;
    height: 36px;
    background: var(--blue-dark);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.hs-about__office-info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.hs-about__office-info strong {
    font-size: .9rem;
    color: var(--white);
}
.hs-about__office-info span {
    font-size: .82rem;
    color: var(--text-muted);
}
.hs-about__office-info a {
    font-size: .84rem;
    font-weight: 600;
    color: var(--lime);
    text-decoration: none;
}
.hs-about__office-info a:hover { text-decoration: underline; }

.hs-about__contact-card {
    background: linear-gradient(135deg, var(--blue-dark) 0%, var(--blue-mid) 100%);
    border-radius: var(--radius-lg);
    padding: 28px;
    color: #fff;
}
.hs-about__contact-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 8px;
}
.hs-about__contact-sub {
    font-size: .88rem;
    opacity: .8;
    line-height: 1.6;
    margin: 0 0 20px;
}
.hs-about__contact-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.hs-about__contact-card .btn--primary {
    background: var(--lime);
    border-color: var(--lime);
    color: var(--dark);
}
.hs-about__contact-card .btn--primary:hover {
    background: #a0f528;
    box-shadow: 0 6px 20px rgba(132,230,32,.35);
}
.hs-about__contact-card .btn--ghost {
    border-color: rgba(255,255,255,.5);
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.hs-about__contact-card .btn--ghost:hover {
    background: rgba(255,255,255,.12);
    border-color: #fff;
}
.hs-about__contact-email {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .82rem;
    opacity: .65;
    margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
    .hs-solutions__grid { grid-template-columns: 1fr 1fr; }
    .hs-sol-card--featured { transform: none; }
    .hs-about__inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 640px) {
    .hs-solutions__grid { grid-template-columns: 1fr; }
    .hs-about__stats { grid-template-columns: 1fr 1fr; }
    .hs-plugins-strip { flex-direction: column; align-items: flex-start; }
}
.section-head--center {
    text-align: center;
    align-items: center;
    max-width: 640px;
    margin: 0 auto 56px;
}
.section-head--center h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.section-head__sub {
    margin-top: 12px;
    font-size: .95rem;
    color: var(--text-muted);
    line-height: 1.65;
}

/* Cards grid */
.hs-solutions__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
}

.hs-sol-card {
    position: relative;
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: 0 2px 16px rgba(10,20,60,.07);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: box-shadow .25s, transform .25s;
}
.hs-sol-card:hover {
    box-shadow: 0 14px 44px rgba(10,20,60,.18);
    transform: translateY(-5px);
}
.hs-sol-card--featured {
    box-shadow: 0 0 0 2px var(--sol-accent, #1a3ecf), 0 10px 36px rgba(10,20,60,.16);
}
.hs-sol-card--featured:hover {
    box-shadow: 0 0 0 2px var(--sol-accent, #1a3ecf), 0 16px 48px rgba(10,20,60,.22);
    transform: translateY(-5px);
}

/* Media header com screenshot do produto */
.hs-sol-card__media {
    position: relative;
    height: 185px;
    background:
        radial-gradient(120% 120% at 85% 0%, color-mix(in srgb, var(--sol-accent, #1a3ecf) 35%, transparent) 0%, transparent 60%),
        linear-gradient(135deg, #0e1626 0%, #16213a 100%);
    overflow: hidden;
}
.hs-sol-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .4s ease;
}
.hs-sol-card:hover .hs-sol-card__media img { transform: scale(1.05); }
.hs-sol-card__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(8,12,24,.5) 100%);
    pointer-events: none;
}
.hs-sol-card__bar { display: none; }

.hs-sol-card__pill {
    position: absolute;
    bottom: 14px;
    left: 16px;
    z-index: 2;
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--sol-accent, #1a3ecf);
    background: #fff;
    padding: 5px 12px;
    border-radius: 20px;
    box-shadow: 0 2px 10px rgba(0,0,0,.25);
    margin: 0;
}
.hs-sol-card__badge {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    background: var(--sol-accent, #1a3ecf);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 20px;
    box-shadow: 0 2px 12px color-mix(in srgb, var(--sol-accent, #1a3ecf) 50%, transparent);
}
.hs-sol-card__inner {
    padding: 24px 26px 26px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.hs-sol-card__name {
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--dark);
    margin: 0 0 8px;
}
.hs-sol-card__lead {
    font-size: .9rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0 0 18px;
}
.hs-sol-card__feats {
    list-style: none;
    padding: 14px 0 0;
    margin: auto 0 0;
    display: flex;
    flex-direction: column;
    gap: 9px;
    border-top: 1px dashed rgba(10,20,60,.14);
}
.hs-sol-card__feats li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .86rem;
    color: var(--dark);
}
.hs-sol-card__feats svg { color: var(--sol-accent, #1a3ecf); flex-shrink: 0; }
.hs-sol-card__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 22px;
    padding: 11px 18px;
    border-radius: 10px;
    border: 1.5px solid color-mix(in srgb, var(--sol-accent, #1a3ecf) 45%, transparent);
    font-size: .9rem;
    font-weight: 700;
    color: var(--sol-accent, #1a3ecf);
    text-decoration: none;
    transition: background .2s, color .2s, border-color .2s;
}
.hs-sol-card__cta:hover {
    background: var(--sol-accent, #1a3ecf);
    border-color: var(--sol-accent, #1a3ecf);
    color: #fff;
}
.hs-sol-card__cta svg { transition: transform .2s; }
.hs-sol-card__cta:hover svg { transform: translateX(3px); }

/* Plugins strip */
.hs-plugins-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid rgba(0,0,0,.08);
}
.hs-plugins-strip__label {
    font-size: .78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-muted);
    white-space: nowrap;
}
.hs-plugins-strip__tag {
    font-size: .82rem;
    font-weight: 500;
    color: var(--dark);
    background: var(--white);
    border: 1px solid rgba(0,0,0,.12);
    border-radius: 20px;
    padding: 5px 14px;
    text-decoration: none;
    transition: border-color .15s, color .15s;
}
.hs-plugins-strip__tag:hover {
    border-color: var(--primary);
    color: var(--primary);
}
.hs-plugins-strip__tag--more {
    font-weight: 600;
    color: var(--primary);
    border-color: var(--primary);
}

/* ═══════════════════════════════════════════════════════════════════════
   HOME — SOBRE A EMPRESA  (.hs-about)
   ═══════════════════════════════════════════════════════════════════════ */
.hs-about {
    padding: 90px 0;
    background: var(--white);
}
.hs-about__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}
.hs-about__copy .eyebrow { color: var(--text-muted); }
.hs-about__copy h2 {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    margin: 8px 0 20px;
    line-height: 1.25;
}
.hs-about__text {
    font-size: .96rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0 0 14px;
}
.hs-about__stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 32px 0 36px;
}
.hs-about__stat {
    background: #f4f7fc;
    border-radius: var(--radius);
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.hs-about__stat-num {
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--primary);
    line-height: 1;
}
.hs-about__stat-label {
    font-size: .8rem;
    color: var(--text-muted);
    font-weight: 500;
}

/* Right column */
.hs-about__offices {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 24px;
}
.hs-about__office {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #f4f7fc;
    border-radius: var(--radius);
    padding: 16px 18px;
}
.hs-about__office-icon {
    width: 36px;
    height: 36px;
    background: var(--primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.hs-about__office-info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.hs-about__office-info strong {
    font-size: .92rem;
    color: var(--dark);
}
.hs-about__office-info span {
    font-size: .82rem;
    color: var(--text-muted);
}
.hs-about__office-info a {
    font-size: .85rem;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
}
.hs-about__office-info a:hover { text-decoration: underline; }

.hs-about__contact-card {
    background: var(--dark);
    border-radius: var(--radius-lg);
    padding: 28px;
    color: #fff;
}
.hs-about__contact-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 8px;
}
.hs-about__contact-sub {
    font-size: .88rem;
    opacity: .75;
    line-height: 1.6;
    margin: 0 0 20px;
}
.hs-about__contact-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.hs-about__contact-actions .btn--ghost {
    border-color: rgba(255,255,255,.35);
    color: #fff;
}
.hs-about__contact-actions .btn--ghost:hover {
    border-color: #fff;
    background: rgba(255,255,255,.08);
}
.hs-about__contact-email {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .82rem;
    opacity: .6;
    margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
    .hs-solutions__grid { grid-template-columns: 1fr 1fr; }
    .hs-sol-card--featured { transform: none; }
    .hs-about__inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 640px) {
    .hs-solutions__grid { grid-template-columns: 1fr; }
    .hs-about__stats { grid-template-columns: 1fr 1fr; }
    .hs-plugins-strip { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   WP NAV MENU — dropdown para menus criados no WordPress (ul.sub-menu)
   ========================================================================== */
.main-nav__list .menu-item { position: relative; }
.main-nav__list .menu-item-has-children > a::after {
    content: "";
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-left: 7px;
    border-right: 1.8px solid currentColor;
    border-bottom: 1.8px solid currentColor;
    transform: rotate(45deg) translateY(-3px);
}
.main-nav__list .sub-menu {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 240px;
    display: none;
    flex-direction: column;
    gap: 2px;
    padding: 10px;
    background: #0d1424;
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 14px;
    box-shadow: 0 22px 48px rgba(0,0,0,.5);
    z-index: 60;
}
.main-nav__list .sub-menu::before {
    content: "";
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 12px;
}
.main-nav__list .menu-item-has-children:hover > .sub-menu,
.main-nav__list .menu-item-has-children:focus-within > .sub-menu {
    display: flex;
}
.main-nav__list .sub-menu a {
    display: block;
    width: 100%;
    padding: 9px 12px;
    white-space: nowrap;
}
@media (max-width: 760px) {
    .main-nav__list .menu-item { width: 100%; }
    .main-nav__list .sub-menu {
        position: static;
        display: flex;
        min-width: 0;
        padding: 0 0 6px 14px;
        background: transparent;
        border: 0;
        border-left: 2px solid rgba(255,255,255,.12);
        border-radius: 0;
        box-shadow: none;
    }
    .main-nav__list .menu-item-has-children > a::after { display: none; }
}

/* ==========================================================================
   MEGA MENU — fixes de contraste dos botões + linha de compatibilidade de SO
   ========================================================================== */
.main-nav__list a.mega-menu__button--primary {
    background: #16e0ef;
    color: #07101f;
}
.main-nav__list a.mega-menu__button--primary:hover {
    background: #3ee8f5;
    color: #07101f;
}
.main-nav__list a.mega-menu__button--ghost {
    color: #16e0ef;
}
.main-nav__list a.mega-menu__button--ghost:hover {
    background: rgba(22,224,239,.12);
    color: #16e0ef;
}
.mega-menu__os {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    color: rgba(232,238,255,.78);
    font-size: .8rem;
}
.mega-menu__os-label {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: rgba(232,238,255,.55);
}
.mega-menu__os-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
}

/* ==========================================================================
   GSTARCAD PAGE — imagem nos cards de edição + faixa de logos de clientes
   ========================================================================== */
.gs-edition-card__img {
    margin: -1.6rem -1.6rem 0;
    height: 130px;
    border-radius: 21px 21px 0 0;
    overflow: hidden;
    background: #0e1626;
}
.gs-edition-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .35s ease;
}
.gs-edition-card:hover .gs-edition-card__img img { transform: scale(1.04); }
.gs-clients-logos {
    margin-top: 56px;
    padding-top: 36px;
    border-top: 1px solid rgba(10,20,60,.1);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 22px;
}
.gs-clients-logos__label {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--text-muted);
}
.gs-clients-logos__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 30px 44px;
}
.gs-clients-logos__row img {
    height: 44px;
    width: auto;
    object-fit: contain;
    filter: grayscale(1);
    opacity: .65;
    transition: filter .2s, opacity .2s;
}
.gs-clients-logos__row img:hover {
    filter: none;
    opacity: 1;
}

/* ==========================================================================
   GSTARCAD PAGE — bloco "conteúdo em destaque" (estilo Bricsys)
   ========================================================================== */
.gs-featured {
    background: #14151c;
    padding: 90px 0;
}
.gs-featured .gs-section-head h2 { color: var(--white); }
.gs-featured-track {
    display: flex;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    padding-bottom: 6px;
}
.gs-featured-track::-webkit-scrollbar { display: none; }
.gs-featured-card {
    flex: 0 0 calc((100% - 48px) / 3);
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    background: #262b36;
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 18px;
    overflow: hidden;
}
.gs-featured-card__media {
    height: 210px;
    background: #0e1626;
    overflow: hidden;
}
.gs-featured-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .35s ease;
}
.gs-featured-card:hover .gs-featured-card__media img { transform: scale(1.04); }
.gs-featured-card__body {
    padding: 24px 26px 14px;
    flex: 1;
}
.gs-featured-card__body h3 {
    margin: 0 0 12px;
    font-size: 1.12rem;
    font-weight: 700;
    color: var(--white);
    line-height: 1.35;
}
.gs-featured-card__body p {
    margin: 0;
    font-size: .89rem;
    line-height: 1.62;
    color: rgba(232,238,255,.78);
}
.gs-featured-card__tag {
    align-self: flex-start;
    margin: 18px 26px 20px;
    padding: 5px 16px;
    border: 1.5px solid #19d8f6;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #19d8f6;
}
.gs-featured-card__link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px 26px;
    border-top: 2px solid var(--lime);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--lime);
    text-decoration: none;
    transition: gap .2s, background .2s;
}
.gs-featured-card__link:hover {
    gap: 12px;
    background: rgba(132,230,32,.07);
}
.gs-featured-nav {
    display: flex;
    gap: 12px;
    margin-top: 30px;
}
.gs-featured-nav button {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1.5px solid rgba(255,255,255,.45);
    background: transparent;
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .2s, color .2s, border-color .2s;
}
.gs-featured-nav button:hover {
    background: var(--white);
    color: #14151c;
    border-color: var(--white);
}
@media (max-width: 1024px) {
    .gs-featured-card { flex-basis: calc((100% - 24px) / 2); }
}
@media (max-width: 680px) {
    .gs-featured-card { flex-basis: 86%; }
}

/* ==========================================================================
   DOWNLOAD PAGE — passos numerados + links de edições
   ========================================================================== */
.gs-dl-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.gs-dl-step {
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 20px;
}
.gs-dl-step__num {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(132,230,32,.18);
    color: #3f7d00;
    font-weight: 800;
    font-size: 1.05rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.gs-dl-step strong {
    display: block;
    font-size: .95rem;
    color: var(--dark);
    margin-bottom: 4px;
}
.gs-dl-step p {
    margin: 0;
    font-size: .85rem;
    color: var(--text-muted);
    line-height: 1.55;
}
.gs-dl-edition-links {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.gs-dl-edition-link {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    align-items: center;
    gap: 2px 12px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    padding: 16px 18px;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s;
}
.gs-dl-edition-link:hover {
    border-color: #84e620;
    box-shadow: 0 6px 20px rgba(10,20,60,.08);
}
.gs-dl-edition-link strong {
    color: var(--dark);
    font-size: .95rem;
}
.gs-dl-edition-link span {
    grid-column: 1;
    font-size: .82rem;
    color: var(--text-muted);
}
.gs-dl-edition-link svg {
    grid-row: 1 / span 2;
    grid-column: 2;
    color: #3f7d00;
}
@media (max-width: 860px) {
    .gs-dl-steps { grid-template-columns: 1fr; }
    .gs-dl-edition-links { grid-template-columns: 1fr; }
}

/* ==========================================================================
   DOWNLOAD TESTE (pós-formulário) — hero obrigado + cards de instaladores
   ========================================================================== */
.gs-dlt-hero__inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 26px 0 30px;
}
.gs-dlt-hero__title {
    margin: 0;
    font-size: clamp(1.9rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.12;
    color: var(--white);
}
.gs-dlt-hero__title span { color: var(--lime); }
.gs-dlt-hero__sub {
    margin: 0;
    font-size: 1rem;
    line-height: 1.65;
    color: rgba(232,238,255,.82);
}
.gs-dlt-hero__sub strong { color: var(--lime); }
.os-compat--center { justify-content: center; }
.gs-dlt-body {
    background: #f4f7fc;
    padding: 56px 0 70px;
}
.gs-dlt-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.gs-dlt-grid--half { grid-template-columns: repeat(3, 1fr); }
.gs-dlt-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 14px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 22px;
    transition: box-shadow .2s, transform .2s, border-color .2s;
}
.gs-dlt-card:hover {
    box-shadow: 0 10px 30px rgba(10,20,60,.1);
    transform: translateY(-3px);
}
.gs-dlt-card--featured {
    background: #0a1228;
    border-color: var(--lime);
    box-shadow: 0 8px 28px rgba(132,230,32,.14);
}
.gs-dlt-card--featured .gs-dlt-card__title { color: var(--white); }
.gs-dlt-card__badge {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 4px 12px;
    border-radius: 999px;
    background: var(--lime);
    color: #11240a;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.gs-dlt-card__badge--os {
    background: #2e5ace;
    color: #fff;
}
.gs-dlt-card__title {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--dark);
}
.gs-dlt-card__meta {
    list-style: none;
    margin: 0;
    padding: 12px 0 0;
    border-top: 1px dashed rgba(10,20,60,.14);
    display: flex;
    flex-direction: column;
    gap: 7px;
    flex: 1;
}
.gs-dlt-card--featured .gs-dlt-card__meta { border-top-color: rgba(255,255,255,.16); }
.gs-dlt-card__meta li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: .85rem;
    color: var(--dark);
}
.gs-dlt-card--featured .gs-dlt-card__meta li { color: rgba(232,238,255,.92); }
.gs-dlt-card__meta li span {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--text-muted);
}
.gs-dlt-card__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 11px 16px;
    border-radius: 10px;
    background: var(--lime);
    color: #11240a;
    font-size: .9rem;
    font-weight: 700;
    text-decoration: none;
    transition: filter .15s, transform .15s;
}
.gs-dlt-card__btn:hover {
    filter: brightness(1.07);
    transform: translateY(-1px);
}
@media (max-width: 1024px) {
    .gs-dlt-grid, .gs-dlt-grid--half { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .gs-dlt-grid, .gs-dlt-grid--half { grid-template-columns: 1fr; }
}

/* ==========================================================================
   MEGA MENU — produto: título em negrito na 1ª linha, descrição menor abaixo
   (corrige .main-nav__list a { display:inline-block } vencendo o flex)
   ========================================================================== */
.main-nav__list a.mega-menu__product {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    padding: 0;
}
.main-nav__list a.mega-menu__product:hover {
    background: transparent;
}
.mega-menu__product strong {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: #ffffff;
    line-height: 1.3;
}
.main-nav__list a.mega-menu__product:hover strong {
    color: #19d8f6;
}
.mega-menu__product span {
    display: block;
    font-size: .8rem;
    font-weight: 400;
    color: rgba(232,238,255,.7);
    line-height: 1.5;
}

/* ==========================================================================
   BLOG — filtros de categoria reais + paginação
   ========================================================================== */
a.blog-page__filter { text-decoration: none; cursor: pointer; }
.blog-page__filter-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    margin-left: 6px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    font-size: .7rem;
    font-weight: 700;
}
.blog-page__filter.is-active .blog-page__filter-count {
    background: rgba(0,0,0,.18);
}
.blog-page__empty {
    text-align: center;
    padding: 60px 0;
    color: var(--text-muted);
    font-size: 1rem;
}
.blog-pagination {
    margin-top: 48px;
    display: flex;
    justify-content: center;
}
.blog-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    padding: 0 14px;
    margin: 0 3px;
    border-radius: 10px;
    border: 1px solid rgba(10,20,60,.15);
    background: var(--white);
    color: var(--dark);
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none;
    transition: border-color .15s, background .15s, color .15s;
}
.blog-pagination .page-numbers:hover {
    border-color: var(--primary, #2e5ace);
    color: var(--primary, #2e5ace);
}
.blog-pagination .page-numbers.current {
    background: var(--dark);
    border-color: var(--dark);
    color: var(--white);
}
.blog-pagination .page-numbers.dots {
    border: 0;
    background: transparent;
}
.blog-pagination .nav-links { display: flex; flex-wrap: wrap; justify-content: center; }

/* ==========================================================================
   GEO5 PAGE — botão verde + galeria de telas
   ========================================================================== */
.geo-btn--green {
    background: #4ade80 !important;
    border-color: #4ade80 !important;
    color: #06281a !important;
}
.geo-btn--green:hover {
    background: #6ce99a !important;
    border-color: #6ce99a !important;
    box-shadow: 0 6px 22px rgba(74,222,128,.35);
}
.geo-gallery-section {
    background: #f4f7fc;
    padding-top: 0;
}
.geo-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.geo-gallery__item {
    margin: 0;
    border-radius: 16px;
    overflow: hidden;
    background: var(--white);
    border: 1px solid #dde5f3;
    display: flex;
    flex-direction: column;
}
.geo-gallery__item--wide { grid-column: span 2; }
.geo-gallery__item img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    object-position: center top;
    transition: transform .35s ease;
}
.geo-gallery__item:hover img { transform: scale(1.03); }
.geo-gallery__item figcaption {
    padding: 12px 16px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-muted);
}
@media (max-width: 1024px) {
    .geo-gallery { grid-template-columns: 1fr 1fr; }
    .geo-gallery__item--wide { grid-column: span 2; }
}
@media (max-width: 640px) {
    .geo-gallery { grid-template-columns: 1fr; }
    .geo-gallery__item--wide { grid-column: span 1; }
}

/* ==========================================================================
   GEO5 HERO — variante verde do gs-hero
   ========================================================================== */
.geo-hero {
    background:
        radial-gradient(ellipse 65% 60% at 105% -5%, rgba(45,138,78,.55) 0%, transparent 58%),
        radial-gradient(ellipse 50% 45% at -5% 105%, rgba(74,222,128,.12) 0%, transparent 55%),
        linear-gradient(170deg, #06140c 0%, #0a1f14 55%, #0c2a1a 100%);
}
.geo-hero__accent { color: #4ade80; }
.geo-perp-badge {
    background: rgba(74,222,128,.14) !important;
    border-color: rgba(74,222,128,.4) !important;
    color: #4ade80 !important;
}
.geo-hero__pill {
    border-color: rgba(74,222,128,.45) !important;
    color: #b9f6cf !important;
}
.geo-hero__pill .gs-hero__pill-dot { background: #4ade80; }

/* ==========================================================================
   GEO5 — régua de pacotes de soluções (tiles verdes com ícones)
   ========================================================================== */
.geo-pacotes-section { padding-bottom: 40px; }
.geo-pacotes {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    gap: 10px;
}
.geo-pacote {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    padding: 22px 10px 18px;
    background: #1e7e34;
    border-radius: 12px;
    text-decoration: none;
    text-align: center;
    transition: background .15s, transform .15s, box-shadow .15s;
}
.geo-pacote:hover {
    background: #2d9a47;
    transform: translateY(-4px);
    box-shadow: 0 10px 26px rgba(30,126,52,.35);
}
.geo-pacote__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 56px;
}
.geo-pacote__icon svg {
    width: 52px;
    height: 52px;
    fill: #ffffff;
}
.geo-pacote__icon svg * { fill: #ffffff !important; stroke: none; }
.geo-pacote__label {
    font-size: .8rem;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.35;
}
.geo-pacotes__note {
    margin-top: 26px;
    text-align: center;
    font-size: .92rem;
    color: var(--text-muted);
}
.geo-pacotes__note a {
    font-weight: 700;
    color: #1e7e34;
    text-decoration: underline;
}
@media (max-width: 1100px) {
    .geo-pacotes { grid-template-columns: repeat(5, 1fr); }
}
@media (max-width: 760px) {
    .geo-pacotes { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .geo-pacotes { grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================================================
   GEO5 — catálogo de programas (/programas-geo5/)
   ========================================================================== */
.geo-hero--compact { padding: 4rem 0 3.5rem; }
.geo-prog-body {
    background: #f4f7fc;
    padding: 48px 0 70px;
}
.geo-prog-search {
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 560px;
    margin: 0 auto 42px;
    padding: 0 18px;
    background: var(--white);
    border: 1.5px solid #d4ddee;
    border-radius: 999px;
    color: var(--text-muted);
    transition: border-color .15s, box-shadow .15s;
}
.geo-prog-search:focus-within {
    border-color: #1e7e34;
    box-shadow: 0 0 0 4px rgba(30,126,52,.12);
}
.geo-prog-search input {
    flex: 1;
    border: 0;
    outline: none;
    background: transparent;
    padding: 14px 0;
    font-size: .95rem;
    color: var(--dark);
}
.geo-prog-groups {
    display: flex;
    flex-direction: column;
    gap: 22px;
}
.geo-prog-group {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 26px 28px;
}
.geo-prog-group__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
.geo-prog-group__title {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}
.geo-prog-group__icon {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: rgba(30,126,52,.12);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}
.geo-prog-group__title h2 {
    margin: 0 0 4px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.geo-prog-group__title p {
    margin: 0;
    font-size: .87rem;
    color: var(--text-muted);
}
.geo-prog-group__links {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-end;
}
.geo-prog-group__links a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .84rem;
    font-weight: 700;
    color: #1e7e34;
    text-decoration: none;
}
.geo-prog-group__links a:hover { text-decoration: underline; }
.geo-prog-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    border-top: 1px dashed rgba(10,20,60,.13);
    padding-top: 16px;
}
.geo-prog-item {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 14px;
    background: #f0f6f1;
    border: 1px solid rgba(30,126,52,.22);
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 600;
    color: #14441f;
}
.geo-prog-item svg { color: #1e7e34; }
.geo-prog-empty {
    text-align: center;
    color: var(--text-muted);
    padding: 30px 0;
}
@media (max-width: 760px) {
    .geo-prog-group__links { align-items: flex-start; }
}

/* ==========================================================================
   GEO5 — cards de soluções (formato Fine) + faixa "economiza seu tempo"
   ========================================================================== */
.geo-sol-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.geo-sol-card {
    display: flex;
    flex-direction: column;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 24px;
    transition: box-shadow .2s, transform .2s, border-color .2s;
}
.geo-sol-card:hover {
    border-color: rgba(30,126,52,.45);
    box-shadow: 0 10px 30px rgba(10,40,20,.1);
    transform: translateY(-3px);
}
.geo-sol-card__icon {
    width: 64px;
    height: 64px;
    border-radius: 14px;
    background: #1e7e34;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}
.geo-sol-card__icon svg {
    width: 42px;
    height: 42px;
}
.geo-sol-card__icon svg * { fill: #ffffff !important; stroke: none; }
.geo-sol-card__title {
    margin: 0 0 6px;
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--dark);
}
.geo-sol-card__desc {
    margin: 0 0 14px;
    font-size: .87rem;
    color: var(--text-muted);
    line-height: 1.55;
}
.geo-sol-card .geo-prog-list {
    border-top: 1px dashed rgba(10,20,60,.13);
    padding-top: 14px;
    margin-bottom: 16px;
    flex: 1;
}
.geo-sol-card__link {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: .86rem;
    font-weight: 700;
    color: #1e7e34;
    text-decoration: none;
    transition: gap .2s;
}
.geo-sol-card__link:hover { gap: 11px; text-decoration: underline; }
.geo-econ-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.geo-econ-card {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 14px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.geo-econ-card__icon { font-size: 1.5rem; }
.geo-econ-card strong {
    color: var(--white);
    font-size: .95rem;
}
.geo-econ-card p {
    margin: 0;
    font-size: .83rem;
    line-height: 1.55;
    color: rgba(232,238,255,.72);
}
@media (max-width: 1024px) {
    .geo-sol-grid { grid-template-columns: 1fr 1fr; }
    .geo-econ-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .geo-sol-grid { grid-template-columns: 1fr; }
    .geo-econ-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   GEO5 — cards de soluções com imagem da página de destino
   ========================================================================== */
.geo-sol-card { padding: 0; overflow: hidden; }
.geo-sol-card__media {
    position: relative;
    display: block;
    height: 175px;
    background: #eef3f8;
    overflow: hidden;
}
.geo-sol-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .35s ease;
}
.geo-sol-card:hover .geo-sol-card__media img { transform: scale(1.04); }
.geo-sol-card__media .geo-sol-card__icon {
    position: absolute;
    left: 16px;
    bottom: -18px;
    width: 54px;
    height: 54px;
    margin: 0;
    border-radius: 12px;
    box-shadow: 0 6px 18px rgba(10,40,20,.3);
    z-index: 2;
}
.geo-sol-card__media .geo-sol-card__icon svg {
    width: 34px;
    height: 34px;
}
.geo-sol-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 30px 24px 22px;
}

/* ==========================================================================
   GEO5 — página de solução (seções zigue-zague + relacionados)
   ========================================================================== */
.geo-breadcrumb { margin-bottom: 18px; }
.geo-sol-detail-body {
    background: #f4f7fc;
    padding: 64px 0 56px;
}
.geo-sol-detail {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 48px;
    align-items: center;
    padding: 28px 0;
}
.geo-sol-detail--invert .geo-sol-detail__copy  { order: 2; }
.geo-sol-detail--invert .geo-sol-detail__media { order: 1; }
.geo-sol-detail__copy h2 {
    margin: 8px 0 14px;
    font-size: clamp(1.3rem, 2.4vw, 1.7rem);
    font-weight: 800;
    color: var(--dark);
    line-height: 1.25;
}
.geo-sol-detail__copy p {
    margin: 0;
    font-size: .95rem;
    line-height: 1.7;
    color: var(--text-muted);
}
.geo-sol-detail__copy strong { color: #14441f; }
.geo-sol-detail__media {
    margin: 0;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #dde5f3;
    background: var(--white);
    box-shadow: 0 10px 32px rgba(10,20,60,.1);
}
.geo-sol-detail__media img {
    width: 100%;
    display: block;
}
.geo-sol-related {
    margin-top: 36px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 28px;
}
.geo-sol-related h2 {
    margin: 0 0 6px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.geo-sol-related > p {
    margin: 0 0 16px;
    font-size: .88rem;
    color: var(--text-muted);
}
.geo-sol-related .geo-prog-list {
    border-top: 1px dashed rgba(10,20,60,.13);
    padding-top: 16px;
    margin-bottom: 18px;
}
.geo-pacote--atual {
    outline: 3px solid #84e620;
    outline-offset: 2px;
}
@media (max-width: 860px) {
    .geo-sol-detail { grid-template-columns: 1fr; gap: 20px; }
    .geo-sol-detail--invert .geo-sol-detail__copy  { order: 1; }
    .geo-sol-detail--invert .geo-sol-detail__media { order: 2; }
}

/* ==========================================================================
   GEO5 — chips de programa linkados com ícone oficial
   ========================================================================== */
a.geo-prog-item--link {
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
a.geo-prog-item--link:hover {
    border-color: #1e7e34;
    box-shadow: 0 4px 12px rgba(30,126,52,.2);
    transform: translateY(-1px);
}
.geo-prog-item img {
    width: 22px;
    height: 22px;
    border-radius: 5px;
    flex-shrink: 0;
}

/* ==========================================================================
   GEO5 — fix: chips não devem esticar na vertical (viravam círculos)
   ========================================================================== */
.geo-prog-list {
    align-items: flex-start;
    align-content: flex-start;
}
.geo-prog-item {
    align-self: flex-start;
    line-height: 1.3;
}
.geo-sol-card__body .geo-prog-list { flex: 1; }

/* ==========================================================================
   GEO5 — página de programa
   ========================================================================== */
.geo-programa-titulo {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 6px 0 2px;
}
.geo-programa-titulo__icone {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    background: #ffffff;
    padding: 6px;
    box-shadow: 0 6px 18px rgba(0,0,0,.3);
    flex-shrink: 0;
}
.geo-programa-titulo h1 { margin: 0; }
.geo-programa-feats {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 28px;
    margin-bottom: 36px;
}
.geo-programa-feats h2 {
    margin: 0 0 16px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.geo-programa-feats__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 26px;
}
.geo-programa-feats__list li {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: .9rem;
    line-height: 1.55;
    color: var(--dark);
}
.geo-programa-feats__list svg {
    color: #1e7e34;
    flex-shrink: 0;
    margin-top: 3px;
}
.geo-programa-galeria h2 {
    margin: 0 0 18px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
@media (max-width: 760px) {
    .geo-programa-feats__list { grid-template-columns: 1fr; }
}

/* ==========================================================================
   GEO5 — breadcrumb mais visível + relatório de exemplo + novidades
   ========================================================================== */
.geo-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font-size: .88rem;
}
.geo-breadcrumb a {
    color: rgba(232,238,255,.85);
    font-weight: 600;
    text-decoration: none;
    padding: 2px 4px;
    border-radius: 6px;
}
.geo-breadcrumb a:hover {
    color: #4ade80;
    background: rgba(74,222,128,.1);
}
.geo-breadcrumb svg { color: rgba(232,238,255,.4); }
.geo-breadcrumb__atual {
    color: #4ade80;
    font-weight: 700;
}
.geo-programa-report {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 40px;
    align-items: center;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 28px;
    margin-top: 36px;
}
.geo-programa-report__media {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #dde5f3;
}
.geo-programa-report__media img { width: 100%; display: block; }
.geo-programa-report__copy h2 {
    margin: 0 0 14px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.geo-programa-report__copy h3 {
    margin: 0 0 10px;
    font-size: .95rem;
    font-weight: 700;
    color: #1e7e34;
}
.geo-programa-report__copy ul {
    margin: 0;
    padding: 0 0 0 18px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    font-size: .9rem;
    color: var(--text-muted);
    line-height: 1.5;
}
.geo-programa-novidades {
    margin-top: 36px;
    background: #0a1f14;
    border-radius: 18px;
    padding: 28px;
    color: #fff;
}
.geo-programa-novidades h2 {
    margin: 0 0 14px;
    font-size: 1.15rem;
    font-weight: 800;
    color: #4ade80;
}
.geo-programa-novidades ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
}
.geo-programa-novidades li {
    background: rgba(74,222,128,.12);
    border: 1px solid rgba(74,222,128,.3);
    border-radius: 999px;
    padding: 7px 16px;
    font-size: .85rem;
    font-weight: 600;
}
.geo-econ-grid--5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1100px) {
    .geo-econ-grid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 860px) {
    .geo-programa-report { grid-template-columns: 1fr; gap: 20px; }
    .geo-econ-grid--5 { grid-template-columns: 1fr 1fr; }
}

/* ==========================================================================
   PRODUTOS — template genérico com cor de destaque por produto
   ========================================================================== */
.prod-hero {
    background:
        radial-gradient(ellipse 65% 60% at 105% -5%, color-mix(in srgb, var(--prod-accent, #2e5ace) 45%, transparent) 0%, transparent 58%),
        linear-gradient(170deg, #060b1c 0%, #0a1228 55%, #0d1530 100%);
}
.prod-accent { color: var(--prod-accent, #84e620); filter: brightness(1.35) saturate(1.1); }
.prod-badge {
    background: color-mix(in srgb, var(--prod-accent, #84e620) 16%, transparent) !important;
    border-color: color-mix(in srgb, var(--prod-accent, #84e620) 45%, transparent) !important;
    color: color-mix(in srgb, var(--prod-accent, #84e620) 60%, #ffffff) !important;
}
.prod-pill {
    border-color: color-mix(in srgb, var(--prod-accent, #84e620) 50%, transparent) !important;
    color: #ffffff !important;
}
.btn.prod-btn {
    background: var(--prod-accent, #84e620) !important;
    border-color: var(--prod-accent, #84e620) !important;
    color: #ffffff !important;
}
.btn.prod-btn:hover {
    filter: brightness(1.15);
    box-shadow: 0 6px 22px color-mix(in srgb, var(--prod-accent, #84e620) 40%, transparent);
}
.prod-detail strong { color: var(--prod-accent, #1e7e34); filter: brightness(.85); }
.prod-eyebrow { color: var(--text-muted) !important; border-bottom-color: var(--prod-accent, #e03e7e) !important; }
.prod-feats {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 28px;
    margin-bottom: 36px;
}
.prod-feats h2 {
    margin: 0 0 18px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}

/* Seções de detalhe sem imagem ocupam coluna única centrada */
.geo-sol-detail:not(:has(.geo-sol-detail__media)) {
    grid-template-columns: 1fr;
    max-width: 820px;
}

/* ==========================================================================
   QUEM SOMOS — fotos do time, números, missão/visão, escritórios
   ========================================================================== */
.qs-fotos {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    align-items: start;
}
.qs-fotos__item {
    margin: 0;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.15);
    box-shadow: 0 14px 34px rgba(0,0,0,.35);
}
.qs-fotos__item img {
    width: 100%;
    height: 230px;
    object-fit: cover;
    display: block;
}
.qs-fotos__item--2, .qs-fotos__item--4 { margin-top: 26px; }
.qs-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 36px;
}
.qs-stat {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    text-align: center;
}
.qs-stat__num {
    font-size: 2rem;
    font-weight: 800;
    color: #2e5ace;
    line-height: 1;
}
.qs-stat__label {
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-muted);
}
.qs-mv {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-bottom: 36px;
}
.qs-mv__card {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 28px;
}
.qs-mv__card h2 {
    margin: 8px 0 12px;
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--dark);
}
.qs-mv__card p:last-child {
    margin: 0;
    font-size: .92rem;
    line-height: 1.7;
    color: var(--text-muted);
}
.qs-valores { margin-bottom: 36px; }
.qs-escritorios__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    border-top: 1px dashed rgba(10,20,60,.13);
    padding-top: 16px;
}
.qs-escritorio {
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: #f4f7fc;
    border-radius: 14px;
    padding: 18px;
}
.qs-escritorio strong { color: var(--dark); font-size: .95rem; }
.qs-escritorio span { color: var(--text-muted); font-size: .85rem; }
.qs-escritorio a { color: #1e7e34; font-weight: 700; font-size: .9rem; text-decoration: none; }
.qs-escritorio a:hover { text-decoration: underline; }
.qs-page .gs-clients-logos { border-top: 0; margin-top: 8px; }
@media (max-width: 1024px) {
    .qs-stats { grid-template-columns: 1fr 1fr; }
    .qs-mv { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
    .qs-fotos { grid-template-columns: 1fr 1fr; }
    .qs-escritorios__grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   CONTATO — formulário + canais + atalhos + mapa
   ========================================================================== */
.ct-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 18px;
    margin-bottom: 36px;
    align-items: start;
}
.ct-form h2 { margin-top: 0; }
.ct-canais {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.ct-canal {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    padding: 16px 18px;
}
.ct-canal__icon { font-size: 1.3rem; }
.ct-canal div { display: flex; flex-direction: column; gap: 2px; }
.ct-canal strong { color: var(--dark); font-size: .95rem; }
.ct-canal span { color: var(--text-muted); font-size: .83rem; }
.ct-canal a { color: #1e7e34; font-weight: 700; font-size: .9rem; text-decoration: none; }
.ct-canal a:hover { text-decoration: underline; }
.ct-atalhos { margin-bottom: 36px; }
.ct-atalhos h2 {
    margin: 0 0 16px;
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--dark);
}
.ct-atalhos__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.ct-atalho {
    display: flex;
    flex-direction: column;
    gap: 8px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 20px;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.ct-atalho:hover {
    border-color: #1e7e34;
    box-shadow: 0 8px 24px rgba(10,40,20,.1);
    transform: translateY(-2px);
}
.ct-atalho__icon { font-size: 1.5rem; }
.ct-atalho strong { color: var(--dark); font-size: .98rem; }
.ct-atalho p { margin: 0; color: var(--text-muted); font-size: .85rem; line-height: 1.5; flex: 1; }
.ct-mapa__frame {
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #dde5f3;
    margin-top: 14px;
}
@media (max-width: 1024px) {
    .ct-grid { grid-template-columns: 1fr; }
    .ct-atalhos__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .ct-atalhos__grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   HOME — fixes: título da seção Nossa Empresa invisível (branco s/ branco)
   e imagens nos painéis de indústrias
   ========================================================================== */
.hs-about__copy h2 { color: var(--dark); }
.hs-about__copy .eyebrow { border-bottom-color: var(--pink); }
.tabs__panel-image {
    border-radius: 14px;
    overflow: hidden;
    background: #0e1626;
}
.tabs__panel-image img {
    width: 100%;
    height: 100%;
    min-height: 220px;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* ==========================================================================
   Página "Fui notificado pela Autodesk" — esconde o menu antigo embutido
   no conteúdo (usa agora o header do tema) — conteúdo intacto
   ========================================================================== */
.page-id-992070 #header,
.page-id-992070 header#header {
    display: none !important;
}

/* ==========================================================================
   HOME — faixa de alerta Autodesk
   ========================================================================== */
.home-autodesk {
    background:
        radial-gradient(ellipse 60% 120% at 90% 50%, rgba(245,158,11,.22) 0%, transparent 60%),
        linear-gradient(135deg, #1c1205 0%, #2a1a06 60%, #331f06 100%);
    border-top: 1px solid rgba(245,158,11,.25);
    border-bottom: 1px solid rgba(245,158,11,.25);
    padding: 34px 0;
}
.home-autodesk__inner {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
}
.home-autodesk__icon {
    width: 62px;
    height: 62px;
    border-radius: 16px;
    background: rgba(245,158,11,.15);
    border: 1.5px solid rgba(245,158,11,.4);
    color: #fbbf24;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.home-autodesk__copy { flex: 1; min-width: 280px; }
.home-autodesk__copy h2 {
    margin: 0 0 6px;
    font-size: clamp(1.15rem, 2.2vw, 1.5rem);
    font-weight: 800;
    color: #ffffff;
}
.home-autodesk__copy p {
    margin: 0;
    font-size: .92rem;
    line-height: 1.6;
    color: rgba(255,243,219,.85);
}
.home-autodesk__copy strong { color: #fbbf24; }
.btn.home-autodesk__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #f59e0b;
    border-color: #f59e0b;
    color: #1c1205;
    font-weight: 800;
    white-space: nowrap;
}
.btn.home-autodesk__btn:hover {
    background: #fbbf24;
    border-color: #fbbf24;
    box-shadow: 0 6px 24px rgba(245,158,11,.4);
}
@media (max-width: 760px) {
    .home-autodesk__inner { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   SEJA UM REVENDEDOR — níveis de parceria, vagas e revenda atual
   ========================================================================== */
.rv-niveis { margin-bottom: 40px; }
.rv-niveis__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 22px;
}
.rv-nivel {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-top: 5px solid var(--nivel-cor, #2e5ace);
    border-radius: 18px;
    padding: 26px;
    transition: box-shadow .2s, transform .2s;
}
.rv-nivel:hover {
    box-shadow: 0 12px 32px rgba(10,20,60,.12);
    transform: translateY(-3px);
}
.rv-nivel--destaque {
    box-shadow: 0 0 0 2px var(--nivel-cor), 0 10px 32px rgba(245,158,11,.18);
}
.rv-nivel__badge {
    align-self: flex-start;
    padding: 4px 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--nivel-cor) 14%, transparent);
    color: var(--nivel-cor);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.rv-nivel__nome {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--dark);
}
.rv-nivel__desc {
    margin: 0;
    flex: 1;
    font-size: .9rem;
    line-height: 1.6;
    color: var(--text-muted);
}
.rv-nivel__link { color: var(--nivel-cor) !important; }
.rv-comum {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 26px;
}
.rv-comum h3 {
    margin: 0 0 16px;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--dark);
}
.rv-vagas { margin-bottom: 40px; }
.rv-vagas__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
.rv-vaga {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #0a1228;
    border: 1px solid rgba(132,230,32,.3);
    border-radius: 16px;
    padding: 20px;
    text-decoration: none;
    transition: border-color .15s, transform .15s, box-shadow .15s;
}
.rv-vaga:hover {
    border-color: var(--lime);
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(132,230,32,.15);
}
.rv-vaga__pin {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(132,230,32,.14);
    color: var(--lime);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.rv-vaga div { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.rv-vaga strong { color: #ffffff; font-size: 1rem; }
.rv-vaga div span { color: rgba(232,238,255,.6); font-size: .8rem; }
.rv-vaga__cta { color: var(--lime); font-weight: 700; font-size: .85rem; white-space: nowrap; }
.rv-atual__card {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.rv-atual__eyebrow {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: #2e5ace;
}
.rv-atual__logo {
    max-width: 200px;
    height: auto;
    border-radius: 10px;
}
.rv-atual__info { display: flex; flex-direction: column; gap: 4px; }
.rv-atual__info h3 {
    margin: 10px 0 2px;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-muted);
}
.rv-atual__info a { color: #1e7e34; font-weight: 700; text-decoration: none; font-size: .92rem; }
.rv-atual__info a:hover { text-decoration: underline; }
.rv-atual__info span { color: var(--text-muted); font-size: .88rem; line-height: 1.5; }
@media (max-width: 1024px) {
    .rv-niveis__grid, .rv-vagas__grid { grid-template-columns: 1fr; }
}

/* Formulários embedados — moldura limpa, sem barra de rolagem */
.ct-form iframe {
    display: block;
    border-radius: 12px;
    background: #ffffff;
    border: 1px solid #e8edf6 !important;
    overflow: hidden;
}

/* ==========================================================================
   TRABALHE CONOSCO — vagas (CPT) + estado vazio
   ========================================================================== */
.tc-vagas { margin-bottom: 36px; }
.tc-vagas__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}
.tc-vaga {
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 24px;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.tc-vaga:hover {
    border-color: #1e7e34;
    box-shadow: 0 10px 28px rgba(10,40,20,.1);
    transform: translateY(-2px);
}
.tc-vaga__area {
    align-self: flex-start;
    padding: 4px 12px;
    border-radius: 999px;
    background: rgba(46,90,206,.1);
    color: #2e5ace;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.tc-vaga h3 {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.tc-vaga p {
    margin: 0;
    color: var(--text-muted);
    font-size: .9rem;
    line-height: 1.6;
    flex: 1;
}
.tc-vaga__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    font-size: .84rem;
    color: var(--text-muted);
    font-weight: 600;
}
.tc-vaga__meta--hero {
    color: rgba(232,238,255,.85);
    margin: 6px 0 14px;
}
.tc-vazio {
    text-align: center;
    background: var(--white);
    border: 1px dashed #c4d0e6;
    border-radius: 18px;
    padding: 48px 24px;
}
.tc-vazio__icon { font-size: 2rem; }
.tc-vazio h3 {
    margin: 12px 0 8px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--dark);
}
.tc-vazio p {
    margin: 0 auto;
    max-width: 520px;
    color: var(--text-muted);
    font-size: .92rem;
    line-height: 1.65;
}
.tc-cultura { margin-bottom: 36px; }
.tc-descricao { margin-bottom: 24px; }
.tc-descricao .entry-content { color: var(--dark); line-height: 1.75; }
.tc-descricao .entry-content ul { padding-left: 22px; }
@media (max-width: 860px) {
    .tc-vagas__grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   SABER PREÇO — resumo de softwares + formulário de cotação
   ========================================================================== */
.sp-softwares__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
.sp-soft {
    display: flex;
    flex-direction: column;
    gap: 8px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 20px;
    transition: border-color .15s, box-shadow .15s;
}
.sp-soft:hover {
    border-color: #1e7e34;
    box-shadow: 0 8px 24px rgba(10,40,20,.08);
}
.sp-soft strong { color: var(--dark); font-size: 1rem; }
.sp-soft p { margin: 0; flex: 1; color: var(--text-muted); font-size: .86rem; line-height: 1.55; }
.sp-soft__acoes { display: flex; justify-content: space-between; gap: 10px; }
.sp-soft__acoes a {
    font-size: .85rem;
    font-weight: 700;
    text-decoration: none;
    color: var(--text-muted);
}
.sp-soft__acoes a.sp-soft__cotar { color: #1e7e34; }
.sp-soft__acoes a:hover { text-decoration: underline; }
.sp-page textarea.gs-form-input { resize: vertical; min-height: 80px; }
@media (max-width: 1024px) { .sp-softwares__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .sp-softwares__grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   SABER PREÇO — mosaico de logos dos softwares no banner
   ========================================================================== */
.sp-logos {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    max-width: 460px;
    margin-left: auto;
}
.sp-logos__tile {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 96px;
    background: #ffffff;
    border-radius: 16px;
    padding: 16px;
    box-shadow: 0 14px 34px rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.16);
    transition: transform .25s ease;
}
.sp-logos__tile:hover { transform: translateY(-4px) scale(1.03); }
.sp-logos__tile img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.sp-logos__tile--2, .sp-logos__tile--4, .sp-logos__tile--6, .sp-logos__tile--8 { margin-top: 18px; }
.sp-logos__tile--mais {
    background: rgba(132,230,32,.14);
    border: 1.5px solid rgba(132,230,32,.5);
    color: var(--lime);
    font-weight: 800;
    font-size: 1.3rem;
    line-height: 1.1;
    text-align: center;
    flex-direction: column;
}
.sp-logos__tile--mais small {
    font-size: .68rem;
    font-weight: 600;
    color: rgba(232,238,255,.8);
    text-transform: uppercase;
    letter-spacing: .05em;
}
@media (max-width: 1024px) {
    .sp-logos { margin: 24px auto 0; }
}

/* Mosaico de logos — tile final com texto curto (variante revenda) */
.sp-logos__tile--mais { font-size: 1.05rem; }

/* ==========================================================================
   EVENTOS — cards de agenda e retrospectiva
   ========================================================================== */
.ev-bloco { margin-bottom: 40px; }
.ev-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.ev-grid--2 { grid-template-columns: 1fr 1fr; }
.ev-card {
    display: flex;
    flex-direction: column;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    overflow: hidden;
    transition: box-shadow .2s, transform .2s;
}
.ev-card:hover {
    box-shadow: 0 12px 32px rgba(10,20,60,.12);
    transform: translateY(-3px);
}
.ev-card__media {
    position: relative;
    height: 190px;
    background: #0e1626;
    overflow: hidden;
}
.ev-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform .35s ease;
}
.ev-card:hover .ev-card__media img { transform: scale(1.04); }
.ev-card__selo {
    position: absolute;
    top: 14px;
    right: 14px;
    padding: 5px 14px;
    border-radius: 999px;
    background: var(--lime);
    color: #11240a;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
    box-shadow: 0 4px 14px rgba(0,0,0,.3);
}
.ev-card__body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 20px 22px 22px;
    flex: 1;
}
.ev-card__quando {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 16px;
    font-size: .82rem;
    font-weight: 700;
    color: #2e5ace;
}
.ev-card h3 {
    margin: 0;
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--dark);
}
.ev-card p {
    margin: 0;
    font-size: .88rem;
    line-height: 1.6;
    color: var(--text-muted);
}
.ev-card--passado .ev-card__media img { filter: saturate(.85); }
@media (max-width: 1024px) {
    .ev-grid { grid-template-columns: 1fr; }
    .ev-grid--2 { grid-template-columns: 1fr; }
}

/* ==========================================================================
   PÁGINAS DE SERVIÇO (Implementação BIM, Projeto Geotécnico, Modelagem 3D)
   ========================================================================== */
.srv-bloco { margin-bottom: 48px; }
.sp-logos__tile svg { max-width: 100%; max-height: 100%; }
.srv-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    counter-reset: srv;
}
.srv-step {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 20px 22px;
}
.srv-step__num {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--srv-accent, #2e5ace) 12%, white);
    color: var(--srv-accent, #2e5ace);
    font-weight: 800;
    font-size: 1.05rem;
}
.srv-step strong { display: block; color: var(--dark); margin-bottom: 4px; }
.srv-step p { margin: 0; font-size: .88rem; line-height: 1.6; color: var(--text-muted); }
.sp-softwares__grid--4 { grid-template-columns: repeat(4, 1fr); }
.srv-formato {
    display: inline-block;
    align-self: flex-start;
    padding: 3px 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--srv-accent, #2e5ace) 10%, white);
    color: var(--srv-accent, #2e5ace);
    font-size: .72rem;
    font-weight: 700;
}
@media (max-width: 1024px) {
    .srv-steps { grid-template-columns: 1fr; }
    .sp-softwares__grid--4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .sp-softwares__grid--4 { grid-template-columns: 1fr; }
}

/* ==========================================================================
   REQUISITOS DO SISTEMA — seletor de softwares + tabelas mín/recomendado
   ========================================================================== */
.req-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
}
.req-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px 10px 12px;
    background: var(--white);
    border: 1.5px solid #dde5f3;
    border-radius: 999px;
    cursor: pointer;
    font: inherit;
    font-size: .9rem;
    font-weight: 700;
    color: var(--dark);
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.req-chip:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(10,20,60,.1); }
.req-chip.is-active {
    border-color: var(--req-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--req-accent) 18%, transparent);
}
.req-chip img {
    width: 30px;
    height: 30px;
    object-fit: contain;
}
.req-chip__sigla {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--req-accent) 14%, white);
    color: var(--req-accent);
    font-size: .78rem;
    font-weight: 800;
}
.req-panel { display: none; margin-bottom: 36px; }
.req-panel.is-active { display: block; }
.req-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
.req-panel__head h2 {
    margin: 0;
    padding-left: 14px;
    border-left: 5px solid var(--req-accent);
}
.req-table {
    border: 1px solid #dde5f3;
    border-radius: 16px;
    overflow: hidden;
    background: var(--white);
}
.req-table__row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 12px;
    padding: 14px 20px;
    border-top: 1px solid #edf1f9;
    font-size: .9rem;
    color: var(--text-muted);
}
.req-table__row:first-child { border-top: none; }
.req-table__row--head {
    background: color-mix(in srgb, var(--req-accent) 7%, white);
    font-weight: 800;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--req-accent);
}
.req-table__item { font-weight: 700; color: var(--dark); }
.req-notas {
    margin: 14px 0 0;
    padding: 0 0 0 4px;
    list-style: none;
    font-size: .85rem;
    color: var(--text-muted);
}
.req-notas li { padding-left: 20px; position: relative; margin-bottom: 6px; }
.req-notas li::before { content: "ℹ️"; position: absolute; left: 0; font-size: .8rem; }
.req-plugins { margin-bottom: 28px; }
@media (max-width: 760px) {
    .req-table__row { grid-template-columns: 1fr; gap: 4px; padding: 12px 16px; }
    .req-table__row--head { display: none; }
    .req-table__row [data-col]::before { content: attr(data-col) ": "; font-weight: 700; color: var(--dark); }
    .req-chip__nome { font-size: .82rem; }
}

/* Ferramentas — cards com botão de download */
.fer-card__btn { align-self: flex-start; margin-top: 4px; display: inline-flex; align-items: center; gap: 8px; }
.fer-card__extra { font-size: .78rem !important; color: #8a93a8 !important; font-style: italic; }

/* ==========================================================================
   FAQ / BASE DE CONHECIMENTO
   ========================================================================== */
.faq-busca {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    max-width: 560px;
    margin-top: 8px;
    padding: 4px 4px 4px 18px;
    background: #ffffff;
    border-radius: 999px;
    box-shadow: 0 14px 34px rgba(0,0,0,.3);
    color: #5a6478;
}
.faq-busca input {
    flex: 1;
    border: none;
    outline: none;
    font: inherit;
    font-size: .95rem;
    padding: 12px 8px;
    background: transparent;
    color: var(--dark);
}
.faq-resultados {
    max-width: 560px;
    margin-top: 10px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 18px 44px rgba(0,0,0,.35);
    overflow: hidden;
}
.faq-resultados a {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px 18px;
    text-decoration: none;
    border-top: 1px solid #eef1f7;
}
.faq-resultados a:first-child { border-top: none; }
.faq-resultados a:hover { background: #f4f7ff; }
.faq-resultados a strong { color: var(--dark); font-size: .92rem; }
.faq-resultados a span { color: #8a93a8; font-size: .76rem; }
.faq-resultados__vazio { margin: 0; padding: 14px 18px; font-size: .88rem; color: var(--text-muted); }
.faq-cats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.faq-cat {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    background: var(--white);
    border: 1.5px solid #dde5f3;
    border-radius: 16px;
    text-decoration: none;
    color: var(--text-muted);
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.faq-cat:hover {
    transform: translateY(-2px);
    border-color: var(--req-accent);
    box-shadow: 0 8px 22px rgba(10,20,60,.1);
}
.faq-cat img { width: 38px; height: 38px; object-fit: contain; flex: 0 0 auto; }
.faq-cat > div { flex: 1; display: flex; flex-direction: column; }
.faq-cat strong { color: var(--dark); font-size: .95rem; }
.faq-cat span { font-size: .78rem; color: #8a93a8; }
.faq-cat svg { color: var(--req-accent); }
.faq-cats__nota { margin-top: 14px; font-size: .85rem; color: var(--text-muted); }
.faq-cat-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 28px;
    align-items: start;
}
.faq-artigos { display: flex; flex-direction: column; gap: 10px; }
.faq-artigo {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s;
}
.faq-artigo:hover { border-color: var(--req-accent); box-shadow: 0 6px 18px rgba(10,20,60,.08); }
.faq-artigo__icone { color: var(--req-accent); flex: 0 0 auto; }
.faq-artigo > div { flex: 1; }
.faq-artigo strong { display: block; color: var(--dark); font-size: .96rem; }
.faq-artigo p { margin: 4px 0 0; font-size: .84rem; color: var(--text-muted); }
.faq-artigo > svg { color: var(--req-accent); flex: 0 0 auto; }
.faq-lateral { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 90px; }
.faq-lateral__bloco {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 16px;
    padding: 20px 22px;
}
.faq-lateral__bloco h3 { margin: 0 0 10px; font-size: .95rem; color: var(--dark); }
.faq-lateral__bloco ul { list-style: none; margin: 0 0 12px; padding: 0; }
.faq-lateral__bloco li { padding: 6px 0; border-top: 1px solid #eef1f7; }
.faq-lateral__bloco li:first-child { border-top: none; }
.faq-lateral__bloco li a { text-decoration: none; color: var(--text-muted); font-size: .88rem; }
.faq-lateral__bloco li a:hover { color: var(--req-accent); }
.faq-lateral__bloco li small { color: #aab2c4; }
.doc-titulo { font-size: clamp(1.6rem, 3.2vw, 2.4rem) !important; }
.doc-meta { color: rgba(232,238,255,.75); font-size: .85rem; }
.doc-conteudo {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 18px;
    padding: 34px 38px;
    color: var(--text-muted);
    line-height: 1.75;
    overflow-wrap: break-word;
}
.doc-conteudo h2, .doc-conteudo h3, .doc-conteudo h4 { color: var(--dark); margin-top: 1.6em; }
.doc-conteudo img { max-width: 100%; height: auto; border-radius: 12px; }
.doc-conteudo iframe { max-width: 100%; border-radius: 12px; }
.doc-conteudo a { color: #2e5ace; }
.doc-conteudo li { margin-bottom: .4em; }
@media (max-width: 1024px) {
    .faq-cats { grid-template-columns: 1fr 1fr; }
    .faq-cat-grid { grid-template-columns: 1fr; }
    .faq-lateral { position: static; }
}
@media (max-width: 640px) {
    .faq-cats { grid-template-columns: 1fr; }
    .doc-conteudo { padding: 24px 20px; }
}

/* Contato comercial — grade de canais e mapas duplos */
.ctc-canais {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.ctc-canais .ct-canal { margin: 0; }
.ctc-mapas {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.ctc-mapas figure { margin: 0; }
.ctc-mapas figcaption { margin-top: 10px; font-size: .86rem; color: var(--text-muted); }
@media (max-width: 1024px) { .ctc-canais { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .ctc-canais, .ctc-mapas { grid-template-columns: 1fr; } }

/* ==========================================================================
   COMPARATIVO DE VERSÕES
   ========================================================================== */
.cmp-table {
    border: 1px solid #dde5f3;
    border-radius: 18px;
    overflow: hidden;
    background: var(--white);
}
.cmp-row {
    display: grid;
    grid-template-columns: 2.2fr 1fr 1fr 1fr;
    align-items: center;
    border-top: 1px solid #edf1f9;
}
.cmp-row:first-child { border-top: none; }
.cmp-row > span { padding: 13px 18px; text-align: center; font-size: .9rem; color: var(--text-muted); }
.cmp-row > span:first-child { text-align: left; }
.cmp-row--head {
    background: #0e1626;
}
.cmp-row--head > span {
    color: #ffffff;
    font-weight: 800;
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.cmp-row--grupo { background: #f4f7ff; }
.cmp-row--grupo > span:first-child {
    font-weight: 800;
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #2e5ace;
    padding-top: 10px;
    padding-bottom: 10px;
}
.cmp-recurso { font-weight: 600; color: var(--dark) !important; }
.cmp-nao { color: #c3cad9; font-weight: 700; }
.cmp-destaque-col { background: color-mix(in srgb, #84e620 7%, transparent); }
.cmp-row--head .cmp-destaque-col { background: rgba(132,230,32,.18); }
.cmp-row--cta > span { padding: 16px 12px; }
.cmp-card--destaque { border-color: #84c620; box-shadow: 0 0 0 3px rgba(132,198,32,.18); }
@media (max-width: 860px) {
    .cmp-row { grid-template-columns: 1.6fr 1fr 1fr 1fr; }
    .cmp-row > span { padding: 10px 8px; font-size: .8rem; }
}

/* Topbar — contato no lugar dos atalhos */
.site-header__utility-links--contact a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Home — botão "Solicitar orçamento" do card final: fundo branco, texto azul */
.hs-about__btn-orcamento {
    background: #ffffff;
    color: var(--blue-dark, #1a3ecf);
    border: 1px solid #ffffff;
}
.hs-about__btn-orcamento:hover {
    background: #f0f4ff;
    color: var(--blue-dark, #1a3ecf);
}

/* ==========================================================================
   FORMULÁRIO DE DOWNLOAD por software (seção #download)
   ========================================================================== */
.prod-download {
    padding: 56px 0;
    background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--prod-accent, #2e5ace) 6%, transparent));
}
.prod-download__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: center;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 22px;
    padding: 36px 40px;
    box-shadow: 0 18px 48px rgba(10,20,60,.08);
}
.prod-download__intro h2 { margin: 6px 0 12px; }
.prod-download__intro > p { color: var(--text-muted); margin: 0 0 18px; }
.prod-download__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.prod-download__list li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .92rem;
    font-weight: 600;
    color: var(--dark);
}
.prod-download__list svg { color: var(--prod-accent, #2e5ace); flex: 0 0 auto; }
.prod-download__form iframe {
    width: 100%;
    border-radius: 14px;
    background: #fff;
    min-height: 760px;
    display: block;
}
@media (max-width: 900px) {
    .prod-download__inner { grid-template-columns: 1fr; padding: 28px 24px; }
    .prod-download__form iframe { min-height: 900px; }
}
@media (max-width: 560px) {
    .prod-download { padding: 36px 0; }
    .prod-download__form iframe { min-height: 1000px; }
}

/* ==========================================================================
   FAIXA COPA DO MUNDO 2026 (delicada, topo do header)
   ========================================================================== */
.copa-band {
    background: #0c1322;
    border-bottom: 1px solid rgba(255,255,255,.06);
    position: relative;
    font-size: .8rem;
    color: rgba(232,238,255,.9);
}
/* hairline verde→amarelo→azul (bandeira, bem sutil) no topo */
.copa-band::before {
    content: "";
    display: block;
    height: 2px;
    background: linear-gradient(90deg, #1a9d4b 0 38%, #f2c200 38% 70%, #2356c9 70% 100%);
    opacity: .85;
}
.copa-band__inner {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 7px 0;
    flex-wrap: wrap;
}
.copa-band__brand {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-weight: 700;
    letter-spacing: .02em;
    color: #f2c200;
}
.copa-band__bola { font-size: .9rem; filter: grayscale(.1); }
.copa-band__flag {
    width: 16px; height: 11px; border-radius: 2px; display: inline-block;
    background: radial-gradient(circle at 50% 50%, #2356c9 0 22%, #f2c200 22% 23%, #1a9d4b 23% 100%);
    box-shadow: 0 0 0 1px rgba(255,255,255,.12);
}
.copa-band__next {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(232,238,255,.85);
}
.copa-band__next-label { opacity: .6; }
.copa-band__next strong { color: #fff; font-weight: 700; }
.copa-band__when {
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(242,194,0,.14);
    color: #f2c200;
    font-weight: 700;
    font-size: .74rem;
}
.copa-band__toggle {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: transparent;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 999px;
    color: rgba(232,238,255,.9);
    font: inherit;
    font-size: .76rem;
    font-weight: 600;
    padding: 4px 12px;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.copa-band__toggle:hover { border-color: #f2c200; color: #f2c200; }
.copa-band__toggle[aria-expanded="true"] .copa-band__chevron { transform: rotate(180deg); }
.copa-band__chevron { transition: transform .2s; }
.copa-band__close {
    background: transparent;
    border: none;
    color: rgba(232,238,255,.5);
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 2px;
}
.copa-band__close:hover { color: #fff; }
.copa-band__jogos { border-top: 1px solid rgba(255,255,255,.06); background: #0a0f1a; }
.copa-band__jogos-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 0;
}
.copa-jogo {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 9px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    min-width: 168px;
}
.copa-jogo--next { border-color: rgba(242,194,0,.55); background: rgba(242,194,0,.07); }
.copa-jogo--past { opacity: .5; }
.copa-jogo__data { font-size: .72rem; color: #f2c200; font-weight: 700; }
.copa-jogo__times { font-size: .9rem; color: #fff; font-weight: 700; }
.copa-jogo__fase { font-size: .72rem; color: rgba(232,238,255,.55); }
.copa-band.is-hidden { display: none; }
@media (max-width: 720px) {
    .copa-band__next { width: 100%; order: 3; }
    .copa-band__toggle { margin-left: 0; }
    .copa-jogo { flex: 1 1 140px; min-width: 0; }
}

/* Taça da Copa girando do lado do logo (só durante o torneio) */
.brand { display: inline-flex; align-items: center; gap: 8px; }
.brand__copa {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}
.brand__copa img {
    display: block;
    width: 44px;
    height: 44px;
    object-fit: contain;
    transform-origin: 50% 55%;
    animation: brand-copa-spin 3.6s ease-in-out infinite;
    filter: drop-shadow(0 0 7px rgba(242,194,0,.55));
}
@media (max-width: 720px) {
    .brand__copa img { width: 36px; height: 36px; }
}
@keyframes brand-copa-spin {
    0%   { transform: rotateY(0deg); }
    100% { transform: rotateY(360deg); }
}
@media (prefers-reduced-motion: reduce) {
    .brand__copa img { animation: none; }
}

/* Placar de jogo já realizado na agenda da Copa */
.copa-jogo__placar {
    display: inline-block;
    margin-left: 6px;
    padding: 1px 8px;
    border-radius: 999px;
    background: rgba(26,157,75,.22);
    border: 1px solid rgba(26,157,75,.55);
    color: #6ee89a;
    font-size: .72rem;
    font-weight: 800;
    vertical-align: middle;
}

/* ==========================================================================
   PÁGINA "FUI NOTIFICADO PELA AUTODESK" (landing de regularização)
   ========================================================================== */
.autodesk-hero { background: linear-gradient(135deg, #1a1206 0%, #0e1626 60%); }
.autodesk-badge { background: rgba(224,168,0,.16); color: #f2c200; border-color: rgba(224,168,0,.4); }
.autodesk-accent { color: #f2c200 !important; }
.gs-hero__lead strong { color: #ffd86b; }
.autodesk-page a.autodesk-btn,
.autodesk-page .btn.autodesk-btn {
    background: #e0a800;
    color: #1a1206;
    border-color: #e0a800;
}
.autodesk-page a.autodesk-btn:hover { background: #f2c200; border-color: #f2c200; }

/* números */
.autodesk-stats { background: #0e1626; padding: 28px 0; }
.autodesk-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.autodesk-stat { text-align: center; }
.autodesk-stat__num { display: block; font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 800; color: #f2c200; line-height: 1.1; }
.autodesk-stat__label { display: block; font-size: .82rem; color: rgba(232,238,255,.75); margin-top: 6px; }

.autodesk-note {
    margin-top: 18px;
    padding: 14px 18px;
    background: color-mix(in srgb, #e0a800 9%, var(--white));
    border-left: 3px solid #e0a800;
    border-radius: 0 12px 12px 0;
    font-size: .9rem;
    color: var(--text-muted);
}
.autodesk-cta-inline { margin-top: 22px; text-align: center; }

/* por que escolher */
.autodesk-why {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 28px;
    margin-top: 24px;
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 20px;
    padding: 32px;
}
.autodesk-why__copy h3 { margin: 0 0 14px; }
.autodesk-why__cta {
    background: linear-gradient(135deg, #1a1206, #0e1626);
    border-radius: 16px;
    padding: 26px;
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: flex-start;
    justify-content: center;
}
.autodesk-why__eco {
    align-self: flex-start;
    background: #e0a800;
    color: #1a1206;
    font-weight: 800;
    font-size: .85rem;
    padding: 4px 14px;
    border-radius: 999px;
}
.autodesk-why__cta p { font-size: .92rem; color: rgba(232,238,255,.85); margin: 0; }

/* FAQ */
.autodesk-faq { display: flex; flex-direction: column; gap: 10px; }
.autodesk-faq__item {
    background: var(--white);
    border: 1px solid #dde5f3;
    border-radius: 14px;
    padding: 4px 20px;
}
.autodesk-faq__item summary {
    cursor: pointer;
    font-weight: 700;
    color: var(--dark);
    padding: 16px 28px 16px 0;
    position: relative;
    list-style: none;
}
.autodesk-faq__item summary::-webkit-details-marker { display: none; }
.autodesk-faq__item summary::after {
    content: "+";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.4rem;
    color: #e0a800;
    font-weight: 400;
}
.autodesk-faq__item[open] summary::after { content: "−"; }
.autodesk-faq__item p { margin: 0 0 16px; color: var(--text-muted); font-size: .92rem; line-height: 1.65; }

/* contato */
.autodesk-contato { padding: 56px 0; background: #0e1626; color: #fff; }
.autodesk-contato .gs-section-head h2 { color: #fff; }
.autodesk-contato .gs-section-head p { color: rgba(232,238,255,.8); }
.autodesk-contato__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 24px; }
.autodesk-contato__card {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.autodesk-contato__card h3 { margin: 0 0 6px; color: #f2c200; font-size: 1.05rem; }
.autodesk-contato__card p { margin: 0; color: rgba(232,238,255,.8); font-size: .9rem; }
.autodesk-contato__card a { color: #fff; font-weight: 600; font-size: .92rem; }
.autodesk-contato__card a[href^="tel"], .autodesk-contato__card a[href^="mailto"] { color: rgba(232,238,255,.9); }
.autodesk-contato__card--cta { background: rgba(224,168,0,.12); border-color: rgba(224,168,0,.4); justify-content: center; }
.autodesk-contato__card--cta .autodesk-btn { margin-top: 8px; }

@media (max-width: 900px) {
    .autodesk-stats__grid { grid-template-columns: 1fr 1fr; }
    .autodesk-why { grid-template-columns: 1fr; }
    .autodesk-contato__grid { grid-template-columns: 1fr; }
}



/* Autodesk — comparação com AutoCAD + janela de software delicada */
.autodesk-compare {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 34px;
    align-items: center;
    margin: 8px 0 28px;
}
.autodesk-window {
    margin: 0;
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
    border: 1px solid #e3e8f2;
    box-shadow: 0 14px 40px rgba(10,20,60,.10);
}
.autodesk-window__bar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 9px 14px;
    background: #f4f6fb;
    border-bottom: 1px solid #e8ecf5;
}
.autodesk-window__dot { width: 9px; height: 9px; border-radius: 50%; background: #d3d9e6; }
.autodesk-window__dot:nth-child(1) { background: #f0a8a0; }
.autodesk-window__dot:nth-child(2) { background: #f2cf8a; }
.autodesk-window__dot:nth-child(3) { background: #a8d8a0; }
.autodesk-window__title {
    margin-left: 8px;
    font-size: .76rem;
    font-weight: 700;
    color: #8a93a8;
    letter-spacing: .02em;
}
.autodesk-window img { width: 100%; display: block; }
.autodesk-compare__copy h3 { margin: 8px 0 10px; font-size: 1.35rem; line-height: 1.25; }
.autodesk-compare__sub { color: var(--text-muted); font-size: .95rem; margin: 0 0 16px; }
.autodesk-compare__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.autodesk-compare__list li { display: flex; gap: 10px; align-items: flex-start; }
.autodesk-compare__list svg { flex: 0 0 auto; margin-top: 1px; }
.autodesk-compare__list span { font-size: .92rem; line-height: 1.55; color: var(--text-muted); }
.autodesk-compare__list strong { color: var(--dark); }
@media (max-width: 860px) {
    .autodesk-compare { grid-template-columns: 1fr; gap: 22px; }
}

/* Footer usa o logo azul (colorido) — sobre fundo claro. */
.site-footer__logo img {
    max-height: 38px;
    width: auto;
}
