/* ============================================================
   /assets/home/home.css
   Home background & wallpaper handling
   ✅ ENHANCED: Finance widget styles
   FIXED: Wallpaper isolated to homepage only
   ============================================================ */

/* ------------------------------------------------------------
   HOMEPAGE LAYER - Dedicated container for desktop background
   ------------------------------------------------------------ */

/* ✅ CRITICAL: Homepage container styling */
#homeRoot {
  position: fixed;
  inset: 0;
  top: var(--desktop-header-h, 32px);
  bottom: 0;
  z-index: 1; /* Below windows (10+) but above body */
  background-color: transparent; /* ✅ Transparent - no color blocking wallpaper */
  overflow: hidden;
}

/* ✅ WALLPAPER LAYER - Crystal clear, no filters, NO DEFAULT IMAGE */
#homeRoot::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  /* ✅ NO default background-image - controlled by profile.js */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  transition: background-image 0.3s ease;
  /* ✅ NO filters, NO blur, NO opacity */
  filter: none;
  backdrop-filter: none;
  opacity: 1;
}

/* iOS Safari fix for wallpaper */
@supports (-webkit-touch-callout: none) {
  #homeRoot::before {
    background-attachment: scroll;
  }
}

/* ✅ Content inside homeRoot should be visible above wallpaper */
#homeRoot > * {
  position: relative;
  z-index: 1;
}

/* ------------------------------------------------------------
   HOME SHELL & OVERLAY
   ------------------------------------------------------------ */
.home-shell {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: #eef3ff;
  overflow: hidden;
  background: transparent;
}

.home-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(
    circle at top, 
    rgba(3, 4, 6, 0.3) 0%, 
    rgba(3, 4, 6, 0) 50%
  );
  z-index: 1;
}

:root[data-theme="light"] .home-overlay {
  background: radial-gradient(
    circle at top, 
    rgba(255, 255, 255, 0.2) 0%, 
    rgba(255, 255, 255, 0) 50%
  );
}

/* =========================================================
   WIDGET AREA - Fixed position on body (top-right)
   Appended to body to avoid homeRoot overflow:hidden clipping
   Adapts to browser vs standalone/PWA mode
   ========================================================= */
.widget-area {
  position: fixed;
  /* Desktop header is 32px, plus padding. Use safe-area for notch devices */
  top: calc(var(--desktop-header-h, 32px) + var(--safe-top, env(safe-area-inset-top, 0)) + 16px);
  right: calc(var(--safe-right, env(safe-area-inset-right, 0)) + 24px);
  z-index: 100;  /* Above content, below windows */
  
  /* Desktop: ~40% width, constrained */
  width: calc(40% - 48px);
  max-width: 400px;
  min-width: 280px;
  
  pointer-events: none;
  background: transparent;
}

/* Standalone/PWA mode - adjust for no browser chrome */
@media (display-mode: standalone) {
  .widget-area {
    top: calc(env(safe-area-inset-top, 0) + var(--desktop-header-h, 32px) + 16px);
  }
}

/* iOS standalone mode */
.ios-standalone .widget-area {
  top: calc(env(safe-area-inset-top, 0) + var(--desktop-header-h, 32px) + 16px);
}

/* =========================================================
   FINANCE WIDGET - Fills the widget area
   ========================================================= */
.finance-widget {
  pointer-events: auto;
  
  /* Fit within the widget area */
  width: 100%;
  min-height: 140px;
  
  /* Frosted glass effect */
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 20px;
  
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  
  /* Center content */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 32px;
  box-sizing: border-box;
  
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.finance-widget:hover {
  background: rgba(255, 255, 255, 0.14);
  box-shadow: 
    0 12px 40px rgba(0, 0, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.widget-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
}

/* ✅ All text green */
.widget-label {
  font-size: 14px;
  font-weight: 600;
  color: #10b981;
  text-transform: uppercase;
  letter-spacing: 2px;
  text-shadow: 0 0 20px rgba(16, 185, 129, 0.3);
}

.widget-value {
  font-size: 48px;
  font-weight: 700;
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
  color: #10b981;
  text-shadow: 0 0 30px rgba(16, 185, 129, 0.4);
}

.widget-value.loading {
  color: rgba(16, 185, 129, 0.5);
  font-size: 18px;
  font-weight: 500;
  text-shadow: none;
}

.widget-value.error {
  color: rgba(16, 185, 129, 0.3);
  text-shadow: none;
}

/* Light mode widget - still green */
:root[data-theme="light"] .finance-widget {
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(16, 185, 129, 0.2);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(16, 185, 129, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

:root[data-theme="light"] .finance-widget:hover {
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 
    0 12px 40px rgba(0, 0, 0, 0.12),
    0 0 0 1px rgba(16, 185, 129, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

:root[data-theme="light"] .widget-label {
  color: #059669;
  text-shadow: none;
}

:root[data-theme="light"] .widget-value {
  color: #059669;
  text-shadow: none;
}

:root[data-theme="light"] .widget-value.loading,
:root[data-theme="light"] .widget-value.error {
  color: rgba(5, 150, 105, 0.4);
}

/* =========================================================
   UPLOAD WIDGET - Shows during active uploads
   ========================================================= */
.upload-widget {
  pointer-events: auto;
  margin-top: 16px;
  
  /* Fit within the widget area */
  width: 100%;
  
  /* Frosted glass effect */
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  
  padding: 16px 20px;
  box-sizing: border-box;
  
  /* Animation */
  opacity: 0;
  transform: translateY(-10px);
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.3s ease;
}

.upload-widget.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Active uploading state - blue accent */
.upload-widget.active {
  border-color: rgba(10, 132, 255, 0.4);
  box-shadow: 
    0 8px 32px rgba(10, 132, 255, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* Success state - green accent */
.upload-widget.success {
  border-color: rgba(52, 199, 89, 0.4);
  box-shadow: 
    0 8px 32px rgba(52, 199, 89, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* Warning state - orange accent */
.upload-widget.warning {
  border-color: rgba(255, 149, 0, 0.4);
  box-shadow: 
    0 8px 32px rgba(255, 149, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.upload-widget-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.upload-widget-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.upload-widget-icon {
  font-size: 18px;
}

.upload-widget-label {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: 1px;
  flex: 1;
}

.upload-widget-pct {
  font-size: 14px;
  font-weight: 700;
  color: #0A84FF;
  font-variant-numeric: tabular-nums;
}

.upload-widget.success .upload-widget-pct {
  color: #34C759;
}

.upload-widget.warning .upload-widget-pct {
  color: #FF9500;
}

.upload-widget-status {
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.upload-widget-progress {
  height: 4px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 4px;
}

.upload-widget-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, #0A84FF, #5AC8FA);
  border-radius: 2px;
  transition: width 0.3s ease;
}

.upload-widget.success .upload-widget-progress-bar {
  background: linear-gradient(90deg, #34C759, #30D158);
}

.upload-widget.warning .upload-widget-progress-bar {
  background: linear-gradient(90deg, #FF9500, #FFCC00);
}

.upload-widget-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
}

.upload-widget-bytes {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  font-variant-numeric: tabular-nums;
}

.upload-widget-clear {
  background: rgba(255, 255, 255, 0.1);
  border: none;
  border-radius: 4px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  padding: 4px 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  line-height: 1;
}

.upload-widget-clear:hover {
  background: rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.9);
}

/* Light mode upload widget */
:root[data-theme="light"] .upload-widget {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(0, 0, 0, 0.1);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

:root[data-theme="light"] .upload-widget.active {
  border-color: rgba(10, 132, 255, 0.3);
}

:root[data-theme="light"] .upload-widget.success {
  border-color: rgba(52, 199, 89, 0.3);
}

:root[data-theme="light"] .upload-widget.warning {
  border-color: rgba(255, 149, 0, 0.3);
}

:root[data-theme="light"] .upload-widget-label {
  color: rgba(0, 0, 0, 0.5);
}

:root[data-theme="light"] .upload-widget-status {
  color: rgba(0, 0, 0, 0.85);
}

:root[data-theme="light"] .upload-widget-bytes {
  color: rgba(0, 0, 0, 0.5);
}

:root[data-theme="light"] .upload-widget-pct {
  color: #007AFF;
}

:root[data-theme="light"] .upload-widget.success .upload-widget-pct {
  color: #28A745;
}

:root[data-theme="light"] .upload-widget.warning .upload-widget-pct {
  color: #E67E00;
}

:root[data-theme="light"] .upload-widget-clear {
  background: rgba(0, 0, 0, 0.05);
  color: rgba(0, 0, 0, 0.5);
}

:root[data-theme="light"] .upload-widget-clear:hover {
  background: rgba(0, 0, 0, 0.1);
  color: rgba(0, 0, 0, 0.8);
}

:root[data-theme="light"] .upload-widget-progress {
  background: rgba(0, 0, 0, 0.1);
}

/* Exception for upload widget - needs backdrop-filter */
#homeRoot .upload-widget,
.widget-area .upload-widget {
  backdrop-filter: blur(24px) saturate(1.5) !important;
  -webkit-backdrop-filter: blur(24px) saturate(1.5) !important;
}

/* Mobile adjustments for upload widget */
@media (max-width: 768px) {
  .upload-widget {
    margin-top: 12px;
    padding: 12px 16px;
    border-radius: 12px;
  }
  
  .upload-widget-icon {
    font-size: 16px;
  }
  
  .upload-widget-label {
    font-size: 10px;
  }
  
  .upload-widget-pct {
    font-size: 12px;
  }
  
  .upload-widget-status {
    font-size: 13px;
  }
  
  .upload-widget-bytes {
    font-size: 10px;
  }
  
  .upload-widget-clear {
    font-size: 10px;
    padding: 3px 6px;
  }
}

/* ------------------------------------------------------------
   LIGHT MODE - Wallpaper hidden, gradient shown
   ------------------------------------------------------------ */

:root[data-theme="light"] #homeRoot {
  background-color: #f0f2f5;
}

:root[data-theme="light"] #homeRoot::before {
  background-image: none !important;
  background: linear-gradient(135deg, #f5f7fa 0%, #e8ebf0 100%) !important;
}

/* ------------------------------------------------------------
   MOBILE ADJUSTMENTS
   ------------------------------------------------------------ */

@media (max-width: 768px) {
  #homeRoot {
    top: var(--mobile-header-h, 69px);
  }
  
  .home-shell {
    padding-top: var(--mobile-header-h, 69px);
  }

  /* Mobile widget area: Top center, fixed */
  .widget-area {
    top: calc(var(--mobile-header-h, 69px) + env(safe-area-inset-top, 0) + 16px);
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    
    /* Centered width */
    width: calc(60% - 32px);
    min-width: 240px;
    max-width: 300px;
  }
  
  .finance-widget {
    min-height: 100px;
    padding: 16px 24px;
  }

  .widget-value {
    font-size: 32px;
  }
  
  .widget-label {
    font-size: 11px;
    letter-spacing: 1.5px;
  }
  
  .widget-content {
    gap: 8px;
  }
}

/* iOS standalone on mobile */
@media (max-width: 768px) and (display-mode: standalone) {
  .widget-area {
    top: calc(env(safe-area-inset-top, 0) + var(--mobile-header-h, 69px) + 16px);
  }
}

/* ------------------------------------------------------------
   BODY - No wallpaper, solid background only
   ------------------------------------------------------------ */

body {
  background-color: #0f1522; /* Solid fallback for areas outside homeRoot */
  background-image: none;
  position: relative;
  overflow-x: hidden;
  overflow-y: auto;
  transition: background-color 0.3s ease;
  /* ✅ NO filters on body */
  filter: none;
  backdrop-filter: none;
}

/* ✅ REMOVE global body::before wallpaper */
body::before {
  display: none !important;
}

/* ✅ Ensure NO filters affect homeRoot visibility */
#homeRoot,
#homeRoot::before,
#homeRoot * {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Exception for finance widget - it needs backdrop-filter */
#homeRoot .finance-widget,
.widget-area .finance-widget {
  backdrop-filter: blur(24px) saturate(1.5) !important;
  -webkit-backdrop-filter: blur(24px) saturate(1.5) !important;
}

:root[data-theme="light"] body {
  background-color: #f0f2f5;
}

/* ✅ ENSURE ALL CONTENT IS ABOVE HOMEPAGE */
#moduleRoot,
.app-window,
.app-launcher {
  position: relative;
  z-index: 10;
}

/* ✅ Header and dock have their own fixed positioning - don't override */
.desktop-header,
.desktop-dock {
  z-index: 15000 !important;
}

/* =========================================================
   IFRAME WALLPAPER BLOCKING - CRITICAL
   Prevent wallpaper from ever showing inside iframes
   ========================================================= */

/* ✅ Block wallpaper completely when inside iframe */
body.in-iframe #homeRoot::before {
  display: none !important;
  background-image: none !important;
  content: none !important;
}

body.in-iframe #homeRoot {
  background-color: transparent !important;
  background-image: none !important;
  display: none !important;
}

/* ✅ Force solid backgrounds in iframes */
body.in-iframe {
  background-color: #0f1522 !important;
  background-image: none !important;
}

body.in-iframe #moduleRoot {
  background-color: #0f1522 !important;
  background-image: none !important;
}

/* ✅ Light mode iframe backgrounds */
:root[data-theme="light"] body.in-iframe {
  background-color: #f0f2f5 !important;
}

:root[data-theme="light"] body.in-iframe #moduleRoot {
  background-color: #f0f2f5 !important;
}

/* =========================================================
   CRYSTAL CLEAR WALLPAPER - NO OVERLAYS OR FILTERS
   ========================================================= */

/* ✅ Ensure wallpaper displays at maximum quality */
#homeRoot::before {
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  will-change: background-image;
}

/* ✅ Prevent any global filters from affecting wallpaper */
body:not(.in-iframe) {
  filter: none !important;
}

/* ✅ Ensure dock/header backdrop-filters don't blur wallpaper */
.desktop-dock,
.desktop-header {
  isolation: isolate; /* Isolate backdrop-filter to element only */
} 