/* --- Trigger Button --- */
.gk-share-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 16px;
    border: 1px solid #e5e7eb;
    background: #fff;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-family: inherit;
    line-height: 1;
    position: relative;
    text-decoration: none;
}

/* --- Tooltip (Reusable) --- */
.gk-tooltip-container { --gk-tooltip-bg: #333; }
.gk-tooltip-container[data-tooltip]:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    background: var(--gk-tooltip-bg);
    color: #fff;
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 1;
    visibility: visible;
    z-index: 100;
    pointer-events: none;
    line-height: 1.4;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}
.gk-tooltip-container[data-tooltip]:hover::before {
    content: ''; position: absolute; border: 6px solid transparent; z-index: 100; pointer-events: none;
}
/* Directions */
.gk-tooltip-container[data-tooltip-pos="top"]:hover::after { bottom: 100%; left: 50%; transform: translateX(-50%) translateY(-10px); }
.gk-tooltip-container[data-tooltip-pos="top"]:hover::before { bottom: 100%; left: 50%; transform: translateX(-50%) translateY(-4px); border-top-color: var(--gk-tooltip-bg); }
.gk-tooltip-container[data-tooltip-pos="bottom"]:hover::after { top: 100%; left: 50%; transform: translateX(-50%) translateY(10px); }
.gk-tooltip-container[data-tooltip-pos="bottom"]:hover::before { top: 100%; left: 50%; transform: translateX(-50%) translateY(4px); border-bottom-color: var(--gk-tooltip-bg); }
.gk-tooltip-container[data-tooltip-pos="right"]:hover::after { top: 50%; left: 100%; transform: translateY(-50%) translateX(10px); }
.gk-tooltip-container[data-tooltip-pos="right"]:hover::before { top: 50%; left: 100%; transform: translateY(-50%) translateX(4px); border-right-color: var(--gk-tooltip-bg); }
.gk-tooltip-container[data-tooltip-pos="left"]:hover::after { top: 50%; right: 100%; transform: translateY(-50%) translateX(-10px); }
.gk-tooltip-container[data-tooltip-pos="left"]:hover::before { top: 50%; right: 100%; transform: translateY(-50%) translateX(-4px); border-left-color: var(--gk-tooltip-bg); }


/* --- Modal Structure --- */
.gk-share-modal {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gk-share-overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
    transition: all 0.3s;
    cursor: pointer;
}

.gk-share-dialog {
    position: relative;
    background: #fff;
    width: 450px;
    max-width: 90%;
    border-radius: 12px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.2);
    display: flex;
    flex-direction: column;
    z-index: 100000;
    overflow: hidden;
}

/* --- Modal Content --- */
.gk-share-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    border-bottom: 1px solid #eee;
}
.gk-share-title { margin: 0; font-size: 16px; font-weight: 700; color: #333; }
.gk-share-close {
    background: none; border: none; font-size: 24px; cursor: pointer; color: #999; line-height: 1; padding: 0;
}
.gk-share-close:hover { color: #333; }

.gk-share-body { padding: 25px 20px; }

/* Networks Grid */
.gk-share-networks {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    justify-content: center;
    margin-bottom: 25px;
}

.gk-share-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border-radius: 12px;
    color: #fff;
    font-size: 22px;
    transition: transform 0.2s, opacity 0.2s;
    text-decoration: none;
}
.gk-share-link:hover { transform: translateY(-3px); opacity: 0.9; }

/* Network Colors */
.gk-net-whatsapp { background: #25D366; }
.gk-net-telegram { background: #229ED9; }
.gk-net-twitter  { background: #000000; }
.gk-net-facebook { background: #1877F2; }

/* Copy Box */
.gk-share-copy-box {
    display: flex;
    align-items: center;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 5px;
    background: #f9f9f9;
}
.gk-share-input {
    flex-grow: 1;
    border: none;
    background: transparent;
    padding: 8px;
    font-size: 13px;
    color: #555;
    outline: none;
    width: 100%;
}
.gk-share-copy-btn {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 6px;
    width: 36px;
    height: 36px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #666;
    transition: all 0.2s;
}
.gk-share-copy-btn:hover { border-color: #aaa; color: #333; }

/* Editor Fix */
.elementor-editor-active .gk-share-modal {
    position: absolute; z-index: 1000; height: auto; min-height: 300px; background: rgba(0,0,0,0.05);
}
