@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

-------------------------------- */

/* 
   FIX 1: Все переменные собраны в одном блоке :root.
   FIX 2: Исправлены ссылки на цвета: вместо несуществующих --color-* теперь используются --leadhook-color-*.
   FIX 3: Убраны лишние пробелы в значениях цветов.
*/
: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 - Brand & UI */
    --leadhook-color-white: #ffffff;
    --leadhook-color-bg: #ffffff;
    --leadhook-color-bg-dark: #f6f7f9;
    --leadhook-color-primary: #9a761e;
    --leadhook-color-primary-light: #b78e28;
    --leadhook-color-contrast-higher: #111827;
    --leadhook-color-contrast-medium: #6b7280;
    --leadhook-color-contrast-dark: #f2f2f3;
    --leadhook-color-accent: #2563eb;
    
    /* FIX: Добавлены определения для черных оттенков, которые использовались в оригинале, но не были объявлены */
    --leadhook-color-black-h: 0;
    --leadhook-color-black-s: 0%;
    --leadhook-color-black-l: 0%;

    /* 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;

    /* FAB Component Tokens */
    --fab-transition-duration: .2s;
    --fab-gap-y: var(--leadhook-space-md);
    --fab-btn-size: 48px;
    --fab-btn-radius: calc(var(--fab-btn-size)/2);
    --fab-btn-icon-size: 24px;
    --fab-popover-radius: 8px;
    --fab-popover-width: 305px;
    --fab-popover-gap: 6px;
}

@media (min-width: 64rem) {
    :root {
        --fab-btn-size: 54px;
    }
}

/* 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;
}

/* Core Floating Component Styles */
.floating {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    /* FIX: Использованы объявленные leadhook-переменные для цвета фона */
    background-color: hsla(var(--leadhook-color-black-h), var(--leadhook-color-black-s), var(--leadhook-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);
}

/* Positioning Logic */
.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));
}

.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 Styles */
.floating__btn {
    display: block;
    position: relative;
    pointer-events: auto;
    width: var(--fab-btn-size);
    height: var(--fab-btn-size);
    background-color: var(--leadhook-color-primary-light);
    box-shadow: var(--leadhook-inner-glow-top), var(--leadhook-shadow-sm);
    border-radius: var(--fab-btn-radius);
    overflow: hidden;
    touch-action: manipulation;
    position: absolute;
    z-index: 2;
    border: 0 none;
    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(--leadhook-color-primary);
    box-shadow: var(--leadhook-shadow-md);
}

.floating__btn:active {
    transform: translateY(2px);
}

.floating--in .floating__btn {
    transform: translateY(0);
    padding: 0;
    outline: 0;
}

.floating__icon-wrapper {
    display: flex;
    height: inherit;
    width: inherit;
    justify-content: center;
    align-items: center;
    transition: transform var(--fab-transition-duration) var(--leadhook-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(--leadhook-color-white);
    fill: currentColor;
    line-height: 1;
    flex-shrink: 0;
    max-width: initial;
    transition: transform var(--fab-transition-duration) var(--leadhook-ease-in-out), opacity var(--fab-transition-duration);
}

/* Popover Styles */
.floating__popover {
    position: absolute;
    z-index: 1;
    filter: drop-shadow(0 2px 5px hsla(0deg, 0%, 0%, 0.2));
    width: 100%;
}

@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(--leadhook-color-bg);
    visibility: hidden;
    transform: translateY(0);
    /* FIX: Оптимизированы transition для clip-path */
    transition: clip-path var(--fab-transition-duration) var(--leadhook-ease-out), transform var(--fab-transition-duration) var(--leadhook-ease-out), visibility 0s var(--fab-transition-duration);
}

.floating__content {
    padding: calc(1.125 * 1rem);
    opacity: 0;
    transition: opacity var(--fab-transition-duration), transform var(--fab-transition-duration);
}

/* --active state */
.floating--active {
    /* FIX: Использован leadhook-color-black для фона */
    background-color: hsl(var(--leadhook-color-black-h), var(--leadhook-color-black-s), var(--leadhook-color-black-l) / 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: clip-path var(--fab-transition-duration) var(--leadhook-ease-out), transform var(--fab-transition-duration) var(--leadhook-ease-out), visibility 0s;
}

.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 & Social Demo Styles */
.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;
}

.socal-icon-tg { color: #27a7e7; }
.socal-icon-wa { color: #128c7e; } /* FIX: Убраны лишние пробелы */
.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;
}

/* FIX 4: Убрано дублирование .bbt-floating. Оставлен вариант с primary-light, так как он был последним в исходнике. */
.bbt-floating {
    background-color: var(--leadhook-color-primary-light);
    color: var(--leadhook-color-bg);
    width: 100%;
    padding: 1.1em 1.6rem;
    height: auto;
    line-height: 1;
    border: 0;
    outline: 0;
}

.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(--leadhook-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%;
    /* FIX: Использована правильная переменная contrast-higher */
    background: hsla(var(--leadhook-color-contrast-higher-h, 221), var(--leadhook-color-contrast-higher-s, 83%), var(--leadhook-color-contrast-higher-l, 53%), 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(--leadhook-color-primary-light);
    transition: none;
    background-color: var(--leadhook-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%;
    object-fit: cover;
    flex-shrink: 0;
    background-color: hsla(var(--leadhook-color-contrast-higher-h, 221), var(--leadhook-color-contrast-higher-s, 83%), var(--leadhook-color-contrast-higher-l, 53%), 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(--leadhook-color-contrast-medium);
}

.floating__menu-time {
    text-align: right;
}

.floating__menu-unread-counter {
    width: 18px;
    height: 18px;
    /* FIX: Использована правильная переменная accent */
    background-color: var(--leadhook-color-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--leadhook-color-white);
    box-shadow: var(--leadhook-inner-glow), 0 1px 3px hsla(var(--leadhook-color-accent-h, 221), var(--leadhook-color-accent-s, 83%), var(--leadhook-color-accent-l, 53%), 0.35);
}

.floating__menu-cta {
    display: flex;
    align-items: center;
    gap: var(--leadhook-space-2xs);
    justify-content: center;
    /* FIX: Использована правильная переменная text-sm */
    font-size: var(--leadhook-text-sm);
    background: var(--leadhook-color-primary);
    color: var(--leadhook-color-primary-light);
    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: var(--leadhook-color-primary);
}

.floating__menu-cta:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--leadhook-color-primary-light);
}

.floating__menu-item:last-child {
    margin-top: var(--leadhook-space-3xs);
}

button:focus {
    outline: 0;
}

