/* ============================================
   Homescreen Hub
   ============================================ */
.homescreen {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  background: var(--black);
}

.homescreen.hidden {
  display: none;
}

/* Hero image */
.hero-image-container {
  position: absolute;
  inset: 0;
}

.hero-portrait {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 55% 30%;
}

/* Cutout silhouette — shows only purple outline on About Me hover */
.hero-cutout {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 55% 30%;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
  z-index: 6;
  mix-blend-mode: screen;
  filter: brightness(0)
          drop-shadow(0 0 6px rgba(157, 78, 221, 0.9))
          drop-shadow(0 0 14px rgba(157, 78, 221, 0.5))
          drop-shadow(0 0 30px rgba(157, 78, 221, 0.3));
  transition: opacity 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.homescreen:has(.corner-mind:hover) .hero-cutout {
  opacity: 1;
}

/* About Me hover: fade other text to background so YOU become the focus */
.hero-title,
.corner-forest .corner-label,
.corner-forest .corner-icon,
.corner-ocean .corner-label,
.corner-ocean .corner-icon,
.corner-tech .corner-label {
  transition: opacity 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.homescreen:has(.corner-mind:hover) .hero-title,
.homescreen:has(.corner-mind:hover) .corner-forest .corner-label,
.homescreen:has(.corner-mind:hover) .corner-forest .corner-icon,
.homescreen:has(.corner-mind:hover) .corner-ocean .corner-label,
.homescreen:has(.corner-mind:hover) .corner-ocean .corner-icon,
.homescreen:has(.corner-mind:hover) .corner-tech .corner-label {
  opacity: 0.1;
}

/* Corner tint overlays (CSS fallback for non-AI-enhanced photo) */
.corner-tint {
  position: absolute;
  width: 50%;
  height: 50%;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.hero-portrait[src*="compressed"] ~ .corner-tint { opacity: 0.3; }

.corner-tint-forest { top: 0; left: 0; background: radial-gradient(ellipse at 15% 25%, rgba(45,95,63,0.6) 0%, transparent 70%); }
.corner-tint-ocean  { top: 0; right: 0; background: radial-gradient(ellipse at 85% 45%, rgba(10,36,99,0.5) 0%, transparent 70%); }
.corner-tint-tech   { bottom: 0; left: 0; background: radial-gradient(ellipse at 32% 75%, rgba(0,217,255,0.3) 0%, transparent 70%); }
.corner-tint-mind   { top: 0; left: 0; background: radial-gradient(ellipse at 48% 25%, rgba(157,78,221,0.4) 0%, transparent 70%); }

/* Vignette */
.homescreen::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 55% 40%, transparent 25%, rgba(0,0,0,0.4) 80%);
  pointer-events: none;
  z-index: 1;
}

/* Hero title */
.hero-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 10;
  pointer-events: none;
}

.hero-name {
  font-size: clamp(2.5rem, 7vw, 5rem);
  font-weight: 900;
  color: #5bb8d4;
  letter-spacing: 0.04em;
  text-shadow: 0 2px 8px rgba(10,36,99,0.4);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  margin-bottom: 0.5rem;
}

.hero-subtitle {
  color: rgba(255,255,255,0.85);
  font-size: clamp(0.9rem, 2vw, 1.2rem);
  font-weight: 400;
  text-shadow: 0 2px 10px rgba(0,0,0,0.5);
  margin-bottom: 0;
}

.hero-hint {
  color: rgba(255,255,255,0.6);
  font-size: 0.9rem;
  margin-top: 2rem;
  opacity: 0;
  animation: hintFadeIn 0.8s ease 3s forwards;
}

@keyframes hintFadeIn {
  to { opacity: 1; }
}

/* ============================================
   Hotspot Regions
   ============================================ */
.corner-hotspot {
  position: absolute;
  border: none;
  background: transparent;
  cursor: pointer;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  padding: 1rem;
  transition: all 0.4s var(--ease-out);
  overflow: visible;
}

/* Forest: over the tree-covered hillside on the left */
.corner-forest { top: 0; left: 0; width: 35%; height: 55%; }
/* Ocean: over the waves on the far right */
.corner-ocean  { top: 10%; right: 0; width: 30%; height: 65%; }
/* Tech board: invisible angled hitbox over the surfboard — JS positions top/left */
.corner-tech-board {
  top: 62%;
  left: -15%;
  width: 100%;
  height: 52%;
  clip-path: polygon(10% 0%, 35% 0%, 80% 100%, 45% 100%);
  background: transparent;
  opacity: 0;
}
.corner-tech-board.positioned { opacity: 1; }
/* Tech label: normal rectangular hotspot like the others */
.corner-tech   { top: 65%; left: 31%; width: 20%; height: 20%; }
/* Hovering the board also highlights the label */
.corner-tech-board:hover ~ .corner-tech .corner-label { color: var(--tech-cyan); }
.corner-tech-board:hover ~ .corner-tech .corner-glow { opacity: 1; background: radial-gradient(ellipse at 50% 50%, rgba(0,217,255,0.15) 0%, transparent 70%); }
/* Mind: JS-positioned over the face area — hidden until JS places it */
.corner-mind   { top: 10%; left: 40%; width: 18%; height: 56%; opacity: 0; }
.corner-mind.positioned { opacity: 1; transition: opacity 0.3s ease; }

/* Icon — large and unmissable */
.corner-icon {
  width: clamp(80px, 12vw, 160px);
  height: clamp(80px, 12vw, 160px);
  flex-shrink: 0;
  color: rgba(255,255,255,0.9);
  transition: all 0.4s var(--ease-out);
  filter: drop-shadow(0 4px 16px rgba(0,0,0,0.6));
}

/* Label — visible by default with breathing pulse, bold on hover */
@keyframes labelPulse {
  0%, 100% { opacity: 0.85; }
  50% { opacity: 1; }
}

.corner-label {
  color: rgba(255,255,255,0.85);
  font-size: clamp(1.4rem, 3vw, 2.8rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-shadow: 0 2px 6px rgba(0,0,0,0.6), 0 0 20px rgba(255,255,255,0.15);
  transition: color 0.5s var(--ease-out), text-shadow 0.5s var(--ease-out), transform 0.5s var(--ease-out);
  white-space: nowrap;
  flex-shrink: 0;
  animation: labelPulse 3.5s ease-in-out infinite;
  border-bottom: 2px solid rgba(255,255,255,0.3);
  padding-bottom: 0.15em;
}

/* When any hotspot is hovered, stop pulse on all labels */
.homescreen:has(.corner-hotspot:hover) .corner-label {
  animation: none;
}

/* Forest hover: dim others + hero title */
.homescreen:has(.corner-forest:hover) .hero-title,
.homescreen:has(.corner-forest:hover) .corner-ocean .corner-label,
.homescreen:has(.corner-forest:hover) .corner-ocean .corner-icon,
.homescreen:has(.corner-forest:hover) .corner-tech .corner-label,
.homescreen:has(.corner-forest:hover) .corner-mind .corner-label {
  opacity: 0.2;
}

/* Ocean hover: dim others + hero title */
.homescreen:has(.corner-ocean:hover) .hero-title,
.homescreen:has(.corner-ocean:hover) .corner-forest .corner-label,
.homescreen:has(.corner-ocean:hover) .corner-forest .corner-icon,
.homescreen:has(.corner-ocean:hover) .corner-tech .corner-label,
.homescreen:has(.corner-ocean:hover) .corner-mind .corner-label {
  opacity: 0.2;
}

/* Tech hover: dim others + hero title */
.homescreen:has(.corner-tech:hover) .hero-title,
.homescreen:has(.corner-tech:hover) .corner-forest .corner-label,
.homescreen:has(.corner-tech:hover) .corner-forest .corner-icon,
.homescreen:has(.corner-tech:hover) .corner-ocean .corner-label,
.homescreen:has(.corner-tech:hover) .corner-ocean .corner-icon,
.homescreen:has(.corner-tech:hover) .corner-mind .corner-label {
  opacity: 0.2;
}

/* Glow overlay */
.corner-glow {
  position: absolute;
  inset: 0;
  border-radius: 0;
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
}

/* ============================================
   Forest: Sprout → Tree grow animation
   ============================================ */

/* Trunk: starts as short sprout stem, grows to full height on hover */
.forest-grow-icon .fg-trunk {
  transform: scaleY(0.3);
  transform-origin: 32px 76px;
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Sprout leaves: visible by default */
.forest-grow-icon .fg-sprout-l,
.forest-grow-icon .fg-sprout-r {
  transition: opacity 0.3s ease, transform 0.4s ease;
  transform-origin: 32px 58px;
}

/* Canopy: hidden by default, blooms on hover */
.forest-grow-icon .fg-canopy {
  transform: scale(0);
  transform-origin: 32px 50px;
  opacity: 0;
  transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1) 0.12s,
              opacity 0.4s ease 0.12s;
}

/* Soil: subtle pulse on hover */
.forest-grow-icon .fg-soil {
  transition: transform 0.4s ease, opacity 0.4s ease;
  transform-origin: 32px 76px;
}

/* Hover: grow into full tree */
.corner-forest:hover .fg-trunk {
  transform: scaleY(1);
}

.corner-forest:hover .fg-sprout-l {
  opacity: 0;
  transform: translateX(-10px) scale(0.2);
}

.corner-forest:hover .fg-sprout-r {
  opacity: 0;
  transform: translateX(10px) scale(0.2);
}

.corner-forest:hover .fg-canopy {
  transform: scale(1);
  opacity: 1;
}

.corner-forest:hover .fg-soil {
  transform: scaleX(1.3);
  opacity: 0.5;
}

/* ---- Hover: icon grows, color shifts ---- */
.corner-forest:hover .corner-icon { color: var(--forest-bright); transform: scale(1.4); }
.corner-forest:hover .corner-label { color: var(--forest-bright); }
.corner-forest:hover .corner-glow { opacity: 1; background: radial-gradient(ellipse at 50% 50%, rgba(123,201,111,0.15) 0%, transparent 70%); }

/* ============================================
   Ocean: Calm → Turbulent water animation
   ============================================ */

/* Let waves flow past SVG edges */
.ocean-waves-icon {
  overflow: visible;
}

/* Waves: gentle drift by default */
.ocean-waves-icon .ow-wave {
  transition: all 0.5s ease;
}

.ocean-waves-icon .ow-wave1 {
  animation: calmDrift1 4s ease-in-out infinite;
}
.ocean-waves-icon .ow-wave2 {
  animation: calmDrift2 5s ease-in-out infinite;
}
.ocean-waves-icon .ow-wave3 {
  animation: calmDrift3 6s ease-in-out infinite;
}

@keyframes calmDrift1 {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(3px); }
}
@keyframes calmDrift2 {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(-2px); }
}
@keyframes calmDrift3 {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(2px); }
}

/* Splash drops: hidden by default */
.ocean-waves-icon .ow-drop {
  transition: opacity 0.3s ease;
}

/* Foam: hidden by default */
.ocean-waves-icon .ow-foam {
  transition: opacity 0.4s ease;
}

/* ---- Hover: smooth bouncy sloshing ---- */
.corner-ocean:hover .corner-icon { color: var(--ocean-foam); transform: scale(1.4); }
.corner-ocean:hover .corner-label { color: var(--ocean-foam); }
.corner-ocean:hover .corner-glow { opacity: 1; background: radial-gradient(ellipse at 50% 50%, rgba(61,157,217,0.2) 0%, transparent 70%); }

/* Waves flow in smooth continuous loops — no hard reversals */
.corner-ocean:hover .ow-wave1 {
  animation: slosh1 3s ease-in-out infinite;
  opacity: 1;
}
.corner-ocean:hover .ow-wave2 {
  animation: slosh2 3.5s ease-in-out infinite;
  opacity: 0.85;
}
.corner-ocean:hover .ow-wave3 {
  animation: slosh3 4s ease-in-out infinite;
  opacity: 0.6;
}

@keyframes slosh1 {
  0%   { transform: translateX(0) translateY(0); }
  20%  { transform: translateX(-5px) translateY(-1.5px); }
  50%  { transform: translateX(2px) translateY(1px); }
  75%  { transform: translateX(5px) translateY(-0.5px); }
  100% { transform: translateX(0) translateY(0); }
}

@keyframes slosh2 {
  0%   { transform: translateX(0) translateY(0); }
  25%  { transform: translateX(4px) translateY(1px); }
  55%  { transform: translateX(-3px) translateY(-1px); }
  80%  { transform: translateX(-5px) translateY(0.5px); }
  100% { transform: translateX(0) translateY(0); }
}

@keyframes slosh3 {
  0%   { transform: translateX(0) translateY(0); }
  30%  { transform: translateX(-3px) translateY(1px); }
  60%  { transform: translateX(4px) translateY(-0.5px); }
  85%  { transform: translateX(2px) translateY(1px); }
  100% { transform: translateX(0) translateY(0); }
}

/* Soft droplets float in gentle loops */
.corner-ocean:hover .ow-drop { opacity: 0.45; }
.corner-ocean:hover .ow-drop1 { animation: dropFloat1 3.2s ease-in-out infinite; }
.corner-ocean:hover .ow-drop2 { animation: dropFloat2 3.6s ease-in-out infinite; }
.corner-ocean:hover .ow-drop3 { animation: dropFloat1 3.8s ease-in-out 0.5s infinite; }
.corner-ocean:hover .ow-drop4 { animation: dropFloat2 3.4s ease-in-out 0.3s infinite; }
.corner-ocean:hover .ow-drop5 { animation: dropFloat1 4s ease-in-out 0.7s infinite; }

@keyframes dropFloat1 {
  0%   { transform: translate(0, 0); }
  30%  { transform: translate(1px, -3px); }
  60%  { transform: translate(-1px, -1px); }
  100% { transform: translate(0, 0); }
}

@keyframes dropFloat2 {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(-1.5px, -2px); }
  65%  { transform: translate(1px, -4px); }
  100% { transform: translate(0, 0); }
}

/* Foam drifts in a gentle loop */
.corner-ocean:hover .ow-foam {
  opacity: 0.35;
  animation: foamDrift 3.5s ease-in-out infinite;
}

@keyframes foamDrift {
  0%   { transform: translateX(0); }
  40%  { transform: translateX(3px); }
  70%  { transform: translateX(-2px); }
  100% { transform: translateX(0); }
}

/* Tech: Apple logo — black to match sticker, small, smooth grow */
.tech-apple {
  width: clamp(30px, 4vw, 50px);
  height: clamp(30px, 4vw, 50px);
  object-fit: contain;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,0.3));
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================
   Tech: Electricity arcing across the label
   ============================================ */
.corner-tech .corner-label {
  position: relative;
  transform: translate(4%, 10px);
}

/* Electric bolt that bounces across the top of the word */
.corner-tech .corner-label::before {
  content: '';
  position: absolute;
  width: 25%;
  height: 14px;
  top: -10px;
  left: -10%;
  opacity: 0;
  pointer-events: none;
  background: var(--tech-cyan);
  filter: drop-shadow(0 0 4px rgba(0,217,255,0.9)) drop-shadow(0 0 10px rgba(0,217,255,0.5));
  transition: opacity 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  clip-path: polygon(
    0% 50%, 8% 15%, 16% 65%, 24% 25%, 32% 75%, 40% 20%,
    48% 70%, 56% 30%, 64% 80%, 72% 15%, 80% 60%, 88% 25%,
    96% 70%, 100% 50%,
    100% 55%,
    96% 75%, 88% 30%, 80% 65%, 72% 20%, 64% 85%, 56% 35%,
    48% 75%, 40% 25%, 32% 80%, 24% 30%, 16% 70%, 8% 20%,
    0% 55%
  );
}

/* Second bolt going in opposite direction */
.corner-tech .corner-label::after {
  content: '';
  position: absolute;
  width: 20%;
  height: 10px;
  top: -7px;
  right: -10%;
  opacity: 0;
  pointer-events: none;
  background: rgba(0, 217, 255, 0.6);
  filter: drop-shadow(0 0 3px rgba(0,217,255,0.7)) drop-shadow(0 0 8px rgba(0,217,255,0.3));
  transition: opacity 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  clip-path: polygon(
    0% 45%, 10% 80%, 20% 20%, 30% 70%, 40% 30%, 50% 75%,
    60% 15%, 70% 65%, 80% 25%, 90% 80%, 100% 45%,
    100% 55%,
    90% 85%, 80% 30%, 70% 70%, 60% 20%, 50% 80%, 40% 35%,
    30% 75%, 20% 25%, 10% 85%, 0% 55%
  );
}

/* Bottom bolts via inner span */
.tech-label-inner {
  position: relative;
}

.tech-label-inner::before {
  content: '';
  position: absolute;
  width: 25%;
  height: 14px;
  bottom: -10px;
  left: -10%;
  opacity: 0;
  pointer-events: none;
  background: var(--tech-cyan);
  filter: drop-shadow(0 0 4px rgba(0,217,255,0.9)) drop-shadow(0 0 10px rgba(0,217,255,0.5));
  clip-path: polygon(
    0% 50%, 8% 15%, 16% 65%, 24% 25%, 32% 75%, 40% 20%,
    48% 70%, 56% 30%, 64% 80%, 72% 15%, 80% 60%, 88% 25%,
    96% 70%, 100% 50%,
    100% 55%,
    96% 75%, 88% 30%, 80% 65%, 72% 20%, 64% 85%, 56% 35%,
    48% 75%, 40% 25%, 32% 80%, 24% 30%, 16% 70%, 8% 20%,
    0% 55%
  );
}

.tech-label-inner::after {
  content: '';
  position: absolute;
  width: 20%;
  height: 10px;
  bottom: -7px;
  right: -10%;
  opacity: 0;
  pointer-events: none;
  background: rgba(0, 217, 255, 0.6);
  filter: drop-shadow(0 0 3px rgba(0,217,255,0.7)) drop-shadow(0 0 8px rgba(0,217,255,0.3));
  clip-path: polygon(
    0% 45%, 10% 80%, 20% 20%, 30% 70%, 40% 30%, 50% 75%,
    60% 15%, 70% 65%, 80% 25%, 90% 80%, 100% 45%,
    100% 55%,
    90% 85%, 80% 30%, 70% 70%, 60% 20%, 50% 80%, 40% 35%,
    30% 75%, 20% 25%, 10% 85%, 0% 55%
  );
}

/* Hover: jagged bolt bounces across the top + jitters */
.corner-tech:hover .corner-label {
  color: var(--tech-cyan);
  text-shadow: 0 0 6px rgba(0,217,255,0.6), 0 0 15px rgba(0,217,255,0.3);
}

.corner-tech:hover .corner-label::before {
  opacity: 1;
  animation: boltBounce 2.5s cubic-bezier(0.34, 1.56, 0.64, 1) infinite,
             boltJitter 0.12s ease-in-out infinite;
}

.corner-tech:hover .corner-label::after {
  opacity: 1;
  animation: boltBounceReverse 3s cubic-bezier(0.34, 1.56, 0.64, 1) 0.8s infinite,
             boltJitter 0.1s ease-in-out infinite;
}

/* Bottom bolts */
.corner-tech:hover .tech-label-inner::before {
  opacity: 1;
  animation: boltBounce 2.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.4s infinite,
             boltJitter 0.11s ease-in-out infinite;
}

.corner-tech:hover .tech-label-inner::after {
  opacity: 1;
  animation: boltBounceReverse 2.6s cubic-bezier(0.34, 1.56, 0.64, 1) 1.2s infinite,
             boltJitter 0.13s ease-in-out infinite;
}

@keyframes boltBounce {
  0%   { left: -10%; opacity: 0; width: 20%; }
  8%   { opacity: 1; }
  25%  { left: 10%; width: 30%; }
  50%  { left: 45%; width: 22%; }
  75%  { left: 75%; width: 28%; }
  92%  { opacity: 1; }
  100% { left: 100%; opacity: 0; width: 18%; }
}

@keyframes boltBounceReverse {
  0%   { right: -10%; opacity: 0; width: 15%; }
  8%   { opacity: 0.8; }
  30%  { right: 15%; width: 25%; }
  55%  { right: 50%; width: 18%; }
  80%  { right: 80%; width: 22%; }
  92%  { opacity: 0.8; }
  100% { right: 105%; opacity: 0; width: 14%; }
}

@keyframes boltJitter {
  0%   { transform: translateY(0); }
  25%  { transform: translateY(-2px); }
  50%  { transform: translateY(1px); }
  75%  { transform: translateY(-1px); }
  100% { transform: translateY(0); }
}

/* Board hover also triggers electricity on the label */
.corner-tech-board:hover ~ .corner-tech .corner-label {
  color: var(--tech-cyan);
  text-shadow: 0 0 6px rgba(0,217,255,0.6), 0 0 15px rgba(0,217,255,0.3);
}
.corner-tech-board:hover ~ .corner-tech .corner-label::before {
  opacity: 1;
  animation: boltBounce 2.5s cubic-bezier(0.34, 1.56, 0.64, 1) infinite,
             boltJitter 0.12s ease-in-out infinite;
}
.corner-tech-board:hover ~ .corner-tech .corner-label::after {
  opacity: 1;
  animation: boltBounceReverse 3s cubic-bezier(0.34, 1.56, 0.64, 1) 0.8s infinite,
             boltJitter 0.1s ease-in-out infinite;
}
.corner-tech-board:hover ~ .corner-tech .tech-label-inner::before {
  opacity: 1;
  animation: boltBounce 2.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.4s infinite,
             boltJitter 0.11s ease-in-out infinite;
}
.corner-tech-board:hover ~ .corner-tech .tech-label-inner::after {
  opacity: 1;
  animation: boltBounceReverse 2.6s cubic-bezier(0.34, 1.56, 0.64, 1) 1.2s infinite,
             boltJitter 0.13s ease-in-out infinite;
}

.corner-tech:hover .corner-glow { opacity: 1; background: radial-gradient(ellipse at 50% 50%, rgba(0,217,255,0.15) 0%, transparent 70%); }

.corner-mind:hover .corner-icon { color: var(--mind-accent); transform: scale(1.4); }
.corner-mind:hover .corner-label { color: var(--mind-accent); }
.corner-mind:hover .corner-glow { opacity: 1; background: radial-gradient(ellipse at 50% 50%, rgba(157,78,221,0.2) 0%, transparent 70%); }

/* Ambient canvas */
.homescreen-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}
