/**
 * 3Syxty Studio — Tooltip & Popover Components
 *
 * Informational tooltips on hover/focus and contextual floating
 * panels anchored to triggers. CSS-driven positioning with
 * JS enhancement for edge detection.
 */

/* -----------------------------------------------------------------------
   Tooltip
   ----------------------------------------------------------------------- */

.tooltip-trigger {
    position: relative;
    display: inline-flex;
}

.tooltip {
    position: absolute;
    padding: var(--space-1-5) var(--space-2-5);
    font: var(--type-caption);
    color: #FFFFFF;
    background-color: var(--surface-invert);
    border-radius: var(--radius-md);
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    z-index: var(--z-tooltip);
    transition: opacity var(--motion-fast), transform var(--motion-fast);
    max-width: 280px;
}

.tooltip-multiline {
    white-space: normal;
    text-align: center;
    line-height: 1.4;
}

/* Arrow */
.tooltip::after {
    content: '';
    position: absolute;
    width: 8px;
    height: 8px;
    background-color: var(--surface-invert);
    transform: rotate(45deg);
}

/* Positions */
.tooltip-top {
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
}
.tooltip-top::after {
    bottom: -4px;
    left: 50%;
    margin-left: -4px;
}

.tooltip-bottom {
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
}
.tooltip-bottom::after {
    top: -4px;
    left: 50%;
    margin-left: -4px;
}

.tooltip-left {
    right: calc(100% + 8px);
    top: 50%;
    transform: translateY(-50%) translateX(4px);
}
.tooltip-left::after {
    right: -4px;
    top: 50%;
    margin-top: -4px;
}

.tooltip-right {
    left: calc(100% + 8px);
    top: 50%;
    transform: translateY(-50%) translateX(-4px);
}
.tooltip-right::after {
    left: -4px;
    top: 50%;
    margin-top: -4px;
}

/* Show states */
.tooltip-trigger:hover .tooltip,
.tooltip-trigger:focus-within .tooltip,
.tooltip[data-visible="true"],
.tooltip.tooltip-visible {
    opacity: 1;
}

.tooltip-trigger:hover .tooltip-top,
.tooltip-trigger:focus-within .tooltip-top,
.tooltip-top[data-visible="true"] {
    transform: translateX(-50%) translateY(0);
}

.tooltip-trigger:hover .tooltip-bottom,
.tooltip-trigger:focus-within .tooltip-bottom,
.tooltip-bottom[data-visible="true"] {
    transform: translateX(-50%) translateY(0);
}

.tooltip-trigger:hover .tooltip-left,
.tooltip-trigger:focus-within .tooltip-left,
.tooltip-left[data-visible="true"] {
    transform: translateY(-50%) translateX(0);
}

.tooltip-trigger:hover .tooltip-right,
.tooltip-trigger:focus-within .tooltip-right,
.tooltip-right[data-visible="true"] {
    transform: translateY(-50%) translateX(0);
}

/* JS-driven tooltip (appended to body, positioned with getBoundingClientRect) */
.tooltip.tooltip-visible {
    position: fixed;
    transform: none;
}

.tooltip.tooltip-visible[data-position="top"]::after {
    bottom: -4px;
    left: 50%;
    margin-left: -4px;
    top: auto;
}

.tooltip.tooltip-visible[data-position="bottom"]::after {
    top: -4px;
    left: 50%;
    margin-left: -4px;
}

.tooltip.tooltip-visible[data-position="left"]::after {
    right: -4px;
    top: 50%;
    margin-top: -4px;
    left: auto;
}

.tooltip.tooltip-visible[data-position="right"]::after {
    left: -4px;
    top: 50%;
    margin-top: -4px;
}

/* Keyboard shortcut hint inside tooltip */
.tooltip-kbd {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    margin-left: var(--space-2);
    padding: 1px 4px;
    font: var(--type-overline);
    font-size: 10px;
    background-color: rgba(255, 255, 255, 0.15);
    border-radius: 3px;
    letter-spacing: 0.02em;
}

/* -----------------------------------------------------------------------
   Rich Tooltip (Contextual Help Card)
   ----------------------------------------------------------------------- */

.tooltip-rich {
    position: fixed;
    z-index: var(--z-tooltip);
    min-width: 240px;
    max-width: 320px;
    padding: 0;
    background: var(--surface-elevated);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-heavy), 0 0 0 1px rgba(0, 0, 0, 0.04);
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px) scale(0.97);
    transition: opacity 180ms ease, transform 180ms ease;
    overflow: hidden;
}

.tooltip-rich.tooltip-rich-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

/* Accent bar at top */
.tooltip-rich::before {
    content: '';
    display: block;
    height: 3px;
    background: var(--accent-gradient);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

/* Arrow */
.tooltip-rich-arrow {
    position: absolute;
    width: 10px;
    height: 10px;
    background: var(--surface-elevated);
    border: 1px solid var(--border-subtle);
    transform: rotate(45deg);
    z-index: -1;
}

.tooltip-rich[data-pos="top"] .tooltip-rich-arrow {
    bottom: -6px;
    border-top: none;
    border-left: none;
}

.tooltip-rich[data-pos="bottom"] .tooltip-rich-arrow {
    top: -3px;
    border-bottom: none;
    border-right: none;
}

.tooltip-rich[data-pos="left"] .tooltip-rich-arrow {
    right: -6px;
    border-top: none;
    border-right: none;
    transform: rotate(-45deg);
}

.tooltip-rich[data-pos="right"] .tooltip-rich-arrow {
    left: -6px;
    border-bottom: none;
    border-left: none;
    transform: rotate(-45deg);
}

/* Content layout */
.tooltip-rich-content {
    padding: var(--space-3) var(--space-4);
}

.tooltip-rich-header {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2-5);
    margin-bottom: var(--space-2);
}

.tooltip-rich-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    background: var(--accent-primary-subtle);
    color: var(--accent-primary);
    flex-shrink: 0;
}

.tooltip-rich-icon svg {
    width: 16px;
    height: 16px;
}

.tooltip-rich-title {
    font: var(--type-body-sm);
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.3;
    margin-top: 2px;
}

.tooltip-rich-desc {
    font: var(--type-caption);
    color: var(--text-secondary);
    line-height: 1.55;
    margin: 0;
}

/* Tip callout */
.tooltip-rich-tip {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    margin-top: var(--space-2-5);
    padding: var(--space-2) var(--space-2-5);
    border-radius: var(--radius-sm);
    background: var(--info-subtle);
    font: var(--type-caption);
    color: var(--text-secondary);
    line-height: 1.45;
}

.tooltip-rich-tip-icon {
    color: var(--accent-primary);
    flex-shrink: 0;
    margin-top: 1px;
}

.tooltip-rich-tip-icon svg {
    width: 14px;
    height: 14px;
}

/* Shortcut row */
.tooltip-rich-shortcut {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-2-5);
    font: var(--type-caption);
    color: var(--text-muted);
}

.tooltip-rich-shortcut kbd {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    font: var(--type-mono);
    font-size: 11px;
    color: var(--text-secondary);
    background: var(--surface-tertiary);
    border: 1px solid var(--border-subtle);
    border-radius: 4px;
    line-height: 1.6;
}

/* Footer with link */
.tooltip-rich-footer {
    padding: var(--space-2) var(--space-4);
    border-top: 1px solid var(--border-subtle);
    background: var(--surface-secondary);
}

.tooltip-rich-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font: var(--type-caption);
    font-weight: 500;
    color: var(--accent-primary);
    text-decoration: none;
    transition: opacity var(--motion-instant);
}

.tooltip-rich-link:hover {
    opacity: 0.8;
}

.tooltip-rich-link svg {
    width: 12px;
    height: 12px;
}

/* Help toggle button */
.help-toggle {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    color: var(--text-muted);
    transition: color var(--motion-fast);
}

.help-toggle:hover {
    color: var(--text-secondary);
}

.help-toggle[data-active="true"] {
    color: var(--accent-primary);
}

.help-toggle-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--text-muted);
    transition: background var(--motion-fast);
}

.help-toggle[data-active="true"] .help-toggle-dot {
    background: var(--accent-primary);
    box-shadow: 0 0 6px var(--accent-primary);
}

/* Hide contextual help markers when tooltips are off */
[data-help]:not([data-tooltip])::after {
    content: '';
    display: none;
}

body[data-help-tips="true"] [data-help] {
    position: relative;
}

body[data-help-tips="true"] [data-help].help-indicator::after {
    content: '';
    position: absolute;
    top: -2px;
    right: -2px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent-primary);
    opacity: 0.7;
    pointer-events: none;
    animation: help-pulse 2s ease-in-out infinite;
}

@keyframes help-pulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50% { opacity: 0.9; transform: scale(1.3); }
}

/* -----------------------------------------------------------------------
   Popover
   ----------------------------------------------------------------------- */

.popover-anchor {
    position: relative;
    display: inline-flex;
}

.popover {
    position: absolute;
    background-color: var(--surface-elevated);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-heavy);
    z-index: var(--z-popover);
    min-width: 200px;
    max-width: 380px;
    overflow: hidden;
    animation: scale-in var(--motion-fast) forwards;
}

.popover[data-closing="true"] {
    animation: scale-out 150ms ease-in forwards;
}

/* Popover positions */
.popover-top {
    bottom: calc(100% + var(--space-2));
    left: 50%;
    transform: translateX(-50%);
    transform-origin: bottom center;
}

.popover-bottom {
    top: calc(100% + var(--space-2));
    left: 50%;
    transform: translateX(-50%);
    transform-origin: top center;
}

.popover-left {
    right: calc(100% + var(--space-2));
    top: 50%;
    transform: translateY(-50%);
    transform-origin: center right;
}

.popover-right {
    left: calc(100% + var(--space-2));
    top: 50%;
    transform: translateY(-50%);
    transform-origin: center left;
}

/* Alignment helpers */
.popover-align-start {
    left: 0;
    transform: none;
}

.popover-align-end {
    right: 0;
    left: auto;
    transform: none;
}

/* Popover sections */
.popover-header {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
}

.popover-header-title {
    font: var(--type-body);
    font-weight: 600;
    color: var(--text-primary);
}

.popover-body {
    padding: var(--space-3) var(--space-4);
}

.popover-body-flush {
    padding: 0;
}

.popover-footer {
    padding: var(--space-3) var(--space-4);
    border-top: 1px solid var(--border-subtle);
}

/* Popover menu items */
.popover-menu {
    padding: var(--space-1);
}

.popover-menu-item {
    display: flex;
    align-items: center;
    gap: var(--space-2-5);
    padding: var(--space-2) var(--space-3);
    font: var(--type-body);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background-color var(--motion-instant);
    border: none;
    background: none;
    width: 100%;
    text-align: left;
}

.popover-menu-item:hover {
    background-color: var(--accent-primary-subtle);
}

.popover-menu-item:focus-visible {
    outline: 2px solid var(--border-focus);
    outline-offset: -2px;
}

.popover-menu-item svg {
    width: 16px;
    height: 16px;
    color: var(--text-muted);
    flex-shrink: 0;
}

.popover-menu-item-danger {
    color: var(--error);
}

.popover-menu-item-danger svg {
    color: var(--error);
}

.popover-menu-item-danger:hover {
    background-color: var(--error-subtle);
}

.popover-menu-kbd {
    margin-left: auto;
    font: var(--type-caption);
    color: var(--text-muted);
}

.popover-menu-divider {
    height: 1px;
    background-color: var(--border-subtle);
    margin: var(--space-1) 0;
}

.popover-menu-label {
    padding: var(--space-2) var(--space-3) var(--space-1);
    font: var(--type-overline);
    color: var(--text-muted);
}
