* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

@font-face {
    font-display: swap;
    font-family: "Instrument Serif";
    font-style: normal;
    font-weight: 400;
    src: url('/assets/fonts/instrument-serif-regular.woff2') format('woff2');
}

html {
    scroll-behavior: smooth;
}

hr {
    border: 0;
}

body {
    background: #110600;
    font-size: 16px;
    font-family: -apple-system, BlinkMacSystemFont, Arial, "Noto Sans", sans-serif;
    color: #edcc8e;
    -webkit-font-smoothing: antialiased;
    font-weight: 450;
}

h1, h2, h3, h4, h5, h6 {
    color: #edcc8e;
    font-family: "Instrument Serif", serif;
    font-weight: 400;
    font-style: normal;
}

h1 {
    font-size: 70px;
}

h2 {
    font-size: 58px;
}

h3 {
    font-size: 48px;
}

h4 {
    font-size: 38px;
}

.site-header {
    display: flex;
    align-items: center;
    width: 90%;
    max-width: 1280px;
    margin: 35px auto 45px auto;
}

.site-header .branding {
    display: flex;
    align-items: center;
}

.site-header .branding img {
    width: 64px;
}

.site-header .branding h4 {
    font-size: 36px;
    margin-left: 10px;
}

.site-header a.branding-link {
    text-decoration: none;
}

.site-header nav.primary ul {
    list-style: none;
    padding: 0;
    display: flex;
    align-items: center;
}

.site-header nav.primary ul li.regular-link a {
    font-size: 18px;
    font-weight: 550;
    padding: 0 15px;
    color: #edcc8e;
    text-decoration: none;
}

.site-header nav.primary ul li.button-link-secondary {
    margin-left: 16px;
}

.button-link-secondary a {
    display: inline-block;
    text-decoration: none;
    font-size: 18px;
    font-weight: 650;
    padding: 15px 24px;
    color: #FF5714;
    background: #2d1b12;
    border: 1px solid #41281b;
    border-radius: 12px;
}

.button-link-secondary a span.button-highlight {
    background: #41281b;
    padding: 4px 6px;
    border-radius: 8px;
    font-size: 16px;
    color: #edcc8e;
}

.button-link-primary a {
    display: inline-block;
    text-decoration: none;
    font-size: 18px;
    font-weight: 650;
    padding: 15px 24px;
    color: #fee2ae;
    background: linear-gradient(#ff5714, #ff5714 60.08%, #ff5714);
    border: 1px solid #bf7b60;
    border-radius: 12px;
    box-shadow: inset 0 4px 2px rgba(255, 255, 255, 0.15),
    inset 0 -2px 3px rgba(0, 0, 0, 0.05),
    0 4px 10px rgba(0, 0, 0, 0.25);
}

.spacer {
    flex: 1;
}

.compact-floating-header {
    position: fixed;
    top: 30px;
    left: 50%;
    transform: translate(-50%, -150%);
    width: 90%;
    max-width: 500px;
    display: flex;
    align-items: center;
    background: rgba(45, 27, 18, 0.75);
    border-radius: 25px;
    z-index: 999;
    padding: 6px 12px;
    backdrop-filter: blur(6px);
    box-shadow: inset 0 1px 2px rgba(255, 255, 255, 0.08),
    inset 0 -2px 3px rgba(0, 0, 0, 0.05),
    0 4px 10px rgba(0, 0, 0, 0.25);
    transition: transform 0.3s ease, opacity 0.3s ease;
    opacity: 0;
    pointer-events: none;
}

.compact-floating-header.header-visible {
    transform: translate(-50%, 0);
    opacity: 1;
    pointer-events: auto;
}

.compact-floating-header:hover {
    opacity: 1;
}

.compact-floating-header img {
    width: 30px;
    margin-left: 5px;
    cursor: pointer;
}

.compact-floating-header .link-option {
    display: flex;
    align-items: center;
    margin-right: 15px;
}

.compact-floating-header .link-option svg {
    width: 18px;
    height: 18px;
    margin-right: 6px;
    color: #edcc8e;
    transition: color 0.1s linear;
    margin-top: 1px;
}

.compact-floating-header a {
    text-decoration: none;
    color: #edcc8e;
    font-weight: 650;
    font-size: 15px;
    transition: color 0.1s linear;
}

.compact-floating-header a:hover {
    color: #ff5714;
}

.compact-floating-header a:hover .link-option svg {
    color: #ff5714;
}

section.hero,
section.brief-description,
section.pricing,
section.faq,
section.compact-app-info {
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
}

section.hero p {
    max-width: 750px;
    font-size: 22px;
    color: #aa8035;
    margin: 10px auto;
    line-height: 1.4;
}

.action-buttons {
    display: flex;
    justify-content: center;
    margin: 35px 0;
}

.action-spacer {
    width: 25px;
}

.app-demo {
    position: relative;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

.app-demo img {
    width: 100%;
}

.app-demo video {
    width: 79.25%;
    height: auto;
    position: absolute;
    top: 5.75%;
    left: 50%;
    transform: translateX(-50%);
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.macbook-notch {
    position: absolute;
    width: 11%;
    height: 3%;
    background: #000;
    top: 5.5%;
    left: 50%;
    transform: translateX(-50%);
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

.brief-description {
    margin: 50px auto !important;
}

.brief-description p,
.pricing p {
    font-size: 20px;
    max-width: 850px;
    margin: 20px auto;
    color: #aa8035;
    line-height: 1.4;
}

.brief-description img {
    width: 60%;
    opacity: 0.85;
}

.usecases {
    display: flex;
    width: 90%;
    max-width: 1280px;
    margin: 95px auto;
}

.peeking-screen {
    position: relative;
    flex: 1;
    max-width: 70%;
}

.peeking-screen img {
    position: relative;
    width: 100%;
    border-radius: 16px 8px 8px 8px;
}

.peeking-screen p {
    position: absolute;
    top: 4.8%;
    right: 2.4%;
    z-index: 599;
    color: #aa8035;
    font-weight: 650;
    font-size: 14px;
}

.peeking-screen p span.highlight {
    color: #edcc8e;
}

.usecase-gallery {
    width: 31.25%;
    margin-left: 3.9%;
}

.usecase-gallery h3 {
    margin-top: 12px;
    margin-bottom: 16px;
}

.usecase-gallery ul {
    list-style: none;
    padding: 0;
}

.usecase-gallery ul li {
    padding: 18px 10px 12px 0;
    border-bottom: 1px solid #2d1b12;
    cursor: pointer;
}

.usecase-gallery ul li .title-section {
    display: flex;
    align-items: center;
}

.usecase-gallery ul li .title-section img {
    width: 28px;
    margin-right: 10px;
    margin-left: -2px;
}

.usecase-gallery ul li p.title {
    font-size: 24px;
    font-weight: 550;
}

.usecase-gallery ul li p.subtitle {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    color: #aa8035;
    font-size: 16px;
    margin-top: 10px;
    line-height: 1.4;
    opacity: 0;
    visibility: hidden;
}

.expand {
    max-height: 46px !important;
    opacity: 1 !important;
    visibility: visible !important;
    padding-bottom: 2px !important;
}

.highlighted-features {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 50px;
    width: 90%;
    max-width: 1280px;
    margin: 50px auto;
}

.highlighted-features video {
    width: 100%;
    border-radius: 10px;
}

.highlighted-features h3 {
    margin-top: 20px;
}

.highlighted-features p {
    color: #aa8035;
    font-size: 20px;
}

.subtle-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 30px;
    width: 90%;
    max-width: 1280px;
    margin: 80px auto;
}

.subtle-features > * {
    border-right: 1px solid #2d1b12;
}

.subtle-features > :last-child {
    border: 0;
}

.subtle-features img.icon {
    width: 50px;
    padding: 8px;
    background: #210d02;
    border-radius: 10px;
}

.subtle-features h4 {
    margin: 10px 0;
}

.subtle-features p {
    max-width: 95%;
    color: #aa8035;
    font-size: 18px;
    line-height: 1.3;
}

.subtle-features .callout {
    display: flex;
    align-items: center;
    margin-top: 20px;
    margin-bottom: 10px;
    margin-right: 10px;
}

.subtle-features .callout img {
    width: 12px;
    margin-right: 4px;
}

.subtle-features .callout p {
    font-size: 12px;
    font-weight: 650;
    padding: 0;
}

.subtle-features .callout p span {
    color: #edcc8e;
}

.pricing {
    margin-top: 110px !important;
}

.license-options {
    width: 90%;
    max-width: 700px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin: 45px auto;
    text-align: start;
}

.license-options > * {
    border-right: 1px solid #2d1b12;
}

.license-options > :last-child {
    border: 0;
}

.license {
    padding: 0 30px;
}

.license p.description {
    font-size: 18px;
    margin-top: 5px;
}

.license p.price {
    font-size: 64px;
    font-weight: 650;
    color: #edcc8e;
}

.license p.price span {
    display: inline-block;
    vertical-align: top;
    font-size: 22px;
    font-weight: 550;
    color: #aa8035;
    margin-left: 5px;
    margin-top: 18px;
}

.license ul {
    list-style: none;
    padding: 0;
    margin-bottom: 35px;
}

.license ul li {
    display: flex;
    align-items: center;
    margin: 14px 0;
    position: relative;
}

.license ul li::before {
    display: block;
    width: 18px;
    height: 18px;
    content: "";
    background: url("/assets/images/check-mark.svg") no-repeat center / contain;
    margin-right: 10px;
}

.license ul li.hover-tooltip span {
    box-sizing: border-box;
    position: relative;
    border-bottom: 1px dashed #aa8035;
    cursor: help;
}

.license ul li.hover-tooltip .tooltip {
    position: absolute;
    opacity: 0;
    top: 25px;
    left: 25px;
    width: 260px;
    background: #210d02;
    border-radius: 10px;
    z-index: 50;
    padding: 2px 20px;
    border: 1px solid #44200d;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    transition: opacity 0.2s ease-in-out;
}

.license ul li.hover-tooltip:hover .tooltip hr {
    border: none;
    border-top: 1px solid #44200d;
}

.license ul li.hover-tooltip .tooltip p {
    font-size: 14px;
    color: #edcc8e;
}

.license ul li.hover-tooltip span:hover + .tooltip {
    opacity: 1;
}

.full-width-button {
    display: block !important;
    text-align: center;
}

.pricing .payment-terms {
    font-size: 16px;
    max-width: 550px;
}

.pricing .payment-terms span {
    color: #edcc8e;
}

.faq {
    margin: 95px auto !important;
}

.faq ul {
    list-style: none;
    padding: 0;
    max-width: 750px;
    margin: 30px auto;
}

.faq ul li {
    padding: 18px 10px 12px 0;
    border-bottom: 1px solid #2d1b12;
    cursor: pointer;
    text-align: start;
}

.faq ul li p.question {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}

.faq ul li p.question span {
    flex: 1;
    font-size: 22px;
    font-weight: 550;
}

.faq ul li .answer p {
    font-size: 18px;
    color: #aa8035;
    margin-top: 15px;
    line-height: 1.4;
}

.faq ul li .answer {
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    visibility: hidden;
    transition: all 0.2s linear;
}

.faq-expanded {
    opacity: 1 !important;
    max-height: 220px !important;
    overflow: auto !important;
    visibility: visible !important;
}

.faq ul li.active p.question::after {
    transform: rotate(180deg);
}

.faq ul li p.question::after {
    display: block;
    width: 24px;
    height: 24px;
    content: "";
    background: url("/assets/images/dropdown.svg") no-repeat center / contain;
    transition: all 150ms linear;
}

.faq p.faq-extra-help {
    font-size: 16px;
    max-width: 550px;
    margin: 20px auto;
    color: #aa8035;
    line-height: 1.45;
}

.faq p.faq-extra-help a {
    color: #edcc8e;
    text-decoration: none;
    transition: color 0.1s linear;
}

.faq p.faq-extra-help a:hover {
    color: #ff5714;
}

.compact-app-info img {
    width: 128px;
}

.compact-app-info p {
    color: #aa8035;
    font-size: 20px;
}

.footer-links {
    border-top: 1px solid #2d1b12;
    width: 90%;
    max-width: 700px;
    margin: 50px auto;
}

.footer-links .social-links {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 24px 0;
}

.footer-links .social-links a svg {
    width: 28px;
    fill: #edcc8e;
    text-decoration: none;
    cursor: pointer;
    transition: fill 0.1s linear;
}

.footer-links .social-links a {
    display: inline-block;
    margin-right: 20px;
}

.footer-links .social-links a:last-child {
    margin-right: 0;
}

.footer-links .social-links a svg:hover {
    fill: #ff5714;
}

.footer-links .links-grid {
    width: 100%;
    max-width: 400px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin: 50px auto;
}

.footer-links .links-grid .links {
    margin: 0 0 0 50px;
}

.footer-links .links-grid .links p {
    color: #aa8035;
    font-weight: 550;
    margin-bottom: 15px;
}

.footer-links .links-grid .links ul {
    list-style: none;
    padding: 0;
}

.footer-links .links-grid .links ul li {
    margin: 10px 0;
}

.footer-links .links-grid .links ul li a {
    text-decoration: none;
    color: #edcc8e;
    transition: color 0.1s linear;
}

.footer-links .links-grid .links ul li a:hover {
    color: #ff5714;
}

.footer-links .copyright-info {
    width: 100%;
    max-width: 700px;
    margin: 50px auto;
    text-align: center;
}

.footer-links .copyright-info p {
    color: #aa8035;
    font-size: 14px;
    margin-bottom: 6px;
}

.hulry-badge {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hulry-badge img {
    width: 54px;
    margin: 0 5px;
}

.hulry-badge p {
    color: #aa8035;
    font-weight: 550;
}

.footer-links a {
    text-decoration: none;
}

.page-article {
    width: 90%;
    max-width: 700px;
    margin: 50px auto;
}

.page-article-meta {
    width: 100%;
    border-bottom: 1px solid #2d1b12;
    padding-bottom: 20px;
    margin-bottom: 30px;
}

.page-article .page-article-meta p {
    font-size: 22px;
    color: #aa8035;
    line-height: 1.4;
}

.page-article .content h2 {
    font-size: 48px;
    margin-top: 30px;
}

.page-article .content p {
    font-size: 18px;
    margin: 20px 0;
    line-height: 1.45;
}

.page-article .content a {
    text-decoration: none;
    color: #aa8035;
    transition: color 0.1s linear;
}

.page-article .content a:hover {
    color: #ff5714;
}

.page-article .content ul {
    padding: 10px 15px 10px 35px;
}

.page-article .content ul li {
    font-size: 18px;
    margin: 10px 0;
    line-height: 1.4;
}

.page-article .content ul li strong {
    background: #2d1b12;
    padding: 3px 6px;
    border-radius: 4px;
}

.page-article .content .last-updated {
    display: inline-flex;
    background: #2d1b12;
    padding: 10px 16px;
    border-radius: 10px;
    margin: 15px 0;
    align-items: center;
}

.page-article .content .last-updated::before {
    display: block;
    width: 24px;
    height: 24px;
    content: "";
    background: url("/assets/images/info-icon.svg") no-repeat center / contain;
    margin-right: 5px;
}

.page-article .content .last-updated strong {
    margin-left: 5px;
}

.page-article .content img,
.page-article .content video,
.page-article .content p img {
    width: 100%;
    height: auto;
}

.page-article .content p img,
.page-article .content figure img,
.page-article .content video {
    border: 2px solid #41281b;
    border-radius: 10px;
}

.page-article .content figure figcaption {
    font-size: 14px;
    color: #aa8035;
    margin: 5px 0 0 2px;
    font-weight: 550;
}

.page-article .content .image-video-grid {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 20px;
    align-items: stretch;
}

.page-article .content .image-video-grid img {
    grid-column: span 3;
    border-radius: 10px;
    object-fit: cover;
    border: 2px solid #41281b;
}

.page-article .content .image-video-grid video {
    width: 100%;
    grid-column: span 1;
    border-radius: 10px;
    object-fit: cover;
    border: 2px solid #41281b;
}

a.founding-story-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    font-size: 16px;
    color: #edcc8e;
    font-weight: 550;
    transition: color 0.1s linear;
}

a.founding-story-link::after {
    content: "↗";
    margin-top: 4px;
    margin-left: 4px;
    font-size: 17px;
}

a.founding-story-link:hover {
    color: #ff5714;
}

@media only screen and (max-width: 480px) {
    .desktop-only {
        display: none;
    }

    section.hero h1 {
        font-size: 48px;
        line-height: 1.25;
    }

    section.hero p {
        font-size: 18px;
        line-height: 1.3;
    }

    .action-buttons {
        flex-wrap: wrap;
    }

    .action-spacer {
        height: 15px;
    }

    .action-buttons .button-link-secondary,
    .action-buttons .button-link-primary {
        width: 100%;
    }

    .action-buttons .button-link-secondary a,
    .action-buttons .button-link-primary a {
        display: block;
    }

    h2 {
        font-size: 42px;
    }

    h3 {
        font-size: 36px;
    }

    .app-demo {
        width: 175%;
        margin-left: -73%;
    }

    .app-demo video {
        border-top-left-radius: 5px;
        border-top-right-radius: 5px;
    }

    .macbook-notch {
        border-bottom-left-radius: 4px;
        border-bottom-right-radius: 4px;
    }

    .brief-description p, .pricing p {
        font-size: 17px;
    }

    .brief-description img {
        width: 100%;
        opacity: 1;
    }

    .usecases {
        flex-wrap: wrap;
        margin: 65px auto;
    }

    .expand {
        max-height: 72px !important;
    }

    .peeking-screen {
        max-width: 100%;
    }

    .peeking-screen p {
        display: none;
    }

    .usecase-gallery {
        width: 100%;
        margin-left: 10px;
        margin-right: 10px;
    }

    .usecase-gallery h3 {
        margin-top: 20px;
        margin-bottom: 15px;
    }

    .highlighted-features {
        width: 88%;
        grid-template-columns: 1fr;
        margin: 75px auto;
    }

    .highlighted-features p {
        font-size: 17px;
    }

    .subtle-features {
        width: 88%;
        grid-template-columns: 1fr;
        grid-gap: 35px;
        margin: 90px auto;
    }

    .subtle-features > *, .license-options > * {
        border-right: 0;
        border-bottom: 1px solid #2d1b12;
        padding-bottom: 20px;
    }

    .subtle-features .callout {
        align-items: start;
    }

    .subtle-features .callout img {
        margin-top: 2px;
    }

    .license-options {
        width: 100%;
        grid-template-columns: 1fr;
        margin: 35px auto;
    }

    .license {
        padding: 30px;
    }

    .pricing .payment-terms {
        width: 92%;
    }

    .faq ul {
        width: 90%;
    }

    .faq ul li p.question span {
        font-size: 20px;
    }

    .faq ul li .answer p {
        font-size: 17px;
    }

    .faq-expanded {
        max-height: 385px !important;
    }

    .faq p.faq-extra-help {
        width: 90%;
    }

    .compact-app-info p {
        font-size: 19px;
        width: 90%;
        margin: 5px auto;
    }

    .footer-links .links-grid .links {
        margin: 0 0 0 32px;
    }

    .page-article {
        width: 86%;
    }

    .page-article .page-article-meta p {
        font-size: 20px;
        line-height: 1.35;
    }

    .page-article .content p {
        font-size: 17px;
    }

    .page-article .content ul li {
        font-size: 17px;
    }

    .page-article .content h2 {
        font-size: 42px;
    }

    .footer-links .copyright-info p {
        font-size: 13px;
    }

    .page-article-meta h1 {
        font-size: 64px;
    }

    .page-article .content .image-video-grid {
        grid-gap: 10px;
    }
}

@media screen and (min-width: 768px) and (max-width: 1200px) and (orientation: landscape) {
    .brief-description img {
        opacity: 1;
    }

    .usecase-gallery {
        width: 35.25%;
    }

    .usecase-gallery h3 {
        margin-top: 15px;
        margin-bottom: 16px;
    }

    .expand {
        max-height: 75px !important;
    }

    .subtle-features .callout {
        align-items: start;
    }

    .subtle-features .callout img {
        margin-top: 2px;
    }

    .peeking-screen {
        overflow-x: hidden;
    }

    .peeking-screen img {
        width: 125%;
    }
}

@media screen and (min-width: 768px) and (max-width: 1200px) and (orientation: portrait) {
    h1 {
        font-size: 53px;
    }

    h2 {
        font-size: 48px;
    }

    h3 {
        font-size: 42px;
    }

    section.hero p {
        max-width: 700px;
    }

    .brief-description p, .pricing p {
        max-width: 625px;
    }

    .brief-description img {
        opacity: 1;
    }

    .usecase-gallery {
        width: 38.25%;
    }

    .expand {
        max-height: 75px !important;
    }

    .usecase-gallery h3 {
        margin-top: 0;
        margin-bottom: 16px;
    }

    .subtle-features .callout {
        align-items: start;
    }

    .subtle-features .callout img {
        margin-top: 2px;
    }

    .peeking-screen {
        overflow-x: hidden;
    }

    .peeking-screen img {
        width: 125%;
    }

    .peeking-screen p {
        top: 2.35%;
    }
}
