/* header.css */

/* ---------- Theme Variables ---------- */
:root {
    --theme-bg: #ffffff;
    --theme-text: #000000;
    --theme-accent: #752D42;
    /* top bar + accents */
    --theme-btn: #20385c;
    /* filled buttons */
    --theme-border: #e9ecef;

    /* convenience */
    --white: #ffffff;
    --black: #000000;

    /* derived mixes (for hovers, subtle fills) */
    --accent-10: color-mix(in srgb, var(--theme-accent) 10%, transparent);
    --btn-hover: color-mix(in srgb, var(--theme-btn) 85%, var(--black) 15%);
}

/* ---------- Fonts ---------- */
@font-face {
    font-family: 'GilroyM';
    src: url('fonts/Gilroy-Medium.woff2') format('woff2'),
        url('fonts/Gilroy-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

body {
    font-family: 'Raleway', Helvetica, Arial, sans-serif;
    background: var(--theme-bg);
    color: var(--theme-text);
}

.font-gilroy {
    font-family: 'GilroyM', 'Raleway', Helvetica, Arial, sans-serif;
}

/* ---------- Top bar ---------- */
.cm-topbar {
    background: var(--theme-accent);
    color: var(--white);
    font-size: 11px;
    /* per request */
}

/* ---------- Header ---------- */
.cm-header {
    background: var(--theme-bg);
    border-bottom: 1px solid var(--theme-border);
}

/* Branding */
.cm-brand img {
    height: 40px;
}

/* ---------- Nav (Desktop) ---------- */
.navbar-nav .nav-link {
    color: var(--theme-text);
    font-weight: 500;
    font-size: 12px;
    /* per request */
    padding: .75rem .9rem;
    transition: color .2s ease;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
    color: var(--theme-accent);
}

/* Underline accent hover */
.nav-link.cm-underline {
    position: relative;
}

.nav-link.cm-underline::after {
    content: "";
    position: absolute;
    left: .9rem;
    right: .9rem;
    bottom: .35rem;
    height: 2px;
    background: var(--theme-accent);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform .25s ease;
}

.nav-link.cm-underline:hover::after {
    transform: scaleX(1);
}

/* Dropdowns */
.navbar-nav .dropdown-menu {
    border-radius: .5rem;
    border: 1px solid var(--theme-border);
    box-shadow: 0 10px 30px color-mix(in srgb, var(--black) 12%, transparent);
    padding: .4rem;
    background: var(--white);
}

.navbar-nav .dropdown-item {
    padding: .5rem .75rem;
    color: var(--theme-text);
}

.navbar-nav .dropdown-item:hover {
    background: var(--accent-10);
    color: var(--theme-accent);
}



/* ---------- Icon buttons (if any) ---------- */
.cm-icon-btn {
    border: none;
    background: transparent;
    color: var(--theme-text);
    padding: .5rem;
    margin-left: .25rem;
    transition: color .2s ease;
}

.cm-icon-btn:hover {
    color: var(--theme-accent);
}

/* ---------- Offcanvas (Mobile Menu) ---------- */
.offcanvas.cm-offcanvas {
    width: 320px;
    background: var(--white);
    color: var(--theme-text);
}

.cm-offcanvas .list-group-item {
    border: none;
    border-bottom: 1px solid var(--theme-border);
    padding: .85rem 0;
    background: var(--white);
    color: var(--theme-text);
}

.cm-offcanvas .accordion-button {
    padding-left: 0;
    background: transparent;
    color: var(--theme-text);
}

.cm-offcanvas .accordion-button:not(.collapsed) {
    color: var(--theme-accent);
    box-shadow: none;
}

/* Center brand logo on mobile */
@media (max-width: 991.98px) {
    .navbar {
        min-height: 58px;
    }

    /* keeps bar tall enough */
    .navbar .container {
        position: relative;
    }

    /* anchor for absolute centering */

    .cm-brand {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        /* perfect center */
        z-index: 2;
        /* above background, below controls */
    }

    /* keep left burger + right search where they are */
    .navbar .d-lg-none.ms-auto {
        margin-left: auto;
    }
}





/* ---------- Buttons ---------- */
.btn {
    font-family: inherit;
}

.btn-theme {
    background: var(--theme-btn);
    color: var(--white);
    border: none;
}

.btn-theme:hover {
    background: var(--btn-hover);
    color: var(--white);
}

/* ---------- Search ---------- */
.cm-search .form-control {
    border-color: var(--theme-border);
    color: var(--theme-text);
    background: var(--white);
}

.cm-search .form-control::placeholder {
    color: color-mix(in srgb, var(--theme-text) 50%, var(--white));
}













/*  */
/* ==============================
   ABOUT + SUBSCRIBE — FULL CSS
   ============================== */
.cm-about-subscribe {
    padding: clamp(28px, 6vw, 56px) 0;
    background: var(--white, #fff);
    border-bottom: 3px solid var(--theme-accent, #752D42);
}

/* Title + paragraph */
.cms-title {
    margin: 0 0 .35rem;
    font-weight: 800;
    color: var(--theme-text, #000);
}

.cms-copy {
    margin: 0;
    color: color-mix(in srgb, var(--theme-text, #000) 78%, var(--white, #fff));
    font-size: clamp(13px, 1.05vw, 15px);
    line-height: 1.7;
}

/* LEFT: envelope + copy aligned like the reference */
.cms-left {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    column-gap: clamp(12px, 2vw, 18px);
}

.cms-envelope-ico {
    font-size: clamp(72px, 8vw, 110px);
    color: var(--theme-accent, #752D42);
    line-height: 1;
    filter: drop-shadow(0 6px 18px rgba(0, 0, 0, .08));
}

.cms-subtitle {
    margin: 0 0 .25rem;
    font-weight: 700;
    color: var(--theme-text, #000);
}

.cms-subcopy {
    margin: 0;
    color: color-mix(in srgb, var(--theme-text, #000) 70%, var(--white, #fff));
    font-size: 14px;
}

/* RIGHT: input (underline style) + pill button on one line */
.cms-form {
    display: grid;
    grid-template-columns: minmax(320px, 1fr) auto;
    align-items: center;
    column-gap: clamp(12px, 2vw, 18px);
}

.cms-input {
    position: relative;
}

.cms-input i {
    position: absolute;
    left: 6px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: color-mix(in srgb, var(--theme-text, #000) 50%, var(--white, #fff));
}

.cms-input input {
    width: 100%;
    height: 42px;
    /* match button height */
    padding-left: 32px;
    /* space for icon */
    border: 0;
    border-bottom: 2px solid color-mix(in srgb, var(--theme-border, #e9ecef) 70%, var(--black, #000) 30%);
    background: transparent;
    outline: none;
    color: var(--theme-text, #000);
    font-size: 15px;
}

.cms-input input::placeholder {
    color: color-mix(in srgb, var(--theme-text, #000) 55%, var(--white, #fff));
}

.cms-input input:focus {
    border-bottom-color: var(--theme-accent, #752D42);
}

/* Pill subscribe button */
.btn-accent-pill {
    height: 42px;
    padding: 0 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--theme-accent, #752D42);
    color: var(--white, #fff);
    border: 0;
    text-transform: uppercase;
    letter-spacing: .35px;
    font-weight: 800;
    font-size: .82rem;
    box-shadow: 0 10px 22px rgba(0, 0, 0, .12);
    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}

.btn-accent-pill:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
    filter: brightness(1.03);
}

.btn-accent-pill:active {
    transform: translateY(1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, .16);
}

/* Responsive stack for small screens */
@media (max-width: 575.98px) {
    .cms-left {
        grid-template-columns: 1fr;
        row-gap: 8px;
        text-align: center;
    }

    .cms-envelope-ico {
        margin-inline: auto;
    }

    .cms-form {
        grid-template-columns: 1fr;
        row-gap: 12px;
    }

    .btn-accent-pill {
        width: max-content;
        margin-inline: auto;
    }
}






/* Footer */
/* =========================
   FOOTER — FULL CSS
   ========================= */
.site-footer {
    --ft-bg: color-mix(in srgb, var(--theme-accent, #752D42) 92%, #000 8%);
    --ft-text: rgba(255, 255, 255, .92);
    --ft-muted: rgba(255, 255, 255, .75);
    --ft-border: color-mix(in srgb, #fff 20%, #000 80%);
    position: relative;
    color: var(--ft-text);
    background: var(--ft-bg);
    padding-top: clamp(28px, 5vw, 48px);
    padding-bottom: clamp(18px, 4vw, 28px);
    overflow: hidden;
}

/* faint corner ornaments (optional look like the screenshot) */
.site-footer::before,
.site-footer::after {
    content: "";
    position: absolute;
    width: 520px;
    height: 520px;
    background: radial-gradient(closest-side, rgba(255, 255, 255, .08), transparent 70%);
    filter: blur(1px);
    pointer-events: none;
}

.site-footer::before {
    left: -220px;
    top: -120px;
}

.site-footer::after {
    right: -220px;
    bottom: -200px;
    transform: scale(.95);
}

/* headings + lists */
.ft-h {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 .5rem;
}

.ft-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ft-list li {
    margin: .35rem 0;
}

.ft-list a {
    color: var(--ft-muted);
    text-decoration: none;
}

.ft-list a:hover {
    color: #fff;
}

/* contact */
.ft-contact {
    margin: 0;
    font-style: normal;
    color: var(--ft-muted);
}

.ft-contact a {
    color: var(--ft-text);
    text-decoration: none;
}

.ft-contact a:hover {
    text-decoration: underline;
}

/* divider */
.ft-divider {
    border: 0;
    height: 1px;
    background: rgba(255, 255, 255, .15);
    margin: clamp(16px, 4vw, 28px) 0;
}

/* bottom bar */
.footer-bottom {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 12px;
}

.ft-copy {
    text-align: center;
    color: var(--ft-muted);
    font-size: .95rem;
}

/* social icons */
.ft-social {
    display: flex;
    gap: 14px;
    align-items: center;
    margin: 0;
    padding: 0;
    list-style: none;
}

.ft-social a {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #fff;
    text-decoration: none;
    border: 1px solid rgba(255, 255, 255, .4);
    transition: transform .15s ease, background .15s ease, border-color .15s;
}

.ft-social a:hover {
    background: rgba(255, 255, 255, .15);
    transform: translateY(-1px);
    border-color: #fff;
}

/* payments (placeholder pills) */
.ft-payments {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}



.ft-payments {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    align-items: center;
}

.pay {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 8px;
    min-width: 58px;
    height: 26px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .12);
}


.pay img {
    display: block;
    height: 16px;
    width: auto;
    object-fit: contain;
}


@media (max-width: 767.98px) {
    .footer-bottom {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .ft-payments {
        justify-content: center;
    }
}

/* ---------- Sticky buttons ---------- */
.float-whatsapp,
.float-top {
    position: fixed;
    z-index: 999;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    box-shadow: 0 12px 26px rgba(0, 0, 0, .22);
}

/* WhatsApp (bottom-left) */
.float-whatsapp {
    left: 16px;
    bottom: 16px;
    background: #25D366;
    color: #fff;
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease;
}

.float-whatsapp i {
    font-size: 28px;
    line-height: 1;
}

.float-whatsapp:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 32px rgba(0, 0, 0, .28);
}

/* Scroll-to-top (bottom-right) */
.float-top {
    right: 16px;
    bottom: 16px;
    background: rgba(255, 255, 255, .92);
    color: #333;
    border: 1px solid rgba(0, 0, 0, .08);
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px);
    transition: opacity .2s ease, transform .2s ease;
}

.float-top i {
    font-size: 24px;
    line-height: 1;
}

.float-top.show {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

@media (min-width: 992px) {

    .float-whatsapp,
    .float-top {
        width: 56px;
        height: 56px;
    }

    .float-whatsapp {
        left: 22px;
        bottom: 22px;
    }

    .float-top {
        right: 22px;
        bottom: 22px;
    }
}

/* responsive columns spacing */
.footer-columns>[class*="col-"] .ft-h {
    margin-top: 2px;
}

.footer-columns>[class*="col-"] {
    min-width: 220px;
}