* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
}

.fpb-shell {
    min-height: 100vh;
    background: #fff;
    color: #111;
    display: grid;
    grid-template-columns: 275px 1fr;
    font-family: Arial, sans-serif;
}

.fpb-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    border-right: 1px solid rgba(255,255,255,.08);
    padding: 54px 58px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #111;
    color: #fff;
}

.fpb-logo strong {
    display: block;
    font-family: Georgia, serif;
    font-size: 26px;
    letter-spacing: .18em;
    font-weight: 400;
    color: #fff;
}

.fpb-logo span {
    display: block;
    margin-top: 6px;
    font-size: 11px;
    letter-spacing: .35em;
    color: rgba(255,255,255,.65);
}

.fpb-sidebar-title span,
.fpb-kicker,
.fpb-step-header p {
    display: block;
    color: #7b1113;
    font-size: 11px;
    letter-spacing: .32em;
    text-transform: uppercase;
    font-weight: 700;
}

.fpb-sidebar-title i {
    display: block;
    width: 1px;
    height: 38px;
    background:rgba(255,255,255,.15);
    margin-top: 24px;
}

.fpb-step-nav {
    display: grid;
    gap: 12px;
}

.fpb-step-nav button {
    background: transparent !important;
    border: 0 !important;
    padding: 0;
    display: grid;
    grid-template-columns: 44px 1fr;
    align-items: center;
    text-align: left;
    cursor: pointer;
   color:rgba(255,255,255,.45);
    box-shadow: none !important;
}

.fpb-step-nav button span {
    font-family: Georgia, serif;
    font-size: 22px;
    color:rgba(255,255,255,.45);
}

.fpb-step-nav button em {
    font-style: normal;
    font-size: 10px;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: #777;
}

.fpb-step-nav button.active span,
.fpb-step-nav button.active em {
    color: #fff !important;
}

.fpb-step-nav button.active span {
    color: #7b1113 !important;
}

.fpb-step-nav button.active::after {
    content: "";
    width: 5px;
    height: 5px;
    background: #fff;
    border-radius: 50%;
    grid-column: 1;
    margin-left: 8px;
    margin-top: 7px;
}

.fpb-sidebar-note{
    color:rgba(255,255,255,.65);
    font-size:14px;
    line-height:1.8;
}

.fpb-sidebar-note span {
    display: block;
    margin-top: 22px;
    font-family: Georgia, serif;
    font-style: italic;
    font-size: 25px;
    color:#fff;
}

.fpb-main {
    min-height: 100vh;
}

.fpb-hero {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.fpb-hero:not(.active) {
    display: none;
}

.fpb-hero-inner {
    padding: 8vw 7vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.fpb-hero h1,
.fpb-step-header h2,
.fpb-success h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-weight: 400;
    letter-spacing: -0.065em;
    line-height: .9;
    color: #111;
    margin: 0;
}

.fpb-hero h1 {
    font-size: clamp(60px, 7vw, 115px);
}

.fpb-hero em {
    font-style: italic;
}

.fpb-hero p:not(.fpb-kicker) {
    max-width: 520px;
    font-size: 16px;
    line-height: 1.7;
    margin: 28px 0 0;
}

.fpb-hero-panel {
    background: #111;
    min-height: 100vh;
}

.fpb-form {
    display: none;
    min-height: 100vh;
    padding: 42px 5.5vw 42px;
}

.fpb-form.show {
    display: block;
}

.fpb-mobile-progress {
    display: none;
}

.fpb-step {
    display: none;
}

.fpb-step.active {
    display: block;
}

.fpb-step-header {
    margin-bottom: 28px;
}

.fpb-step-header h2 {
    font-size: clamp(42px, 4vw, 62px);
    line-height: .95;
    max-width: 760px;
    margin-bottom: 14px;
}

.fpb-step-header span {
    display: block;
    margin-top: 16px;
    font-family: Georgia, serif;
    font-size: 18px;
}

.fpb-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px 28px;
    max-width: 1050px;
}

.fpb-grid .full {
    grid-column: 1 / -1;
}

.fpb-step label {
    display: block;
    color: #111;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .22em;
    font-weight: 700;
    margin-bottom: 14px;
}

.fpb-step input,
.fpb-step textarea {
    width: 100%;
    margin-top: 8px;
    border: 1px solid #cfc7bb;
    background: transparent;
    color: #111;
    padding: 13px 15px;
    min-height: 48px;
    font-size: 14px;
    font-family: Arial, sans-serif;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
    outline: none;
    border-radius: 0;
    box-shadow: none !important;
}

.fpb-step textarea {
    min-height: 112px;
    resize: vertical;
    line-height: 1.5;
}

.fpb-step input:focus,
.fpb-step textarea:focus {
    border-color: #111;
}

.fpb-industry-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 9px;
    max-width: 1120px;
}

.fpb-industry-card {
    position: relative;
    min-height: 145px;
    margin: 0;
    padding: 0;
    cursor: pointer;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    border: 1px solid transparent;
}

.fpb-industry-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.45);
    transition: .25s ease;
}

.fpb-industry-card span {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 12px;
    letter-spacing: .34em;
    text-transform: uppercase;
    text-align: center;
    padding: 18px;
}

.fpb-industry-card input {
    display: none;
}

.fpb-industry-card:hover {
    transform: translateY(-2px);
}

.fpb-industry-card:hover::before {
    background: rgba(0,0,0,.28);
}

.fpb-industry-card:has(input:checked) {
    border-color: #7b1113;
}

.fpb-industry-card:has(input:checked)::after {
    content: "✓";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    background: #7b1113;
    color: #fff;
    font-size: 12px;
}

.fpb-card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    max-width: 1050px;
}

.fpb-card {
    position: relative;
    border: 1px solid #cfc7bb;
    min-height: 88px;
    padding: 22px 16px;
    display: grid;
    place-items: center;
    text-align: center;
    cursor: pointer;
    background: transparent;
}

.fpb-card input {
    display: none;
}

.fpb-card span {
    font-size: 11px;
    letter-spacing: .26em;
    text-transform: uppercase;
}

.fpb-card:hover {
    border-color: #111;
    background: #fff;
}

.fpb-card:has(input:checked) {
    border-color: #111;
    background: #fff;
}

.fpb-card:has(input:checked)::after {
    content: "✓";
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    height: 20px;
    display: grid;
    place-items: center;
    background: #111;
    color: #fff;
    border-radius: 50%;
    font-size: 10px;
}

.fpb-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    margin-top: 30px;
    max-width: 1120px;
}

.fpb-btn,
.fpb-btn:visited,
.fpb-btn:focus,
.fpb-btn:active {
    background: #111 !important;
    color: #fff !important;
    border: 1px solid #111 !important;
    border-radius: 0 !important;
    padding: 15px 28px;
    min-width: 200px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: .24em;
    font-size: 11px;
    font-weight: 700;
    transition: .25s ease;
    box-shadow: none !important;
}

.fpb-btn:hover {
    background: #7b1113 !important;
    border-color: #7b1113 !important;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(0,0,0,.14) !important;
}

.fpb-back,
.fpb-back:visited,
.fpb-back:focus,
.fpb-back:active {
    background: transparent !important;
    border: 0 !important;
    color: #111 !important;
    opacity: .55;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: .24em;
    font-size: 11px;
    font-weight: 700;
    padding: 0;
    box-shadow: none !important;
}

.fpb-back:hover {
    opacity: 1;
    background: transparent !important;
    color: #7b1113 !important;
}

.fpb-success {
    display: none;
    min-height: 70vh;
    align-content: center;
    max-width: 900px;
}

.fpb-success.show {
    display: grid;
}

.fpb-success p {
    color: #7b1113;
    font-size: 11px;
    letter-spacing: .35em;
    text-transform: uppercase;
    font-weight: 700;
}

.fpb-success h2 {
    font-size: clamp(48px, 6vw, 90px);
}

.fpb-success span {
    margin-top: 25px;
    font-size: 18px;
}

@media (max-width: 1100px) {
    .fpb-shell {
        grid-template-columns: 235px 1fr;
    }

    .fpb-sidebar {
        padding: 38px 30px;
    }

    .fpb-industry-grid,
    .fpb-card-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 820px) {
    .fpb-shell {
        display: block;
    }

    .fpb-sidebar {
        display: none;
    }

    .fpb-form {
        padding: 28px 20px 45px;
    }

    .fpb-mobile-progress {
        display: flex;
        align-items: center;
        gap: 15px;
        margin-bottom: 30px;
        font-size: 11px;
        letter-spacing: .2em;
        text-transform: uppercase;
    }

    .fpb-mobile-progress i {
        flex: 1;
        height: 1px;
        background: #d8d1c7;
    }

    .fpb-mobile-progress b {
        display: block;
        height: 1px;
        width: 12%;
        background: #7b1113;
    }

    .fpb-hero {
        display: block;
        min-height: 100vh;
    }

    .fpb-hero-inner {
        padding: 70px 24px;
        min-height: 100vh;
    }

    .fpb-hero-panel {
        display: none;
    }

    .fpb-hero h1,
    .fpb-step-header h2 {
        font-size: 45px;
    }

    .fpb-grid,
    .fpb-industry-grid,
    .fpb-card-grid {
        grid-template-columns: 1fr;
    }

    .fpb-industry-card {
        min-height: 140px;
    }

    .fpb-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .fpb-btn {
        width: 100%;
    }

    .fpb-back {
        text-align: left;
        padding: 10px 0;
    }
}


/* FORCE FEMME BLUEPRINT OVERRIDES */

.fpb-form {
    padding: 35px 5vw 35px !important;
}

.fpb-step-header h2 {
    font-size: clamp(38px, 3.3vw, 56px) !important;
    line-height: .95 !important;
    max-width: 680px !important;
    margin-bottom: 12px !important;
}

.fpb-hero h1 {
    font-size: clamp(54px, 6vw, 95px) !important;
}

.fpb-step-header {
    margin-bottom: 22px !important;
}

.fpb-industry-card {
    min-height: 135px !important;
}

.fpb-btn,
.fpb-btn:hover,
.fpb-btn:focus,
.fpb-btn:active,
.fpb-btn:visited {
    background: #111 !important;
    color: #fff !important;
    border-color: #111 !important;
    box-shadow: none !important;
}

.fpb-btn:hover {
    background: #7b1113 !important;
    border-color: #7b1113 !important;
    color: #fff !important;
}

.fpb-step-nav button,
.fpb-step-nav button:hover,
.fpb-step-nav button:focus,
.fpb-step-nav button:active {
    background: transparent !important;
    color: #777 !important;
    box-shadow: none !important;
}

.fpb-step-nav button.active,
.fpb-step-nav button.active:hover {
    background: transparent !important;
    color: #111 !important;
}

.fpb-step-nav button.active span {
    color: #7b1113 !important;
}

.fpb-step-nav button.active em {
    color: #111 !important;
}

/* FINAL HERO + FONT OVERRIDES */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400;1,500&display=swap');

html,
body {
    margin: 0;
    padding: 0;
}

body.admin-bar .fpb-shell {
    height: calc(100vh - 32px) !important;
    min-height: calc(100vh - 32px) !important;
}

.fpb-shell {
    height: 100vh !important;
    min-height: 100vh !important;
    overflow: hidden !important;
    background: #fdfbf8 !important;
}

.fpb-main,
.fpb-hero,
.fpb-form {
    height: 100vh !important;
    min-height: 100vh !important;
    overflow: hidden !important;
}

.fpb-hero h1,
.fpb-step-header h2,
.fpb-success h2,
.fpb-logo strong,
.fpb-sidebar-note span,
.fpb-step-nav button span {
    font-family: "Playfair Display", Georgia, serif !important;
}

.fpb-hero {
    grid-template-columns: 52% 48% !important;
    background: #fdfbf8 !important;
}

.fpb-hero-inner {
    padding: 5vw 6vw !important;
}

.fpb-hero-panel {
    height: 100vh !important;
    min-height: 100vh !important;
    background-color: #fdfbf8 !important;
    background-image: url("https://femmecreative.com.au/wp-content/uploads/2026/06/femme-editorial.png") !important;
    background-repeat: no-repeat !important;
    background-position: right center !important;
    background-size: contain !important;
}

.fpb-hero h1 {
    font-size: clamp(58px, 6vw, 104px) !important;
    line-height: .88 !important;
}

.fpb-hero p:not(.fpb-kicker) {
    max-width: 460px !important;
}

/* prevent Elementor/Theme spacing */
.elementor,
.elementor-section,
.elementor-container,
.elementor-widget-wrap,
.elementor-widget-shortcode {
    margin: 0 !important;
    padding: 0 !important;
}

/* Mobile: allow scroll because the form needs it */
@media (max-width: 820px) {
    html,
    body,
    .fpb-shell,
    .fpb-main,
    .fpb-form {
        height: auto !important;
        min-height: 100vh !important;
        overflow: auto !important;
    }

    .fpb-hero {
        display: block !important;
    }

    .fpb-hero-panel {
        display: none !important;
    }
}


/* CONTENT STEP CLEANUP + INTERNAL SCROLL */

.fpb-main,
.fpb-form {
    overflow: hidden !important;
}

.fpb-step.active {
    height: calc(100vh - 70px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 14px;
}

body.admin-bar .fpb-step.active {
    height: calc(100vh - 102px) !important;
}

.fpb-step.active::-webkit-scrollbar {
    width: 6px;
}

.fpb-step.active::-webkit-scrollbar-track {
    background: transparent;
}

.fpb-step.active::-webkit-scrollbar-thumb {
    background: #111;
}

/* Make content page feel consistent */

.fpb-content-block h3,
.fpb-repeat-block h4 {
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: 30px !important;
    font-weight: 400 !important;
    letter-spacing: -0.03em !important;
    line-height: 1 !important;
    margin: 26px 0 18px !important;
    color: #111 !important;
}

.fpb-step-header span {
    font-family: Arial, sans-serif !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    margin-top: 12px !important;
    max-width: 720px;
}

.fpb-content-block {
    display: none;
    max-width: 1080px;
    margin-bottom: 26px;
}

.fpb-content-block.show {
    display: block;
}

.fpb-content-block textarea {
    min-height: 92px !important;
}

.fpb-content-block input {
    min-height: 46px !important;
}

.fpb-repeat-block {
    border-top: 1px solid #d8d1c7;
    padding-top: 18px;
    margin-top: 22px;
}

/* keep buttons visible nicely at bottom of longer steps */
.fpb-actions {
    padding-bottom: 35px;
}


/* WEBSITE FUNCTIONALITY STEP */

.fpb-functionality-list {
    max-width: 1080px;
    display: grid;
    gap: 12px;
}

.fpb-function-row {
    border-top: 1px solid #d8d1c7;
    padding: 18px 0;
}

.fpb-function-row:last-child {
    border-bottom: 1px solid #d8d1c7;
}

.fpb-function-toggle {
    margin: 0 !important;
    cursor: pointer;
}

.fpb-function-toggle input {
    display: none;
}

.fpb-function-toggle span {
    display: block;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 28px;
    font-weight: 400;
    letter-spacing: -0.03em;
    text-transform: none;
    color: #111;
    position: relative;
    padding-right: 40px;
}

.fpb-function-toggle span::after {
    content: "+";
    position: absolute;
    right: 0;
    top: 0;
    font-family: Arial, sans-serif;
    font-size: 22px;
    color: #7b1113;
}

.fpb-function-row.open .fpb-function-toggle span::after {
    content: "✓";
}

.fpb-function-details {
    display: none;
    padding: 20px 0 4px;
    max-width: 760px;
}

.fpb-function-details.show {
    display: block;
    animation: fpbFadeIn .25s ease;
}

.fpb-mini-options {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.fpb-mini-options label {
    margin: 0 !important;
    cursor: pointer;
}

.fpb-mini-options input {
    display: none;
}

.fpb-mini-options span {
    display: block;
    border: 1px solid #cfc7bb;
    padding: 12px 16px;
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    background: transparent;
}

.fpb-mini-options input:checked + span {
    background: #111;
    color: #fff;
    border-color: #111;
}

.fpb-platform-options,
.fpb-other-field {
    display: none !important;
    margin-top: 16px !important;
}

.fpb-platform-options.show,
.fpb-other-field.show {
    display: block !important;
}

.fpb-function-details select {
    width: 100%;
    margin-top: 8px;
    border: 1px solid #cfc7bb;
    background: transparent;
    color: #111;
    padding: 13px 15px;
    min-height: 48px;
    font-size: 14px;
    border-radius: 0;
    outline: none;
}

@keyframes fpbFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 820px) {
    .fpb-function-toggle span {
        font-size: 24px;
    }

    .fpb-mini-options {
        display: grid;
        grid-template-columns: 1fr;
    }
}


/* CLEAN PLATFORM PILLS - REPLACES DROPDOWNS */

.fpb-platform-title {
    margin: 18px 0 12px !important;
    font-size: 10px !important;
    letter-spacing: .22em !important;
    text-transform: uppercase !important;
    font-weight: 700 !important;
    color: #111 !important;
}

.fpb-platform-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 12px 0 16px;
}

.fpb-platform-pill {
    margin: 0 !important;
    cursor: pointer;
}

.fpb-platform-pill input {
    display: none !important;
}

.fpb-platform-pill span {
    display: block;
    border: 1px solid #cfc7bb;
    padding: 12px 18px;
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    background: transparent;
    color: #111;
    transition: .2s ease;
}

.fpb-platform-pill:hover span {
    border-color: #111;
}

.fpb-platform-pill input:checked + span {
    background: #111;
    color: #fff;
    border-color: #111;
}

.fpb-function-details select {
    display: none !important;
}

/* LOCK BLUEPRINT VIEW ONLY */

.fpb-shell {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    overflow: hidden !important;
    z-index: 1;
}

body.admin-bar .fpb-shell {
    top: 32px !important;
    height: calc(100vh - 32px) !important;
}

.fpb-main,
.fpb-form,
.fpb-hero {
    height: 100% !important;
    overflow: hidden !important;
}

/* allow only the active step content to scroll internally */
.fpb-step.active {
    overflow-y: auto !important;
}

/* REMOVE RANDOM PAGE/SECTION LINES ON BLUEPRINT */
.fpb-shell {
    top: 0 !important;
    left: 0 !important;
    z-index: 9999 !important;
    border: 0 !important;
}

body.admin-bar .fpb-shell {
    top: 32px !important;
}

.fpb-shell,
.fpb-shell * {
    outline: none !important;
}

.elementor,
.elementor-section,
.elementor-container,
.elementor-column,
.elementor-widget-wrap,
.elementor-widget,
.elementor-widget-container {
    border: 0 !important;
    box-shadow: none !important;
}

body.page .site,
body.page #page,
body.page .site-content,
body.page .entry-content {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

body:has(.fpb-shell) {
    overflow: hidden !important;
    height: 100vh !important;
}

body:has(.fpb-shell) .elementor,
body:has(.fpb-shell) .elementor-section,
body:has(.fpb-shell) .elementor-container,
body:has(.fpb-shell) .elementor-widget-wrap,
body:has(.fpb-shell) .elementor-widget-shortcode,
body:has(.fpb-shell) .elementor-widget-container {
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
}

.fpb-shell {
    position: fixed !important;
    inset: 0 !important;
    height: 100dvh !important;
    width: 100vw !important;
    overflow: hidden !important;
    z-index: 999999 !important;
}

body.admin-bar .fpb-shell {
    top: 32px !important;
    height: calc(100dvh - 32px) !important;
}


/* SELLING STEP */
.fpb-commerce-content {
    display: none;
    margin-top: 30px;
    max-width: 1100px;
}

.fpb-commerce-content.show {
    display: block;
    animation: fpbFadeIn .25s ease;
}

.fpb-selling-choice {
    margin-top: 20px;
    margin-bottom: 10px;
}


/* REVIEW STEP */

.fpb-review {
    max-width: 1050px;
    display: grid;
    gap: 18px;
}

.fpb-review-section {
    border-top: 1px solid #d8d1c7;
    padding: 18px 0;
}

.fpb-review-section h3 {
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: 30px !important;
    font-weight: 400 !important;
    margin: 0 0 12px !important;
    color: #111 !important;
}

.fpb-review-section p {
    margin: 6px 0;
    font-size: 14px;
    line-height: 1.5;
}

.fpb-confirm {
    margin-top: 28px !important;
    display: flex !important;
    gap: 12px;
    align-items: flex-start;
    max-width: 780px;
}

.fpb-confirm input {
    width: auto !important;
    min-height: auto !important;
    margin-top: 3px !important;
}

.fpb-confirm span {
    font-size: 13px;
    line-height: 1.5;
    letter-spacing: 0;
    text-transform: none;
    font-weight: 400;
}


/* PREMIUM VALIDATION */

.fpb-error-box {
    max-width: 760px;
    border-top: 1px solid #111;
    border-bottom: 1px solid #d8d1c7;
    padding: 18px 0;
    margin: 0 0 24px;
    animation: fpbFadeIn .25s ease;
}

.fpb-error-box strong {
    display: block;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 28px;
    font-weight: 400;
    letter-spacing: -0.03em;
    margin-bottom: 6px;
}

.fpb-error-box span {
    display: block;
    font-size: 13px;
    margin-bottom: 10px;
}

.fpb-error-box ul {
    margin: 0;
    padding-left: 18px;
}

.fpb-error-box li {
    font-size: 13px;
    line-height: 1.7;
}

.fpb-field-error {
    border-color: #7b1113 !important;
    box-shadow: inset 0 0 0 1px #7b1113 !important;
}

.fpb-shake {
    animation: fpbShake .35s ease;
}

@keyframes fpbShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-4px); }
    50% { transform: translateX(4px); }
    75% { transform: translateX(-3px); }
}

/* LUXURY UPLOAD BOXES */

.fpb-upload {
    max-width: 900px;
    margin-bottom: 22px;
}

.fpb-upload-box {
    border: 1px solid #cfc7bb;
    min-height: 145px;
    display: grid !important;
    place-items: center;
    text-align: center;
    padding: 28px;
    cursor: pointer;
    background: rgba(255,255,255,.35);
    transition: .25s ease;
}

.fpb-upload-box:hover,
.fpb-upload-box.dragging {
    border-color: #111;
    background: #fff;
}

.fpb-upload-box input[type="file"] {
    display: none !important;
}

.fpb-upload-box span {
    font-family: "Playfair Display", Georgia, serif;
    font-size: 28px;
    letter-spacing: -0.03em;
    text-transform: none;
    font-weight: 400;
    color: #111;
}

.fpb-upload-box em {
    display: block;
    font-style: normal;
    font-size: 12px;
    letter-spacing: .18em;
    text-transform: uppercase;
    margin-top: 10px;
    color: #111;
}

.fpb-upload-box small {
    display: block;
    font-size: 11px;
    letter-spacing: .16em;
    text-transform: uppercase;
    margin-top: 8px;
    color: #777;
}

.fpb-upload-list {
    display: grid;
    gap: 8px;
    margin-top: 12px;
}

.fpb-upload-item {
    border-top: 1px solid #d8d1c7;
    padding: 10px 0;
    display: grid;
    grid-template-columns: 24px 1fr auto;
    gap: 10px;
    align-items: center;
    font-size: 13px;
}

.fpb-upload-item span {
    color: #7b1113;
}

.fpb-upload-item strong {
    font-weight: 400;
}

.fpb-upload-item em {
    font-style: normal;
    color: #777;
    font-size: 12px;
}

/* IMAGE UPLOAD PREVIEWS */

.fpb-upload-title {
    margin: 18px 0 12px !important;
    font-size: 10px !important;
    letter-spacing: .24em !important;
    text-transform: uppercase !important;
    font-weight: 700 !important;
    color: #111 !important;
}

.fpb-upload-preview-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-top: 12px;
}

.fpb-upload-preview-item {
    min-width: 0;
}

.fpb-upload-thumb {
    aspect-ratio: 1.35 / 1;
    border: 1px solid #d8d1c7;
    background: #f8f5ef;
    overflow: hidden;
    display: grid;
    place-items: center;
    margin-bottom: 8px;
}

.fpb-upload-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fpb-upload-thumb span {
    font-size: 13px;
    letter-spacing: .25em;
    color: #7b1113;
}

.fpb-upload-preview-item strong {
    display: block;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.fpb-upload-preview-item em {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    font-style: normal;
    color: #777;
}

@media (max-width: 820px) {
    .fpb-upload-preview-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
