/* ================================================================
   AlpineFlow — ArtisanFlow Theme (Spectrum Palette)

   A warm, multi-color theme using the Spectrum palette:
   amber, terra, rose, violet, teal.

   Self-contained — ships its own --spectrum-* color definitions.
   Override the :root variables below to customize the palette.

   Supports class-based dark mode (same convention as Tailwind v4):
     - Light by default
     - Dark when .dark is on an ancestor or .flow-container itself

   Usage:
     @import 'alpineflow/structural.css';
     @import 'alpineflow/theme-artisanflow.css';

   Override any --flow-* variable on .flow-container to customise.
   ================================================================ */

/* ── Spectrum palette (override these to customize) ──────────────── */
:root {
    /* Accents */
    --spectrum-amber: #DAA532;
    --spectrum-violet: #8B5CF6;
    --spectrum-teal: #14B8A6;

    /* Surfaces (light mode defaults) */
    --spectrum-surface: #FAFBFC;
    --spectrum-surface-alt: #F1F3F5;
    --spectrum-elevated: #FFFFFF;
    --spectrum-card: #FFFFFF;

    /* Borders */
    --spectrum-border-subtle: rgba(0,0,0,0.06);
    --spectrum-border-medium: rgba(0,0,0,0.10);
    --spectrum-border-accent: rgba(0,0,0,0.15);

    /* Text */
    --spectrum-text-body: #1A1D26;
    --spectrum-text-muted: #5C5F6E;
    --spectrum-text-faint: #8A8D9B;
}

/* Dark mode palette */
.dark {
    --spectrum-surface: #08090C;
    --spectrum-surface-alt: #0E1015;
    --spectrum-elevated: #14171F;
    --spectrum-card: #191D27;

    --spectrum-border-subtle: rgba(255,255,255,0.05);
    --spectrum-border-medium: rgba(255,255,255,0.08);
    --spectrum-border-accent: rgba(255,255,255,0.12);

    --spectrum-text-body: #E4E5EA;
    --spectrum-text-muted: #8A8D9B;
    --spectrum-text-faint: #4E5160;
}

/* ── Shared values (identical in both modes) ────────────────────── */
.flow-container {
    /* Node sizing & layout */
    --flow-node-min-width: 150px;
    --flow-node-border-radius: 6px;
    --flow-node-padding: 12px 16px;
    --flow-node-font-size: 14px;
    --flow-node-transition: border-color 0.15s;

    /* Handles */
    --flow-handle-size: 8px;
    --flow-handle-invalid-bg: #ef4444;

    /* Edge dimensions & animation */
    --flow-edge-stroke-width: 1.5;
    --flow-edge-animated-dasharray: 6 3;
    --flow-edge-animated-duration: 0.5s;
    --flow-edge-pulse-duration: 2s;
    --flow-edge-pulse-min-opacity: 0.3;
    --flow-edge-dot-size: 4;
    --flow-edge-dot-duration: 2s;
    --flow-edge-stroke-width-selected: 2;
    --flow-edge-reconnecting-opacity: 0.25;
    --flow-edge-reconnecting-transition: opacity 0.15s;

    /* Edge label sizing */
    --flow-edge-label-border-radius: 4px;
    --flow-edge-label-padding: 2px 8px;
    --flow-edge-label-font-size: 11px;

    /* Node toolbar sizing */
    --flow-node-toolbar-padding: 4px 6px;
    --flow-node-toolbar-border-radius: 6px;
    --flow-node-toolbar-btn-padding: 4px 8px;
    --flow-node-toolbar-btn-border-radius: 4px;
    --flow-node-toolbar-btn-font-size: 12px;

    /* Drag handle sizing */
    --flow-drag-handle-padding: 6px 12px;
    --flow-drag-handle-border-radius: 6px 6px 0 0;
    --flow-drag-handle-font-size: 12px;
    --flow-drag-handle-font-weight: 600;

    /* Node states */
    --flow-node-locked-border-style: dashed;

    /* Controls sizing */
    --flow-controls-gap: 1px;
    --flow-controls-btn-width: 28px;
    --flow-controls-btn-height: 28px;
    --flow-controls-btn-border-radius: 6px;

    /* Selection */
    --flow-selection-border-radius: 2px;

    /* Background pattern */
    --flow-bg-pattern-gap: 20;

    /* Minimap */
    --flow-minimap-border-radius: 6px;

    /* Panel */
    --flow-panel-border-radius: 6px;
    --flow-panel-min-width: 100px;
    --flow-panel-min-height: 60px;

    /* Group node sizing */
    --flow-node-group-border-radius: 10px;
    --flow-node-group-font-size: 11px;
    --flow-node-group-text-transform: uppercase;
    --flow-node-group-letter-spacing: 0.5px;
    --flow-node-group-padding: 6px 14px;
    --flow-node-group-shadow: none;

    /* Layout animation */
    --flow-layout-animation-duration: 0.3s;

    /* Focus */
    --flow-node-focus-outline-offset: 2px;

    /* Rotate handle */
    --flow-rotate-handle-size: 14px;
    --flow-rotate-handle-offset: 24px;

    /* Guide paths */
    --flow-guide-path-width: 1;
    --flow-guide-path-dash: 4 4;
    --flow-guide-path-opacity: 0.5;

    /* Whiteboard tools */
    --flow-tool-stroke-color: var(--spectrum-text-faint);
    --flow-tool-highlighter-color: var(--spectrum-amber);

    /* Row highlights */
    --flow-edge-row-highlight-color: var(--spectrum-violet);

    /* Validation colors (semantic — not accent-derived) */
    --flow-node-invalid-border: 1.5px dashed #ef4444;
    --flow-node-invalid-shadow: 0 0 0 2px rgba(239, 68, 68, 0.15);
    --flow-node-drop-target-border: 1.5px dashed #3b82f6;
    --flow-node-drop-target-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
    --flow-connection-line-invalid: #ef4444;
    --flow-selection-full-bg: rgba(59, 130, 246, 0.06);
    --flow-selection-full-border-color: rgba(59, 130, 246, 0.4);
    --flow-lasso-stroke-full: rgba(59, 130, 246, 0.6);
}

/* ── Light mode (default) ────────────────────────────────────────── */
.flow-container {
    /* Canvas */
    --flow-bg-color: var(--spectrum-surface-alt);
    --flow-bg-pattern-color: rgba(0, 0, 0, 0.12);

    /* Node colors */
    --flow-node-bg: var(--spectrum-card);
    --flow-node-color: var(--spectrum-text-body);
    --flow-node-border: 1px solid var(--spectrum-border-medium);
    --flow-node-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);

    /* Ghost node (edge drop preview) */
    --flow-ghost-bg: var(--spectrum-card);
    --flow-ghost-border: var(--spectrum-violet);

    /* Node accent stripe */
    --flow-node-border-top: 2.5px solid var(--spectrum-violet);

    /* Node interactive states */
    --flow-node-hover-border-color: var(--spectrum-violet);
    --flow-node-selected-border-color: var(--spectrum-violet);
    --flow-node-selected-shadow: 0 0 0 1px var(--spectrum-violet);

    /* Handles */
    --flow-handle-bg: var(--spectrum-text-faint);
    --flow-handle-border: 1px solid var(--spectrum-card);
    --flow-handle-hover-bg: var(--spectrum-violet);
    --flow-handle-active-bg: var(--spectrum-violet);

    /* Edges */
    --flow-edge-stroke: var(--spectrum-border-accent);
    --flow-edge-stroke-selected: var(--spectrum-violet);
    --flow-edge-dot-fill: var(--spectrum-violet);
    --flow-edge-marker-color: var(--spectrum-text-faint);

    /* Edge labels */
    --flow-edge-label-bg: var(--spectrum-card);
    --flow-edge-label-border: 1px solid var(--spectrum-border-medium);
    --flow-edge-label-color: var(--spectrum-text-muted);

    /* Drag handle */
    --flow-drag-handle-bg: var(--spectrum-elevated);
    --flow-drag-handle-border-bottom: 1px solid var(--spectrum-border-medium);
    --flow-drag-handle-color: var(--spectrum-text-muted);

    /* Node toolbar */
    --flow-node-toolbar-bg: rgba(255, 255, 255, 0.95);
    --flow-node-toolbar-border: 1px solid var(--spectrum-border-medium);
    --flow-node-toolbar-btn-bg: var(--spectrum-elevated);
    --flow-node-toolbar-btn-border: 1px solid var(--spectrum-border-medium);
    --flow-node-toolbar-btn-color: var(--spectrum-text-body);
    --flow-node-toolbar-btn-hover-bg: var(--spectrum-surface-alt);

    /* Node states */
    --flow-node-locked-opacity: 0.6;

    /* Focus */
    --flow-node-focus-outline: 2px solid var(--spectrum-violet);
    --flow-edge-focus-stroke: var(--spectrum-violet);
    --flow-edge-focus-stroke-width: 2.5;

    /* Controls */
    --flow-controls-btn-bg: var(--spectrum-card);
    --flow-controls-btn-border: 1px solid var(--spectrum-border-medium);
    --flow-controls-btn-color: var(--spectrum-text-body);
    --flow-controls-btn-hover-bg: var(--spectrum-elevated);

    /* Selection & lasso */
    --flow-selection-bg: rgba(139, 92, 246, 0.06);
    --flow-selection-border: 1px solid rgba(139, 92, 246, 0.3);
    --flow-lasso-stroke: rgba(139, 92, 246, 0.5);

    /* Minimap */
    --flow-minimap-border: 1px solid var(--spectrum-border-medium);
    --flow-minimap-bg: var(--spectrum-surface-alt);
    --flow-minimap-node-color: var(--spectrum-border-accent);
    --flow-minimap-mask-color: rgba(0, 0, 0, 0.08);

    /* Panel */
    --flow-panel-bg: rgba(255, 255, 255, 0.95);
    --flow-panel-border: 1px solid var(--spectrum-border-medium);
    --flow-panel-resize-bg: linear-gradient(135deg, transparent 50%, rgba(0, 0, 0, 0.12) 50%);
    --flow-panel-resize-hover-bg: linear-gradient(135deg, transparent 50%, rgba(139, 92, 246, 0.5) 50%);
    --flow-panel-resize-border-radius: 0 0 5px 0;

    /* Group node */
    --flow-node-group-bg: rgba(0, 0, 0, 0.04);
    --flow-node-group-border: 1.5px dashed var(--spectrum-border-accent);
    --flow-node-group-hover-border-color: var(--spectrum-text-faint);

    /* Resize handles */
    --flow-resizer-bg: rgba(139, 92, 246, 0.4);
    --flow-resizer-border: 1px solid var(--spectrum-violet);
    --flow-resizer-hover-bg: var(--spectrum-violet);

    /* Loading */
    --flow-loading-bg: rgba(255, 255, 255, 0.85);
    --flow-loading-indicator-color: rgba(0, 0, 0, 0.08);
    --flow-loading-text-color: rgba(0, 0, 0, 0.4);

    /* Touch selection */
    --flow-touch-selection-bg: rgba(139, 92, 246, 0.9);
    --flow-touch-selection-color: #fff;

    /* Rotate handle */
    --flow-rotate-handle-bg: var(--spectrum-violet);
    --flow-rotate-handle-border: 2px solid var(--spectrum-card);
    --flow-rotate-handle-line-color: var(--spectrum-border-accent);

    /* Guide paths */
    --flow-guide-path-color: var(--spectrum-text-faint);

    /* Devtools */
    --flow-devtools-btn-bg: rgba(255,255,255,0.9);
    --flow-devtools-btn-border: 1px solid var(--spectrum-border-medium);
    --flow-devtools-btn-color: var(--spectrum-text-muted);
    --flow-devtools-btn-hover: rgba(255,255,255,1);
    --flow-devtools-panel-bg: rgba(255,255,255,0.95);
    --flow-devtools-panel-border: 1px solid var(--spectrum-border-medium);
    --flow-devtools-divider: var(--spectrum-border-subtle);
    --flow-devtools-title-color: var(--spectrum-text-faint);
    --flow-devtools-label-color: var(--spectrum-text-faint);
    --flow-devtools-value-color: var(--spectrum-text-body);
}

/* ── Dark mode (.dark class on ancestor or container) ────────────── */
.dark .flow-container,
.flow-container.dark {
    /* Canvas */
    --flow-bg-color: var(--spectrum-surface);
    --flow-bg-pattern-color: rgba(255, 255, 255, 0.15);

    /* Node colors */
    --flow-node-bg: var(--spectrum-card);
    --flow-node-color: var(--spectrum-text-body);
    --flow-node-border: 1px solid var(--spectrum-border-medium);
    --flow-node-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);

    /* Ghost node (edge drop preview) */
    --flow-ghost-bg: var(--spectrum-card);
    --flow-ghost-border: var(--spectrum-violet);

    /* Node accent stripe */
    --flow-node-border-top: 2.5px solid var(--spectrum-violet);

    /* Node interactive states */
    --flow-node-hover-border-color: var(--spectrum-violet);
    --flow-node-selected-border-color: var(--spectrum-violet);
    --flow-node-selected-shadow: 0 0 0 1px var(--spectrum-violet);

    /* Handles */
    --flow-handle-bg: var(--spectrum-text-faint);
    --flow-handle-border: 1px solid var(--spectrum-card);
    --flow-handle-hover-bg: var(--spectrum-violet);
    --flow-handle-active-bg: var(--spectrum-violet);

    /* Edges */
    --flow-edge-stroke: var(--spectrum-border-accent);
    --flow-edge-stroke-selected: var(--spectrum-violet);
    --flow-edge-dot-fill: var(--spectrum-violet);
    --flow-edge-marker-color: var(--spectrum-text-faint);

    /* Edge labels */
    --flow-edge-label-bg: var(--spectrum-card);
    --flow-edge-label-border: 1px solid var(--spectrum-border-medium);
    --flow-edge-label-color: var(--spectrum-text-muted);

    /* Drag handle */
    --flow-drag-handle-bg: var(--spectrum-surface);
    --flow-drag-handle-border-bottom: 1px solid var(--spectrum-border-medium);
    --flow-drag-handle-color: var(--spectrum-text-muted);

    /* Node toolbar */
    --flow-node-toolbar-bg: rgba(25, 29, 39, 0.95);
    --flow-node-toolbar-border: 1px solid var(--spectrum-border-medium);
    --flow-node-toolbar-btn-bg: var(--spectrum-elevated);
    --flow-node-toolbar-btn-border: 1px solid var(--spectrum-border-accent);
    --flow-node-toolbar-btn-color: var(--spectrum-text-body);
    --flow-node-toolbar-btn-hover-bg: var(--spectrum-card);

    /* Node states */
    --flow-node-locked-opacity: 0.7;

    /* Focus */
    --flow-node-focus-outline: 2px solid var(--spectrum-violet);
    --flow-edge-focus-stroke: var(--spectrum-violet);

    /* Controls */
    --flow-controls-btn-bg: var(--spectrum-card);
    --flow-controls-btn-border: 1px solid var(--spectrum-border-medium);
    --flow-controls-btn-color: var(--spectrum-text-body);
    --flow-controls-btn-hover-bg: var(--spectrum-elevated);

    /* Selection & lasso */
    --flow-selection-bg: rgba(139, 92, 246, 0.08);
    --flow-selection-border: 1px solid rgba(139, 92, 246, 0.4);
    --flow-lasso-stroke: rgba(139, 92, 246, 0.5);
    --flow-selection-full-bg: rgba(59, 130, 246, 0.08);
    --flow-selection-full-border-color: rgba(59, 130, 246, 0.5);
    --flow-lasso-stroke-full: rgba(59, 130, 246, 0.7);

    /* Minimap */
    --flow-minimap-border: 1px solid var(--spectrum-border-medium);
    --flow-minimap-bg: var(--spectrum-surface);
    --flow-minimap-node-color: var(--spectrum-border-accent);
    --flow-minimap-mask-color: rgba(0, 0, 0, 0.25);

    /* Panel */
    --flow-panel-bg: rgba(25, 29, 39, 0.95);
    --flow-panel-border: 1px solid var(--spectrum-border-medium);
    --flow-panel-resize-bg: linear-gradient(135deg, transparent 50%, rgba(255, 255, 255, 0.1) 50%);
    --flow-panel-resize-hover-bg: linear-gradient(135deg, transparent 50%, rgba(139, 92, 246, 0.5) 50%);

    /* Group node */
    --flow-node-group-bg: rgba(255, 255, 255, 0.03);
    --flow-node-group-border: 1.5px dashed var(--spectrum-border-accent);
    --flow-node-group-hover-border-color: var(--spectrum-text-faint);

    /* Resize handles */
    --flow-resizer-bg: rgba(139, 92, 246, 0.4);
    --flow-resizer-border: 1px solid var(--spectrum-violet);
    --flow-resizer-hover-bg: var(--spectrum-violet);

    /* Loading */
    --flow-loading-bg: rgba(8, 9, 12, 0.85);
    --flow-loading-indicator-color: rgba(255, 255, 255, 0.1);
    --flow-loading-text-color: rgba(255, 255, 255, 0.4);

    /* Touch selection */
    --flow-touch-selection-bg: rgba(139, 92, 246, 0.9);
    --flow-touch-selection-color: #fff;

    /* Rotate handle */
    --flow-rotate-handle-bg: var(--spectrum-violet);
    --flow-rotate-handle-border: 2px solid var(--spectrum-surface);
    --flow-rotate-handle-line-color: var(--spectrum-border-accent);

    /* Validation (slightly brighter for dark bg visibility) */
    --flow-node-invalid-border: 1.5px dashed #f87171;
    --flow-node-invalid-shadow: 0 0 0 2px rgba(248, 113, 113, 0.2);
    --flow-node-drop-target-border: 1.5px dashed #60a5fa;
    --flow-node-drop-target-shadow: 0 0 0 2px rgba(96, 165, 250, 0.25);
    --flow-connection-line-invalid: #f87171;

    /* Whiteboard tools */
    --flow-tool-stroke-color: var(--spectrum-text-muted);
    --flow-tool-highlighter-color: var(--spectrum-amber);

    /* Row highlights */
    --flow-edge-row-highlight-color: var(--spectrum-violet);

    /* Guide paths */
    --flow-guide-path-color: var(--spectrum-border-accent);

    /* Devtools */
    --flow-devtools-btn-bg: var(--spectrum-card);
    --flow-devtools-btn-border: 1px solid var(--spectrum-border-medium);
    --flow-devtools-btn-color: var(--spectrum-text-muted);
    --flow-devtools-btn-hover: var(--spectrum-elevated);
    --flow-devtools-panel-bg: var(--spectrum-card);
    --flow-devtools-panel-border: 1px solid var(--spectrum-border-medium);
    --flow-devtools-divider: var(--spectrum-border-subtle);
    --flow-devtools-title-color: var(--spectrum-text-faint);
    --flow-devtools-label-color: var(--spectrum-text-faint);
    --flow-devtools-value-color: var(--spectrum-text-body);
}

/* ── Shape node defaults (clipped shapes use background-as-border) ── */
.flow-node-diamond,
.flow-node-hexagon,
.flow-node-parallelogram,
.flow-node-triangle {
    min-width: 120px;
    min-height: 80px;
    border: none;
    border-top: none;
    box-shadow: none;
    background: var(--spectrum-border-accent);
}
.dark .flow-node-diamond,
.dark .flow-node-hexagon,
.dark .flow-node-parallelogram,
.dark .flow-node-triangle {
    background: var(--spectrum-border-accent);
}
.flow-node-diamond.flow-node-selected,
.flow-node-hexagon.flow-node-selected,
.flow-node-parallelogram.flow-node-selected,
.flow-node-triangle.flow-node-selected {
    background: var(--flow-node-selected-border-color);
}
.flow-node-circle {
    min-width: 80px;
    min-height: 80px;
}
.flow-node-cylinder {
    min-width: 100px;
    min-height: 80px;
    padding-top: 16px;
}
.flow-node-stadium {
    min-width: 120px;
}

/* ── Rotate handle colors ──────────────────────────────────────── */
.flow-rotate-handle {
    background: var(--flow-rotate-handle-bg);
    border: var(--flow-rotate-handle-border);
}
.flow-rotate-handle::before {
    background: var(--flow-rotate-handle-line-color);
}

/* ── Node state classes (for class-based visual states) ─────── */
.flow-node.flow-node-success {
    --flow-node-border-top: 2.5px solid var(--spectrum-teal);
    border-color: var(--spectrum-teal);
}
.flow-node.flow-node-success:hover,
.flow-node-selected.flow-node-success {
    border-color: var(--spectrum-teal);
    box-shadow: 0 0 0 1px var(--spectrum-teal);
}
.flow-node.flow-node-warning {
    --flow-node-border-top: 2.5px solid var(--spectrum-amber);
    border-color: var(--spectrum-amber);
}
.flow-node.flow-node-warning:hover,
.flow-node-selected.flow-node-warning {
    border-color: var(--spectrum-amber);
    box-shadow: 0 0 0 1px var(--spectrum-amber);
}
.flow-node.flow-node-danger {
    --flow-node-border-top: 2.5px solid #ef4444;
    border-color: #ef4444;
}
.flow-node.flow-node-danger:hover,
.flow-node-selected.flow-node-danger {
    border-color: #ef4444;
    box-shadow: 0 0 0 1px #ef4444;
}
.flow-node.flow-node-info {
    --flow-node-border-top: 2.5px solid #3b82f6;
    border-color: #3b82f6;
}
.flow-node.flow-node-info:hover,
.flow-node-selected.flow-node-info {
    border-color: #3b82f6;
    box-shadow: 0 0 0 1px #3b82f6;
}
.flow-node.flow-node-primary {
    --flow-node-border-top: 2.5px solid var(--spectrum-violet);
    border-color: var(--spectrum-violet);
}
.flow-node.flow-node-primary:hover,
.flow-node-selected.flow-node-primary {
    border-color: var(--spectrum-violet);
    box-shadow: 0 0 0 1px var(--spectrum-violet);
}
.flow-node.flow-node-muted {
    opacity: 0.45;
}

/* ── Edge utility classes (for class-based edge styling) ─────── */
.flow-edge-svg path.flow-edge-highlight {
    stroke: var(--spectrum-violet);
    stroke-width: 2.5;
}
.flow-edge-svg path.flow-edge-success {
    stroke: var(--spectrum-teal);
    stroke-width: 2.5;
}
.flow-edge-svg path.flow-edge-warning {
    stroke: var(--spectrum-amber);
    stroke-width: 2.5;
}
.flow-edge-svg path.flow-edge-danger {
    stroke: #ef4444;
    stroke-width: 2.5;
}
.flow-edge-svg path.flow-edge-info {
    stroke: #3b82f6;
    stroke-width: 2.5;
}
.flow-edge-svg path.flow-edge-primary {
    stroke: var(--spectrum-violet);
    stroke-width: 2.5;
}

/* ── Laravel ecosystem node classes ──────────────────────────── */
.flow-node.flow-node-laravel { --flow-node-border-top: 2.5px solid #FF2D20; border-color: #FF2D20; }
.flow-node.flow-node-alpine { --flow-node-border-top: 2.5px solid #77C1D2; border-color: #77C1D2; }
.flow-node.flow-node-livewire { --flow-node-border-top: 2.5px solid #FB70A9; border-color: #FB70A9; }
.flow-node.flow-node-reverb { --flow-node-border-top: 2.5px solid #16A34A; border-color: #16A34A; }
.flow-node.flow-node-horizon { --flow-node-border-top: 2.5px solid #8B5CF6; border-color: #8B5CF6; }
.flow-node.flow-node-forge { --flow-node-border-top: 2.5px solid #1E3A5F; border-color: #1E3A5F; }
.flow-node.flow-node-vapor { --flow-node-border-top: 2.5px solid #F59E0B; border-color: #F59E0B; }
.flow-node.flow-node-nova { --flow-node-border-top: 2.5px solid #14B8A6; border-color: #14B8A6; }
.flow-node.flow-node-pulse { --flow-node-border-top: 2.5px solid #EF4444; border-color: #EF4444; }
.flow-node.flow-node-pennant { --flow-node-border-top: 2.5px solid #6366F1; border-color: #6366F1; }
.flow-node.flow-node-sanctum { --flow-node-border-top: 2.5px solid #D97706; border-color: #D97706; }
.flow-node.flow-node-breeze { --flow-node-border-top: 2.5px solid #06B6D4; border-color: #06B6D4; }
.flow-node.flow-node-pint { --flow-node-border-top: 2.5px solid #EC4899; border-color: #EC4899; }

