@charset "UTF-8";

/* -------------------------------- 

File#: _1_floating-action-button
Title: Floating Action Button
Descr: A floating button representing the primary page action
Usage: codyhouse.co/license

-------------------------------- */
/* Fallback design tokens and utilities (decouple from theme css) */
:root {
    /* Spacing */
    --leadhook-space-3xs: 0.25rem;
    --leadhook-space-2xs: 0.375rem;
    --leadhook-space-xs: 0.5rem;
    --leadhook-space-sm: 0.75rem;
    --leadhook-space-md: 1rem;
    --leadhook-space-lg: 1.5rem;

    /* Typography sizes */
    --leadhook-text-xs: 0.75rem;
    --leadhook-text-sm: 0.875rem;
    --leadhook-text-base: 1.1rem;
    --leadhook-text-md: 1.275rem;
    --leadhook-text-lg: 1.275rem;

    /* Radii */
    --leadhook-radius-md: 8px;

    /* Colors */
    --leadhook-color-white: #ffffff;
    --leadhook-color-bg: #ffffff;
    --leadhook-color-bg-dark: #f6f7f9;
    --leadhook-color-primary: #2563eb;
    --leadhook-color-primary-light: #1d4ed8;
    --leadhook-color-contrast-higher: #111827;
    --leadhook-color-contrast-medium: #6b7280;
    --leadhook-color-contrast-dark: #f2f2f3;
    --leadhook-color-accent: #2563eb;

    /* HSL components used in shadows (safe defaults) */
    --leadhook-color-black-h: 0;
    --leadhook-color-black-s: 0%;
    --leadhook-color-black-l: 0%;
    --leadhook-color-contrast-higher-h: 215;
    --leadhook-color-contrast-higher-s: 28%;
    --leadhook-color-contrast-higher-l: 17%;

    /* Shadows and easing */
    --leadhook-shadow-sm: 0 2px 6px rgba(0, 0, 0, .08);
    --leadhook-shadow-md: 0 12px 24px rgba(0, 0, 0, .16);
    --leadhook-inner-glow-top: 0 1px 0 rgba(255, 255, 255, .35) inset;
    --leadhook-inner-glow: 0 1px 0 rgba(255, 255, 255, .25) inset;
    --leadhook-z-index-overlay: 15;
    --leadhook-ease-out: ease-out;
    --leadhook-ease-in-out: ease-in-out;

    /* HSL components for primary (for hsla utilities) */
    --leadhook-color-primary-h: 221;
    --leadhook-color-primary-s: 83%;
    --leadhook-color-primary-l: 53%;

    /* No aliases: use leadhook-prefixed variables throughout */
}

/* Minimal utility classes used by FAB markup */
.floating-container {
    width: calc(100% - 2 * 16px);
    margin-left: auto;
    margin-right: auto;
}

.floating-max-width {
    max-width: 90rem;
}

.floating-height-100 {
    height: 100%;
}

.position-relative {
    position: relative;
}

.padding-sm {
    padding: var(--leadhook-space-sm);
}

.icon {
    display: inline-block;
    width: 1em;
    height: 1em;
}

:root {





    --fab-transition-duration: .2s;
    /* transition duration */
    --fab-gap-y: var(--leadhook-space-md);
    /* top/bottom gap between button and viewport - horizontal gap depends on the max-width utility class */
    --fab-btn-size: 48px;
    /* button size */
    --fab-btn-radius: calc(var(--fab-btn-size)/2);
    /* button border-radius - use px units */
    --fab-btn-icon-size: 24px;
    /* icon size */
    --fab-popover-radius: 8px;
    /* popover border-radius - use px units */
    --fab-popover-width: 305px;
    /* popover width - from the @xs breakpoint ↓ */
    --fab-popover-gap: 6px
        /* gap between popover and button */
}

@media (min-width: 64rem) {
    :root {
        --fab-btn-size: 54px
    }
}

.floating {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0);
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: background var(--fab-transition-duration), opacity var(--fab-transition-duration), visibility 0s var(--fab-transition-duration)
}

.floating--in {
    opacity: 1;
    visibility: visible;
    transition: background var(--fab-transition-duration), opacity var(--fab-transition-duration)
}

.floating--bottom-right .floating__btn,
.floating--bottom-right .floating__popover,
.floating--bottom-left .floating__btn,
.floating--bottom-left .floating__popover {
    bottom: var(--fab-gap-y);
    bottom: calc(var(--fab-gap-y) + env(safe-area-inset-bottom))
        /* fixes issue on iOS */
}

.floating--bottom-right .floating__popover-inner {
    -webkit-clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 0 calc(100% - var(--fab-btn-size)) round var(--fab-btn-radius));
    clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 0 calc(100% - var(--fab-btn-size)) round var(--fab-btn-radius))
}

@media (min-width: 32rem) {
    .floating--bottom-right .floating__popover-inner {
        -webkit-clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 0 calc(var(--fab-popover-width) - var(--fab-btn-size)) round var(--fab-btn-radius));
        clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 0 calc(var(--fab-popover-width) - var(--fab-btn-size)) round var(--fab-btn-radius))
    }
}

.floating--bottom-left .floating__popover-inner {
    -webkit-clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(100% - var(--fab-btn-size)) 0 0 round var(--fab-btn-radius));
    clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(100% - var(--fab-btn-size)) 0 0 round var(--fab-btn-radius))
}

@media (min-width: 32rem) {
    .floating--bottom-left .floating__popover-inner {
        -webkit-clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(var(--fab-popover-width) - var(--fab-btn-size)) 0 0 round var(--fab-btn-radius));
        clip-path: inset(calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(var(--fab-popover-width) - var(--fab-btn-size)) 0 0 round var(--fab-btn-radius))
    }
}

.floating--bottom-right .floating__btn,
.floating--bottom-right .floating__popover,
.floating--top-right .floating__btn,
.floating--top-right .floating__popover {
    right: 0
}

.floating--bottom-left .floating__btn,
.floating--bottom-left .floating__popover,
.floating--top-left .floating__btn,
.floating--top-left .floating__popover {
    left: 0
}

.floating--top-right .floating__btn,
.floating--top-right .floating__popover,
.floating--top-left .floating__btn,
.floating--top-left .floating__popover {
    top: var(--fab-gap-y)
}

.floating--top-right .floating__popover-inner {
    -webkit-clip-path: inset(0 0 calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(100% - var(--fab-btn-size)) round var(--fab-btn-radius));
    clip-path: inset(0 0 calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(100% - var(--fab-btn-size)) round var(--fab-btn-radius))
}

@media (min-width: 32rem) {
    .floating--top-right .floating__popover-inner {
        -webkit-clip-path: inset(0 0 calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(var(--fab-popover-width) - var(--fab-btn-size)) round var(--fab-btn-radius));
        clip-path: inset(0 0 calc(var(--fab-popover-height) - var(--fab-btn-size)) calc(var(--fab-popover-width) - var(--fab-btn-size)) round var(--fab-btn-radius))
    }
}

.floating--top-left .floating__popover-inner {
    -webkit-clip-path: inset(0 calc(100% - var(--fab-btn-size)) calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 round var(--fab-btn-radius));
    clip-path: inset(0 calc(100% - var(--fab-btn-size)) calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 round var(--fab-btn-radius))
}

@media (min-width: 32rem) {
    .floating--top-left .floating__popover-inner {
        -webkit-clip-path: inset(0 calc(var(--fab-popover-width) - var(--fab-btn-size)) calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 round var(--fab-btn-radius));
        clip-path: inset(0 calc(var(--fab-popover-width) - var(--fab-btn-size)) calc(var(--fab-popover-height) - var(--fab-btn-size)) 0 round var(--fab-btn-radius))
    }
}

/* button */
.floating__btn {
    display: block;
    position: relative;
    pointer-events: auto;
    width: var(--fab-btn-size);
    height: var(--fab-btn-size);
    background-color: var(--color-primary);
    box-shadow: var(--inner-glow-top), var(--shadow-sm);
    border-radius: var(--fab-btn-radius);
    overflow: hidden;
    touch-action: manipulation;
    position: absolute;
    z-index: 2;
    transform: translateY(20px);
    transition: box-shadow var(--fab-transition-duration), background var(--fab-transition-duration), transform var(--fab-transition-duration)
}

.floating__btn:hover {
    background-color: var(--color-primary-light);
    box-shadow: var(--shadow-md)
}

.floating__btn:active {
    transform: translateY(2px)
}

.floating--in .floating__btn {
    transform: translateY(0);
    padding: 0;
}

.floating__icon-wrapper {
    display: flex;
    height: inherit;
    width: inherit;
    justify-content: center;
    align-items: center;
    transition: transform var(--fab-transition-duration) var(--ease-out)
}

.floating__icon-wrapper:last-child {
    position: absolute;
    top: 0;
    transform: translateY(100%)
}

.floating__icon-wrapper:last-child .floating__icon {
    transform: rotate(-45deg);
    opacity: 0
}

.floating--active .floating__icon-wrapper {
    transform: translateY(-100%)
}

.floating--active .floating__icon-wrapper .floating__icon {
    opacity: 0
}

.floating--active .floating__icon-wrapper:last-child {
    transform: translateY(0)
}

.floating--active .floating__icon-wrapper:last-child .floating__icon {
    transform: rotate(0);
    opacity: 1
}

.floating__icon {
    display: block;
    height: var(--fab-btn-icon-size);
    width: var(--fab-btn-icon-size);
    margin: auto;
    color: var(--color-white);
    fill: currentColor;
    line-height: 1;
    flex-shrink: 0;
    max-width: initial;
    /* icon color */
    transition: transform var(--fab-transition-duration) var(--ease-in-out), opacity var(--fab-transition-duration)
}

/* popover */
.floating__popover {
    position: absolute;
    z-index: 1;
    filter: drop-shadow(0 2px 5px hsla(0deg, 0%, 0%, 0.2));
    width: 100%
        /* full-width on smaller devices */
}

@media (min-width: 32rem) {
    .floating__popover {
        width: var(--fab-popover-width)
    }
}

.floating__popover-inner {
    max-height: calc(100vh - var(--fab-gap-y) * 2 - var(--fab-btn-size));
    overflow: auto;
    background-color: var(--color-bg);
    visibility: hidden;
    transform: translateY(0);
    transition: transform var(--fab-transition-duration) var(--ease-out), visibility 0s var(--fab-transition-duration), -webkit-clip-path var(--fab-transition-duration) var(--ease-out);
    transition: clip-path var(--fab-transition-duration) var(--ease-out), transform var(--fab-transition-duration) var(--ease-out), visibility 0s var(--fab-transition-duration);
    transition: clip-path var(--fab-transition-duration) var(--ease-out), transform var(--fab-transition-duration) var(--ease-out), visibility 0s var(--fab-transition-duration), -webkit-clip-path var(--fab-transition-duration) var(--ease-out)
}

.floating__content {
    padding: calc(1.125 * 1rem);
    opacity: 0;
    transition: opacity var(--fab-transition-duration), transform var(--fab-transition-duration)
}

/* --active */
.floating--active {
    background-color: hsl(0deg 0% 0% / 80%);
    pointer-events: auto
}

.floating--active .floating__popover-inner {
    visibility: visible;
    transform: translateY(calc(-1 * var(--fab-btn-size) - var(--fab-popover-gap)));
    -webkit-clip-path: inset(0 0 0 0 round var(--fab-popover-radius));
    clip-path: inset(0 0 0 0 round var(--fab-popover-radius));
    transition: transform var(--fab-transition-duration) var(--ease-out), visibility 0s, -webkit-clip-path var(--fab-transition-duration) var(--ease-out);
    transition: clip-path var(--fab-transition-duration) var(--ease-out), transform var(--fab-transition-duration) var(--ease-out), visibility 0s;
    transition: clip-path var(--fab-transition-duration) var(--ease-out), transform var(--fab-transition-duration) var(--ease-out), visibility 0s, -webkit-clip-path var(--fab-transition-duration) var(--ease-out)
}

.floating--active.floating--top-left .floating__popover-inner,
.floating--active.floating--top-right .floating__popover-inner {
    transform: translateY(calc(var(--fab-btn-size) + var(--fab-popover-gap)))
}

.floating--active .floating__content {
    opacity: 1
}



/* menu example */
.floating--has-demo-menu {
    --fab-popover-width: 300px
}

.floating-grid {
    grid-gap: 1rem;
    position: relative;
    display: grid;
}

.floating__socal {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: .5rem;
}

.floating__socal-bbt {
    background-color: var(--leadhook-color-contrast-dark);
    padding: .5rem 1rem;
    border-radius: .6rem;
    display: flex;
    align-items: center;
}

.floating__socal-bbt:hover {
    opacity: .8;
}

.floating__socal-bbt .socal-icon {

}

.socal-icon-tg {
    color: #27a7e7;
}

.socal-icon-wa {
    color: #128c7e  ;
}

.socal-icon-vk {
    color: #0077ff;
}

.socal-icon-max {
    fill: #7535e4;
}

.floating__socal-bbt span {
    font-size: var(--leadhook-text-xs);
    font-weight: 500;
    color: var(--leadhook-color-contrast-higher);
    padding-left: .4rem;
}


.lh-floating-phone {
    font-size: 1.65rem;
    font-weight: 500;
    line-height: 1;
}

.bbt-floating {
    background-color: var(--leadhook-color-primary);
    color: var(--leadhook-color-bg);
    width: 100%;
    padding: 1.1em 1.6rem;
    height: auto;
    line-height: 1;
    border: 0;
    outline: none;
}

.bbt-floating {
    background-color: var(--leadhook-color-primary-light);
    color: var(--leadhook-color-bg);
}

.floating__menu {
    list-style: none;
    padding: var(--leadhook-space-3xs)
}

.floating__menu-btn {
    position: relative;
    display: flex;
    align-items: center;
    padding: var(--leadhook-space-2xs);
    border-radius: var(--leadhook-radius-md);
    cursor: pointer;
    line-height: 1;
    color: inherit;
    text-decoration: none
}

.floating__menu-btn::before,
.floating__menu-btn::after {
    content: "";
    position: absolute;
    z-index: 1
}

.floating__menu-btn::before {
    inset: 0;
    border-radius: inherit;
    background-color: var(--color-bg-dark);
    opacity: 0;
    transform: scale(0.75);
    transition: 0.1s
}

.floating__menu-btn::after {
    width: calc(100% - var(--leadhook-space-2xs) * 2);
    height: 1px;
    left: var(--leadhook-space-2xs);
    top: 100%;
    background: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075)
}

.floating__menu-btn:hover::before {
    opacity: 1;
    transform: scale(1)
}

.floating__menu-btn:hover::after {
    display: none
}

.floating__menu-btn:focus-visible {
    outline: none
}

.floating__menu-btn:focus-visible::before {
    opacity: 1;
    transform: scale(1);
    box-shadow: inset 0 0 0 2px var(--color-primary);
    transition: none;
    background-color: var(--color-bg)
}

.floating__menu-item:nth-last-child(2) .floating__menu-btn::after {
    display: none
}



.floating__header {
    font-size: var(--leadhook-text-md);
    font-weight: 700;
    padding-bottom: 1.2rem;
    line-height: 1.1;
}

.floating__menu-img {
    --size: 40px;
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    flex-shrink: 0;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1)
}

.floating__menu-title,
.floating-label {
    font-weight: 500;
    color: var(--leadhook-color-contrast-medium);
    font-size: var(--leadhook-text-xs)
}

.floating-label {
    padding-bottom: .4rem;
}

.floating__menu-time,
.floating__menu-preview,
.floating__menu-unread-counter {
    font-size: var(--leadhook-text-xs)
}

.floating__menu-time,
.floating__menu-preview {
    color: var(--color-contrast-medium)
}

.floating__menu-time {
    text-align: right
}

.floating__menu-unread-counter {
    width: 18px;
    height: 18px;
    background-color: var(--color-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
    box-shadow: var(--inner-glow), 0 1px 3px hsla(var(--color-accent-darker-h), var(--color-accent-darker-s), var(--color-accent-darker-l), 0.35)
}

.floating__menu-cta {
    display: flex;
    align-items: center;
    gap: var(--leadhook-space-2xs);
    justify-content: center;
    font-size: var(--text-sm);
    background: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
    color: var(--color-primary);
    font-weight: 600;
    text-decoration: none;
    padding: var(--leadhook-space-sm) 0;
    border-radius: var(--leadhook-radius-md);
    line-height: 1
}

.floating__menu-cta:hover {
    background: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.15)
}

.floating__menu-cta:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--color-primary)
}

.floating__menu-item:last-child {
    margin-top: var(--leadhook-space-3xs)
}


