#toolset {
	display: none;
}

body {
	background-color: #fff;
	color: #000;
}

a:active {
	opacity: 0.7;
}

.page a.active {
	
}

i,
em {
	font-style: italic;
}

b,
strong {
	font-weight: bolder;
}

sub,
sup {
	position: relative;
	vertical-align: baseline;
}

sub {
	top: 0.3em;
}

sup {
	top: -0.4em;
}

s {
	text-decoration: line-through;
}

img {
	border: 0;
	padding: 0;
}

ul,
ol {
	margin: 0;
	padding: 0 0 0 2.5em;
}

blockquote {
	margin: 0;
	padding: 0 0 0 1em;
}

hr {
	background: rgba(127, 127, 127, 0.2);
	border: 0;
	height: 1px;
	display: block;
}

.content img {
	float: none;
	margin-bottom: 2rem;
    vertical-align: bottom;
}

[image-gallery="slideshow"] {
    margin-bottom: 2rem;
}

.gallery_image_caption {
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    font-size: 1.4rem;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.30);
	font-family: "Monument Grotesk Mono", Icons;
	font-style: normal;
	line-height: 1.2;	
}

/**
 * Loading Animation
 */

.loading[data-loading] {
	position: fixed;
	bottom: 8px; 
    left: 8px;
}

/**
 * Editor styles
 */

[data-predefined-style="true"] bodycopy {
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.4;
    color: rgb(72, 72, 72);
    text-transform: none;
    letter-spacing: 0.02em;
}

[data-predefined-style="true"] bodycopy a {
	color: rgb(255, 113, 0);
	text-decoration: none;
}

[data-predefined-style="true"] bodycopy a:hover {
    color: rgba(0, 65, 255, 1);
	color: rgba(193, 255, 0, 1);

}

bodycopy a.image-link,
bodycopy a.icon-link,
bodycopy a.image-link:hover,
bodycopy a.icon-link:hover {
	border-bottom: 0;
	padding-bottom: 0;
}

[data-predefined-style="true"] h1 {
	font-family: "Monument Grotesk Variable", Icons;
	font-style: normal;
	font-weight: 800;
	padding: 0;
	margin: 0;
	font-size: 16.9vmin;
	line-height: 1.2;
	color: rgba(0, 0, 0, 1);
	font-variation-settings: 'slnt' 0, 'MONO' 0;
}

[data-predefined-style="true"] h1 a {
	color: rgba(236, 255, 11, 0.75);
}

[data-predefined-style="true"] h2 {
	font-family: "Space Grotesk", Icons;
	padding: 0;
	margin: 0;
	color: rgba(255, 255, 255, 0.75);
	font-size: 2rem;
	line-height: 1.4;
	font-style: normal;
	font-weight: 700;
	font-variation-settings: 'slnt' 0, 'MONO' 1;
	}

[data-predefined-style="true"] h2 a {
	color: rgba(193, 255, 0, 0.75);
}

[data-predefined-style="true"] small {
	display: inline-block;
	font-size: 2.2rem;
	line-height: 1.2;
	font-family: "Space Grotesk", Icons;
	font-style: normal;
	font-weight: 400;
	color: rgb(49, 49, 49);
}

[data-predefined-style="true"] small a {
	color: #39ff00;
	border-bottom-width: 0em;
}

/**
 * Breakpoints
 */


[data-css-preset] .page {
    background-color: initial /*!page_bgcolor*/;
}

.mobile .page,
[data-css-preset].mobile .page {
	position: relative;
	max-width: 100%;
	width: 100%;
	background-color: transparent /*!page_bgcolor*/;
}

[data-css-preset] .container {
	margin-left: auto /*!content_center*/;
	margin-right: auto /*!content_center*/;
	text-align: center /*!text_center*/;
}

[data-css-preset] body {
	background-color: rgba(198, 198, 198, 1)/*!body_bgcolor*/;
}

[data-css-preset] .container_width {
	width: 39%/*!content_center*/;
}

[data-css-preset] .content_padding {
	padding-top: 0.7rem/*!main_margin*/;
	padding-bottom: 0.7rem/*!main_margin*/;
	padding-left: 0.7rem/*!main_margin*/;
	padding-right: 0.7rem/*!main_margin*/;
}

/**
 * Thumbnails
 */

div[thumbnails] {
	justify-content: flex-start;
}

[data-css-preset] .thumbnails {
   	background-color: transparent/*!thumbnails_bgcolor*/;   
}

[data-css-preset] .thumbnails_width {
    width: 28%/*!thumbnails_width*/;
}

[data-css-preset] [thumbnails-pad] {
    padding: 0rem/*!thumbnails_padding*/;
}

[data-css-preset] [thumbnails-gutter] {
    margin: 0rem/*!thumbnails_padding*/;
}

[data-css-preset] [responsive-layout] [thumbnails-pad] {
    padding: 0.5rem/*!responsive_thumbnails_padding*/; 
}

[data-css-preset] [responsive-layout] [thumbnails-gutter] {
    margin: -1rem/*!responsive_thumbnails_padding*/; 
}

.thumbnails .thumb_image {
	outline: 0px solid rgba(0,0,0,.12);
    outline-offset: -1px;
}

.thumbnails .title {
    margin-top: 1.0rem;
    margin-bottom: 0.7rem;
    font-size: 1.5rem;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.85);
	font-family: Diatype, Icons;
	font-style: normal;
	line-height: 1.3;
}

.thumbnails .tags {
    margin-top: .8rem;
    margin-bottom: 1.5rem;
    font-size: 1.4rem;
	font-weight: 500;
	color: rgba(0, 0, 0, 0.3);
	font-family: "Monument Grotesk Mono", Icons;
	font-style: normal;
	line-height: 1.2;
}

.thumbnails .tags a {
	border-bottom: 0;
    color: rgba(0, 0, 0, 0.3);
    text-decoration: none;
}

.thumbnails .has_title .tags {
	margin-top: -0.5rem;
}

/**
 * Site Menu Button
 */

[data-css-preset] #site_menu_button {
    color: rgba(0, 0, 0, 0.75);
    line-height: 1;
    font-size: 28px /*!site_menu_button*/;
    padding: 6px;
    line-height: 1;
    background: rgba(33, 32, 46, 0);
    position: fixed;
	top: 3rem /*!site_menu_button*/;
	right: 3rem /*!site_menu_button*/;
}

body.mobile #site_menu_button {
	margin: -6px;
    font-size: 24px;
}

#site_menu_button.custom_icon {
	width: 40px;
    height: auto;
}

#site_menu_button.active {
	display: none;
}


/**
 * Site Menu
 */

#site_menu {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif, "Sans Serif", Icons;
	background: rgba(20, 20, 20, 0.95);
	font-size: 20px;
	font-style: normal;
	font-weight: 400;
	padding: 20px 30px 90px 30px;
	max-width: 400px;
	min-width: 300px;
	text-align: left;
	display: flex;
	justify-content: flex-start;
}

body.mobile #site_menu {
	width: 100%;
}

#site_menu .page-link a {
	color: rgba(255, 255, 255, 0.75);
}

#site_menu .set-link > a {
	color: rgba(255, 255, 255, 0.75);
	font-weight: bold;
}

#site_menu a:active {
	opacity: .7;
}

#site_menu a.active {
	opacity: .4;
}

#site_menu .close {
	display: none;
	color: rgba(255, 255, 255, 0.4);
	line-height: .85em;
	font-size: 45px;
}

body.mobile #site_menu .close {
	display: block;
	font-size: 50px;
	line-height: 1em;
}

#site_menu .break {
	height: 28px;
}

#site_menu .indent {
	margin-left: 28px;
}

/*
 * Shop Button
 */

[data-css-preset] #shop_button {
	color: rgba(0, 0, 0, 0.85);
    background: transparent;
	font-size: 32px;
    font-style: normal;
	font-weight: 400;
    line-height: 1;
    position: fixed;
	padding: 6px;
	top: 1rem /*!shop_button*/;
	left: 1.5rem /*!shop_button*/;
}

#shop_button.text {
    font-size: 1.6rem;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.75);
	font-family: Diatype, Icons;
    padding: 0;
    line-height: 1.3;
	font-style: normal;
}

#shop_button.custom_icon {
	width: 40px;
    height: auto;
}

body.mobile #shop_button:not(.text) {
	margin: -6px;
    font-size: 40px;
}

/*
 * Shop Product Widget
 */

.shop_product {
    width: 100%;
	max-width: 22rem;
    position: relative;
    display: block;
}

.shop_product .price {
	font-family: Diatype, Icons;
	font-size: 1.6rem;
	line-height: 1;
	color: rgba(0, 0, 0, 0.75);
    display: block;
    margin-bottom: 1rem;
	font-style: normal;
	font-weight: 400;
}

.shop_product .dropdown {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif, "Sans Serif", Icons;
    font-size: 1.4rem;
    display: inline-block;
	width: 100%;
    border: 1px solid rgba(0,0,0,.2);
    background:  white url(https://static.cargo.site/assets/images/select-line-arrows.svg) no-repeat right;
    margin-bottom: 1rem;
    line-height: 1.3;
    padding: .7rem 2.5rem .8rem 1rem;
	font-style: normal;
	font-weight: 400;
    color: rgba(0, 0, 0, 0.75);
}

.shop_product .button {
	font-family: Diatype, Icons;
	font-size: 1.4rem;
    background: rgba(0, 0, 0, 0.75);
    color: rgba(255,255,255,1);
    flex: 0 0 50%;
    text-align: left;
    display: inline-block;
	line-height: 1.3;
    padding: .8rem 1rem .9rem;
	font-style: normal;
	font-weight: 700;
}

/*
 * Image Zoom
 */

.content img.image-zoom:active {
  opacity: .7;
}

/**
 * Quick View
 */

[data-css-preset] .quick-view {
    padding-top: 2.3rem /*!quick_view_padding*/;
    padding-bottom: 2.3rem /*!quick_view_padding*/;
    padding-left: 2.3rem /*!quick_view_padding*/;
    padding-right: 2.3rem /*!quick_view_padding*/;
    height: 100% /*!quick_view_height*/;
    width: 100% /*!quick_view_width*/;
}

body.mobile .quick-view {
    width: 100%;
    height: 100%;
    margin: 0;
}

[data-css-preset] .quick-view-background {
	background: rgba(255, 255, 255, 1) /*!quick_view_bgcolor*/;
}

.quick-view-caption {
	font-family: "Monument Grotesk Mono", Icons;
    transition: 100ms opacity ease-in-out;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 3.5rem 0;
    text-align: center;
    font-size: 1.4rem;
	font-style: normal;
	font-weight: 400;
    line-height: 1.2;
}

.quick-view-caption span {
    padding: 0.5rem 1rem;
    display: inline-block;
    background: rgba(0,0,0,0.4);
    color: white;
}


/**
 * Quick View Navigation 
 */

.quick-view-navigation .left-arrow {
    left: 10px;
}

.quick-view-navigation .right-arrow {
    right: 10px;
}

.quick-view-navigation .left-arrow,
.quick-view-navigation .right-arrow {
    /* Change height/width together to scale */
    height: 36px;
    width: 36px;
}

.quick-view-navigation .left-arrow .inner-color,
.quick-view-navigation .right-arrow .inner-color {
    stroke: #fff;
    stroke-width: 0px;
}

.quick-view-navigation .left-arrow .outer-color,
.quick-view-navigation .right-arrow .outer-color {
    stroke: rgba(0, 0, 0, 0.85);
    stroke-width: 2px;
}

.quick-view-navigation .close-button {  
    top: 10px;
    right: 10px;
    /* Change height/width together to scale */
    width: 36px;
    height: 36px;
}

.quick-view-navigation .close-button .inner-color {
    stroke: #fff;
    stroke-width: 0px;
}

.quick-view-navigation .close-button .outer-color {
    stroke: rgba(0, 0, 0, 0.85);
    stroke-width: 2px;
}

/** 
 * Image Gallery Navigation Arrows 
 */
 
.image-gallery-navigation .left-arrow,
.image-gallery-navigation .right-arrow {
    /* Change height/width together to scale */
    height: 36px;
    width: 36px;
}

.image-gallery-navigation .left-arrow .inner-color,
.image-gallery-navigation .right-arrow .inner-color {
    stroke: #fff;
    stroke-width: 1.5px;
}

.image-gallery-navigation .left-arrow .outer-color,
.image-gallery-navigation .right-arrow .outer-color {
    stroke: rgba(0, 0, 0, 0.6);
    stroke-width: 2.5px;
}

/**
 * Wallpaper Backdrop Navigation Arrows 
 */

.wallpaper-navigation .left-arrow,
.wallpaper-navigation .right-arrow {
   /* Change height/width together to scale */
   width: 36px;
   height: 36px;
}

.wallpaper-navigation .left-arrow .inner-color,
.wallpaper-navigation .right-arrow .inner-color {
   stroke: #fff;
    stroke-width: 1.5px;
}

.wallpaper-navigation .left-arrow .outer-color,
.wallpaper-navigation .right-arrow .outer-color {
    stroke: rgba(0, 0, 0, 0.6);
    stroke-width: 2.5px;
}


/**
 * Feed
 */

.feed .content_container .page {
    border-top: 0px dashed rgba(0, 0, 0, 0.2);
}

.feed .content_container .page_container:first-child .page {
	border-top: 0;
}



/*
 * Audio Player
 */

.audio-player {
    max-width: 36rem;
    height: 3.3rem;
    outline: 1px solid rgba(0,0,0,0.15);
    color: rgba(0, 0, 0, 0.6);
    background: #fff;
    font-size: 1.4rem;
    line-height: 1.2;
	font-family: Diatype, Icons;
    font-style: normal;
    font-weight: 400;
    text-align: left;
    margin: 1px 1px 1em 1px;
}

body.mobile .audio-player {
    max-width: 100%;
}

.audio-player .separator {
    width: 1px;
    background-color: rgba(0,0,0,0.15);
}

.audio-player .button {
    background: transparent;
    cursor: pointer;
    fill: rgba(0, 0, 0, 0.85);
}

.audio-player .icon {
    fill: rgba(0, 0, 0, 0.85);
    padding: 30%;
    width: 100%;
    margin: auto;
}

.audio-player .buffer {
    background: rgba(0,0,0,0.03);
}

.audio-player .progress {
    background: rgba(0,0,0,0.1);
}

.audio-player .progress-indicator {
    border: 1px solid rgba(0, 0, 0, 0.7);
    width: 1px;
    height: 100%;
    right: 0;
    position: absolute;
    cursor: ew-resize;
}

.audio-player .note-icon {
    height: 100%;
    width: 3.8rem;
    padding: 1rem;
    fill: rgba(0, 0, 0, 0.5);
}

.audio-player .current-time {
    padding-left: 1rem;
}

.audio-player .total-time {
    padding-right: 1rem;
}

@font-face {
    font-family: 'Archon';
    font-weight: normal;
    font-style: normal;
    src: url('https://files.cargocollective.com/c1143346/Archon.woff') format('woff');
}


[data-predefined-style="true"] bodycopy {
    font-size: 1rem;
    font-weight: 500;
    color: rgb(72, 72, 72);
    font-family: "Michroma", Icons;
    font-style: normal;
    line-height: 1.4;
	font-variation-settings: 'slnt' 0, 'MONO' 0;
}

@font-face {
    font-family: 'woff';
    font-weight: normal;
    font-style: normal;
    src: url('https://files.cargocollective.com/c1143346/ELAINE-Regular.woff') format('woff');
}


[data-predefined-style="true"] H1 {
    font-size: 2rem;
    font-weight: 400;
    color: rgba(0, 0, 0, 0.85);
    font-family: "woff", Icons;
    font-style: normal;
    line-height: 1.2;
}

[data-css-preset] .container_width {
	width: 100% /*!content_left*/;
}

[data-css-preset] .container {
	text-align: center /*!text_center*/;
}

[data-css-preset] .content_padding {
	padding-top: 0.9rem /*!main_margin*/;
	padding-bottom: 0.9rem /*!main_margin*/;
	padding-left: 0.9rem /*!main_margin*/;
	padding-right: 0.9rem /*!main_margin*/;
}


/* ───────────── ROUNDED IMAGES + VIDEOS ───────────── */

/* All images and iframes (for YouTube/Vimeo) */
img,
iframe {
  border-radius: 18px;          /* smooth corners */
  overflow: hidden;
  transition: transform 0.3s ease, filter 0.3s ease, box-shadow 0.4s ease;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}

/* Hover effect: slightly lift + glow */
img:hover,
iframe:hover {
  transform: scale(1.02);
  box-shadow: 0 0 20px rgba(255, 255, 255, 0.25),
              0 0 40px rgba(0, 255, 255, 0.15);
}

/* Prevent corners from being cut inside links */
a img {
  border-radius: 18px;
}

/* ───────────── LIQUID GLASS EFFECT ───────────── */

img,
iframe {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  transition: transform 0.5s ease, filter 0.5s ease, box-shadow 0.6s ease;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.08);
  backdrop-filter: blur(0px);
}

img::after,
iframe::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.2), transparent 60%),
              radial-gradient(circle at 70% 70%, rgba(255,255,255,0.15), transparent 70%);
  opacity: 0;
  transform: scale(1.5) rotate(0deg);
  transition: opacity 0.6s ease, transform 2s ease;
  mix-blend-mode: screen;
  pointer-events: none;
}






/* Hover: refracted light shimmer & liquid glow */
img:hover::after,
iframe:hover::after {
  opacity: 1;
  transform: scale(1) rotate(360deg);
}

img:hover,
iframe:hover {
  transform: scale(1.03);
  filter: brightness(1.05) contrast(1.08) saturate(1.1);
  box-shadow: 0 0 30px rgba(255, 0, 0, 0.15),
              0 0 60px rgba(255, 230, 180, 0.25),
              0 0 200px rgba(120, 0, 255, 0.2);
}

/* ───────────── CIRCULAR IMAGE MASK (HOME THUMBNAILS ONLY) ───────────── */

/* Only affect linked thumbnail images in your project grid */
.thumbnails a img {
  -webkit-mask-image: radial-gradient(circle, white 99%, transparent 100%);
  mask-image: radial-gradient(circle, white 99%, transparent 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: cover;
  mask-size: cover;
  border-radius: 50%; /* ensures perfect circle */
  overflow: hidden;
}

/* Optional: keep hover glow smooth but constrained */
.thumbnails a img:hover {
  transform: scale(1.03);
  filter: brightness(1.05) contrast(1.1);
  box-shadow: 0 0 30px rgba(255, 255, 255, 0.15),
              0 0 60px rgba(255, 230, 180, 0.25),
              0 0 80px rgba(120, 0, 255, 0.2);
}

/* ───────────── CIRCULAR IMAGE MASK FOR PROJECT GRID ───────────── */

/* Apply only to project thumbnails */
.thumbnails .thumb_image img {
  -webkit-mask-image: radial-gradient(circle, white 99%, transparent 100%);
  mask-image: radial-gradient(circle, white 99%, transparent 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: cover;
  mask-size: cover;
  border-radius: 50%;
  overflow: hidden;
  transition: transform 0.4s ease, box-shadow 0.4s ease, filter 0.4s ease;
}

/* Hover glow and lift (inside the circle only) */
.thumbnails .thumb_image img:hover {
  transform: scale(1.03);
  filter: brightness(1.05) contrast(1.08);
  box-shadow: 
    0 0 20px rgba(255, 255, 255, 0.15),
    0 0 40px rgba(255, 230, 180, 0.25),
    0 0 60px rgba(128, 0, 255, 1);
}

/* ───────────── FORCE UNIFORM SMOOTH HOVER FOR ALL IMAGES (SAFE VERSION) ───────────── */

img,
.thumbnails img,
.thumb_image img,
.content img,
a img,
div img {
  transition: none !important;
  transform: none !important;
}

/* Reapply smooth transitions (Cargo-safe syntax) */
img,
.thumbnails img,
.thumb_image img,
.content img,
a img,
div img {
  transition: all 0.6s ease-out !important;
  will-change: transform, filter, box-shadow;
}

/* Unified hover effect */
img:hover,
.thumbnails img:hover,
.thumb_image img:hover,
.content img:hover,
a img:hover,
div img:hover {
  transform: scale(1.03) !important;
  filter: brightness(1.08) contrast(1.05) !important;
  box-shadow:
    0 0 20px rgba(255, 255, 255, 0.15),
    0 0 40px rgba(255, 230, 180, 0.25),
    0 0 60px rgba(128, 0, 255, 1);
}
/* ───────────── FIX: HOVERED IMAGE ALWAYS ON TOP ───────────── */

img,
.thumbnails img,
.thumb_image img,
.content img,
a img,
div img {
  position: relative;
  z-index: 0;
  transition: all 0.6s ease-out !important;
}

/* When hovered, bring it above all others */
img:hover,
.thumbnails img:hover,
.thumb_image img:hover,
.content img:hover,
a img:hover,
div img:hover {
  z-index: 999 !important;
  transform: scale(1.03) !important;
  filter: brightness(1.08) contrast(1.05) !important;
  box-shadow:
    0 0 20px rgba(255, 255, 255, 0.15),
    0 0 40px rgba(255, 230, 180, 0.25),
    0 0 60px rgba(128, 0, 255, 1);
}


/* Inflates + turns orange on hover */
.cursor-hover {
  transform: translate(-50%, -50%) scale(2.5);
  background: orange;
}
/* === IMAGE INVERT HOVER EFFECT === */
a img, img.linked-image {
  transition: filter 0.6s ease;
}

/* === Invert only the image that is directly hovered === */
a img {
  transition: filter 0.6s ease;
}


/* Optional: keep background clean for transparent areas */
a img:hover {
  mix-blend-mode: normal;
  background-color: transparent;
}


/* Optional: keep transparent parts clear */
a:hover img, img.linked-image:hover {
  mix-blend-mode: normal;
  background-color: transparent;
}

/* === CLICK-BASED NEON BALLOON CURSOR === */
body, a, button, [role="button"], input, textarea {
  cursor: none !important;
}

#custom-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 999999;
  transform: translate(-50%, -50%) scale(1);
  background: white;
  box-shadow: 0 0 5px rgba(255, 255, 255, 0.3);
  transition: transform 0.25s ease, box-shadow 0.4s ease, background 0.4s ease;
  mix-blend-mode: difference;
}

/* Neon balloon click animation */
#custom-cursor.click-burst {
  transform: translate(-50%, -50%) scale(3);
  background: radial-gradient(circle at center,
    hsl(var(--hue, 200), 100%, 65%) 0%,
    hsl(calc(var(--hue, 200) + 100), 100%, 55%) 100%);
  box-shadow:
    0 0 15px hsl(var(--hue, 200), 100%, 70%),
    0 0 35px hsl(calc(var(--hue, 200) + 100), 100%, 60%),
    0 0 60px hsl(var(--hue, 200), 100%, 50%);
  filter: brightness(2);
}
/* === Keep dot cursor for zoomable images === */
img.image-zoom,
img[onclick*="zoom"],
.image-zoomable {
  cursor: none !important; /* Hide default magnifying glass */
}

/* When hovering over zoomable images, change dot color */
img.image-zoom:hover ~ #custom-cursor,
img[onclick*="zoom"]:hover ~ #custom-cursor,
.image-zoomable:hover ~ #custom-cursor {
  background: hsl(var(--hue, 200), 100%, 65%);
  box-shadow:
    0 0 10px hsl(var(--hue, 200), 100%, 70%),
    0 0 25px hsl(var(--hue, 200), 100%, 60%);
  filter: brightness(1.4);
}

/* Color when hovering zoomable image */
#custom-cursor.cursor-zoom {
  background: hsl(var(--hue, 180), 100%, 60%);
  box-shadow:
    0 0 12px hsl(var(--hue, 180), 100%, 70%),
    0 0 30px hsl(var(--hue, 180), 100%, 60%);
  filter: brightness(1.3);
}

/* Always hide default cursor everywhere */
body, a, img, button, iframe {
  cursor: none !important;
}

/* Make sure zoom plugins or image clicks don't re-enable it */
* {
  cursor: none !important;
}

/* === Force browser cursor to never appear anywhere === */
*,
*::before,
*::after {
  cursor: none !important;
}

/* When Cargo injects a zoom overlay or iframe */
body.zoom,
.lightbox,
div[id*="zoom"],
iframe {
  cursor: none !important;
}

/* === Neon Dot Cursor === */
#custom-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: hsl(var(--hue, 200), 100%, 60%);
  pointer-events: none;
  transform: translate(-50%, -50%) scale(1);
  z-index: 999999;
  mix-blend-mode: difference;
  transition: transform 0.5s ease, box-shadow 0.5s ease, background 0.5s ease;
}

/* === Smooth Neon Burst === */
.click-burst {
  animation: neonBurst 1.2s ease-out forwards;
}

@keyframes neonBurst {
  0% {
    transform: translate(-50%, -50%) scale(1);
    box-shadow:
      0 0 10px hsl(var(--hue), 100%, 65%),
      0 0 20px hsl(var(--hue), 100%, 70%);
  }
  50% {
    transform: translate(-50%, -50%) scale(2.4);
    box-shadow:
      0 0 35px hsl(var(--hue), 100%, 70%),
      0 0 80px hsl(var(--hue), 100%, 80%);
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
    box-shadow:
      0 0 8px hsl(var(--hue), 100%, 55%),
      0 0 16px hsl(var(--hue), 100%, 65%);
  }
}
/* === Hover Preview Fix === */
#hover-preview {
  position: fixed;
  top: 0;
  left: 0;
  max-width: 320px;
  height: auto;
  border-radius: 10px;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.95);
  transition: opacity 0.3s ease, transform 0.3s ease;
  filter: brightness(1.05) contrast(1.1) saturate(1.1);
  box-shadow: 0 0 35px rgba(80, 150, 255, 0.4);
  z-index: 99998;
}

#hover-preview.visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* Let links actually detect hover (cursor layer won't block) */
a, a * {
  pointer-events: auto !important;
}

/* Keep cursor overlay above but never blocking */
#custom-cursor {
  pointer-events: none !important;
  z-index: 99999 !important;
}



/* Slightly stronger shadow on hover */
a:hover {
  text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.4);
}


/* === BLUR EFFECT for internal nav links === */
a.blurry-link {
  filter: blur(4px);
  opacity: 0.6;
  transition: filter 0.5s ease, opacity 0.5s ease;
}

a.blurry-link:hover,
a.blurry-link.active,
a.blurry-link[aria-current="page"] {
  filter: blur(0);
  opacity: 1;
}



/* === BLURRED LINK EFFECT === */
.blur-link {
  filter: blur(2px);
  opacity: 0.6;
  transition: filter 0.4s ease, opacity 0.4s ease;
  display: inline-block;
  text-decoration: none;
  color: inherit;
}
/* Hover: clear and visible */
.blur-link:hover {
  filter: blur(0);
  opacity: 1;
}

/* Active / current page stays clear */
.blur-link.active,
.blur-link[aria-current="page"],
.page a.active.blur-link {
  filter: blur(0);
  opacity: 1;
}







#hover-label {
  position: fixed;
  top: 0;
  left: 500;
  pointer-events: none;
  padding: 6px 12px;
  background: rgba(0, 120, 255, 0.5);
  color: #fff;
  font-family: "Space Grotesk", sans-serif;
  font-size: 0.9rem;
  border-radius: 6px;
  backdrop-filter: blur(4px);
  box-shadow: 0 2px 10px rgba(0,0,0,0.25);
  opacity: 0;
  transform: translate3d(0,0,0);
  transition: opacity 0.25s ease;
  mix-blend-mode: normal;
  z-index: 2; /* safely below your image hover glow */
  will-change: transform;
}





