/* ============================================================
   DocOS — styles.css — Premium Dark SaaS
   ============================================================ */

/* ---------- Theme Variables ---------- */
:root {
  --accent: #3B82F6;
  --accent-glow: rgba(59,130,246,0.25);
  --accent-soft: rgba(59,130,246,0.12);
  --bg: #050507;
  --bg2: #0A0A0E;
  --bg3: #0F1014;
  --bg4: #16171D;
  --bg5: #1E1F27;
  --border: rgba(255,255,255,0.06);
  --border-accent: rgba(59,130,246,0.35);
  --text: #EEEEF2;
  --text2: #8B8D9A;
  --text3: #4A4C5A;
  --danger: #EF4444;
  --success: #22C55E;
  --warning: #F59E0B;
  --radius: 18px;
  --radius-sm: 12px;
  --radius-xs: 8px;
  --transition: 0.2s ease;
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;
  --dock-h: 80px;
  --topbar-h: 56px;
  --docos-shell-h: 100svh;
  --docos-vvh: 100dvh;
  --glass: rgba(15,16,20,0.72);
  --glass-border: rgba(255,255,255,0.07);
  --card-bg: linear-gradient(145deg, rgba(15,16,20,0.85) 0%, rgba(22,23,29,0.6) 100%);
  --card-shadow: 0 2px 8px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.03) inset;
}

[data-theme="black-blue"] {
  --accent: #3B82F6;
  --accent-glow: rgba(59,130,246,0.25);
  --accent-soft: rgba(59,130,246,0.12);
  --border-accent: rgba(59,130,246,0.35);
}
[data-theme="black-yellow"] {
  --accent: #EAB308;
  --accent-glow: rgba(234,179,8,0.25);
  --accent-soft: rgba(234,179,8,0.12);
  --border-accent: rgba(234,179,8,0.35);
}
[data-theme="black-red"] {
  --accent: #EF4444;
  --accent-glow: rgba(239,68,68,0.25);
  --accent-soft: rgba(239,68,68,0.12);
  --border-accent: rgba(239,68,68,0.35);
}
[data-theme="black-green"] {
  --accent: #22C55E;
  --accent-glow: rgba(34,197,94,0.25);
  --accent-soft: rgba(34,197,94,0.12);
  --border-accent: rgba(34,197,94,0.35);
}
[data-theme="black-orange"] {
  --accent: #F97316;
  --accent-glow: rgba(249,115,22,0.25);
  --accent-soft: rgba(249,115,22,0.12);
  --border-accent: rgba(249,115,22,0.35);
}
[data-theme="chameleon"] {
  --accent: #A855F7;
  --accent-glow: rgba(168,85,247,0.25);
  --accent-soft: rgba(168,85,247,0.12);
  --border-accent: rgba(168,85,247,0.35);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
/* iOS-stable shell: html and body fill the visual viewport exactly,
   no scrolling at the document level. The app is absolutely positioned
   inside body, which acts as a relative stage. This is the pattern used by
   Twitter Lite, Pinterest PWA, etc. — it does not drift on iOS keyboard. */
html {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: var(--bg);
  overscroll-behavior: none;
}
body {
  position: relative;
  width: 100%;
  height: 100%;
  height: 100dvh;
  margin: 0;
  padding: 0;
  overflow: hidden;
  /* Background is rendered by a fixed pseudo-element on its own GPU layer.
     Body itself stays transparent so adding/removing content (image previews,
     modals, cinema iframe) never triggers a body-wide background repaint. */
  background: transparent;
  overscroll-behavior: none;
  font-family: var(--font);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  touch-action: pan-y;
}
/* Stable, never-repainted background layer. Lives on its own composite
   layer (transform + will-change). contain: strict prevents any
   descendant change from invalidating it. This is the iPhone app pattern:
   the background is "below the world" and absolutely cannot be jiggled
   by content edits, uploads, or video playback. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: -1;
  pointer-events: none;
  transform: translateZ(0);
  will-change: transform;
  contain: strict;
}

button { background: none; border: none; cursor: pointer; color: inherit; font-family: inherit; }
input, select, textarea { font-family: inherit; }
a { color: var(--accent); }

/* ---------- App Shell ----------
   #app is ABSOLUTELY positioned inside the relative body.
   This is the canonical native-PWA pattern that survives iOS keyboard, scroll, swipe.
   Centering: inset:0 fills the body, max-width:430px caps it on tablets,
   margin:0 auto centers it. No transforms, no position:fixed quirks. */
#app {
  display: flex;
  flex-direction: column;
  position: absolute;
  inset: 0;
  margin: 0 auto;
  width: 100%;
  max-width: 430px;
  overflow: hidden;
  /* Transparent shell — the stable background lives on body::before so
     content changes never invalidate the painted background. */
  background: transparent;
  contain: layout paint style;
  isolation: isolate;
  transform: translateZ(0);
  will-change: transform;
  -webkit-backface-visibility: hidden;
}


/* ---------- Topbar ---------- */
.topbar {
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-left: max(1rem, env(safe-area-inset-left, 0px));
  padding-right: max(1rem, env(safe-area-inset-right, 0px));
  padding-top: max(0px, env(safe-area-inset-top, 0px));
  background: var(--glass);
  backdrop-filter: blur(24px) saturate(1.3);
  -webkit-backdrop-filter: blur(24px) saturate(1.3);
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
  z-index: 10;
  contain: paint;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.topbar-left { display: flex; align-items: center; gap: 0.5rem; }
.app-logo { font-size: 1.2rem; font-weight: 900; letter-spacing: -0.5px; color: var(--accent); }
.app-version { font-size: 0.58rem; color: var(--accent); background: var(--accent-soft); padding: 2px 8px; border-radius: 20px; font-weight: 700; letter-spacing: 0.3px; }
.topbar-right { display: flex; gap: 0.35rem; }
.icon-btn { width: 38px; height: 38px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1rem; background: var(--bg4); border: 1px solid var(--glass-border); transition: all 0.2s ease; }
.icon-btn:active { background: var(--bg5); transform: scale(0.93); border-color: var(--accent); }

/* ---------- Main Content ---------- */
#mainContent {
  flex: 1;
  min-height: 0;
  position: relative;
  overflow: hidden;
  overflow: clip;
  contain: layout paint;
}

/* ---------- Screens ---------- */
.screen {
  position: absolute;
  inset: 0;
  min-height: 0;
  display: none;
  flex-direction: column;
}
.screen.active { display: flex; }
.screen-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: none;
  overscroll-behavior-x: none;
  scrollbar-gutter: stable;
  touch-action: pan-y;
  padding-top: 1rem;
  padding-left: max(1rem, env(safe-area-inset-left, 0px));
  padding-right: max(1rem, env(safe-area-inset-right, 0px));
  padding-bottom: calc(var(--dock-h) + 1rem + env(safe-area-inset-bottom, 0px));
  scroll-padding-top: 1rem;
  contain: content;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.screen-scroll::-webkit-scrollbar { display: none; }

/* ---------- Bottom Dock ---------- */
.bottom-dock {
  position: relative;
  isolation: isolate;
  overflow: visible;
  height: var(--dock-h);
  padding-bottom: env(safe-area-inset-bottom, 16px);
  background:
    radial-gradient(110px 54px at 18% 16%, rgba(96,165,250,0.15) 0%, transparent 72%),
    radial-gradient(120px 60px at 50% 10%, color-mix(in srgb, var(--accent) 22%, transparent) 0%, transparent 70%),
    radial-gradient(110px 54px at 82% 14%, rgba(255,193,77,0.12) 0%, transparent 74%),
    linear-gradient(180deg, rgba(14,14,18,0.82) 0%, rgba(5,5,8,0.97) 100%);
  backdrop-filter: blur(28px) saturate(1.16);
  -webkit-backdrop-filter: blur(28px) saturate(1.16);
  border-top: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 -1px 0 rgba(255,255,255,0.04) inset,
    0 -30px 80px rgba(0,0,0,0.48);
  display: flex;
  align-items: flex-start;
  justify-content: space-around;
  padding-top: 8px;
  padding-left: max(8px, env(safe-area-inset-left, 0px));
  padding-right: max(8px, env(safe-area-inset-right, 0px));
  flex-shrink: 0;
  z-index: 100;
  contain: paint;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.bottom-dock::before,
.bottom-dock::after {
  content: '';
  position: absolute;
  pointer-events: none;
  inset: 0;
}
.bottom-dock::before {
  top: -1px;
  height: 1px;
  inset-inline: 18px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.12) 16%, rgba(255,255,255,0.04) 52%, rgba(255,255,255,0.10) 86%, transparent 100%);
  opacity: 0.9;
}
.bottom-dock::after {
  inset: auto 10% 16px;
  height: 54px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(96,165,250,0.12) 0%, rgba(96,165,250,0.05) 28%, transparent 72%);
  filter: blur(18px);
  opacity: 0.7;
}

.dock-btn {
  --dock-fx: rgba(96,165,250,0.95);
  --dock-fx-soft: rgba(96,165,250,0.16);
  --dock-fx-border: rgba(96,165,250,0.28);
  --dock-fx-text: #9cc5ff;
  --dock-hit-bg: color-mix(in srgb, var(--dock-fx) 8%, transparent);
  position: relative;
  isolation: isolate;
  overflow: visible;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  padding: 7px 14px 7px;
  min-width: 62px;
  border-radius: 22px;
  border: 1px solid transparent;
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 220ms cubic-bezier(.22,.9,.25,1),
    border-color 220ms ease,
    background-color 220ms ease,
    box-shadow 260ms ease,
    filter 220ms ease;
}
.dock-btn::before,
.dock-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  opacity: 0;
  transition: opacity 220ms ease, transform 260ms ease, filter 260ms ease;
}
.dock-btn::before {
  inset: auto 10px -8px;
  height: 12px;
  border-radius: 999px;
  background: radial-gradient(circle, var(--dock-fx) 0%, color-mix(in srgb, var(--dock-fx) 72%, transparent) 34%, transparent 74%);
  filter: blur(12px);
  transform: translateY(4px) scaleX(0.72);
}
.dock-btn::after {
  inset: 1px;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 18%, rgba(255,255,255,0.01) 48%, transparent 100%),
    linear-gradient(135deg, color-mix(in srgb, var(--dock-fx) 9%, white 12%) 0%, transparent 34%, transparent 64%, color-mix(in srgb, var(--dock-fx) 6%, white 8%) 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.08) inset,
    0 0 0 1px rgba(255,255,255,0.02) inset;
  transform: translateY(4px) scale(0.94);
}
.dock-btn:active { transform: translateY(1px) scale(0.95); }
.dock-btn.dock-pressed { transform: translateY(-1px) scale(0.985); }
.dock-btn.active:not(.dock-center) {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--dock-hit-bg) 75%, rgba(255,255,255,0.05)) 0%, color-mix(in srgb, var(--dock-hit-bg) 42%, rgba(255,255,255,0.02)) 100%);
  border-color: color-mix(in srgb, var(--dock-fx-border) 88%, rgba(255,255,255,0.06));
  box-shadow:
    0 18px 42px color-mix(in srgb, var(--dock-fx) 16%, transparent),
    0 0 0 1px color-mix(in srgb, var(--dock-fx) 16%, transparent),
    0 1px 0 rgba(255,255,255,0.10) inset,
    0 -8px 18px rgba(255,255,255,0.02) inset;
}
.dock-btn.active:not(.dock-center)::before,
.dock-btn.active:not(.dock-center)::after,
.dock-btn.dock-pressed:not(.dock-center)::before,
.dock-btn.dock-pressed:not(.dock-center)::after,
.dock-btn.dock-hit:not(.dock-center)::before,
.dock-btn.dock-hit:not(.dock-center)::after {
  opacity: 1;
}
.dock-btn.dock-pressed:not(.dock-center)::before,
.dock-btn.dock-hit:not(.dock-center)::before { transform: translateY(0) scaleX(1.08); }
.dock-btn.dock-pressed:not(.dock-center)::after,
.dock-btn.dock-hit:not(.dock-center)::after { transform: translateY(0) scale(1); }

.dock-icon {
  position: relative;
  z-index: 1;
  font-size: 1.3rem;
  line-height: 1;
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.06);
  transition: all 240ms cubic-bezier(.22,.9,.25,1);
}
.dock-btn.active:not(.dock-center) .dock-icon {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--dock-fx) 35%, transparent),
    color-mix(in srgb, var(--dock-fx) 15%, transparent));
  border-color: color-mix(in srgb, var(--dock-fx) 40%, transparent);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--dock-fx) 30%, transparent),
    inset 0 1px 0 rgba(255,255,255,0.12);
  transform: translateY(-2px) scale(1.08);
}
.dock-btn:not(.active):not(.dock-center):active .dock-icon {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--dock-fx) 25%, transparent),
    color-mix(in srgb, var(--dock-fx) 10%, transparent));
  border-color: color-mix(in srgb, var(--dock-fx) 30%, transparent);
  transform: scale(0.95);
}
.dock-label {
  position: relative;
  z-index: 1;
  font-size: 0.68rem;
  color: var(--text3);
  letter-spacing: 0.22px;
  font-weight: 580;
  transition: color 220ms ease, transform 220ms ease, opacity 220ms ease, text-shadow 220ms ease;
}
.dock-btn.active .dock-label {
  color: var(--dock-fx-text);
  text-shadow: 0 0 10px color-mix(in srgb, var(--dock-fx) 28%, transparent);
}
.dock-btn.active .dock-label,
.dock-btn.dock-pressed .dock-label,
.dock-btn.dock-hit .dock-label { transform: translateY(-1px); }
.dock-btn.dock-hit:not(.dock-center) {
  box-shadow:
    0 20px 44px color-mix(in srgb, var(--dock-fx) 20%, transparent),
    0 0 0 1px color-mix(in srgb, var(--dock-fx) 18%, transparent),
    0 1px 0 rgba(255,255,255,0.12) inset,
    0 -10px 20px rgba(255,255,255,0.02) inset;
}

.dock-btn[data-fx="home"] {
  --dock-fx: #66a7ff;
  --dock-fx-soft: rgba(84, 131, 255, 0.18);
  --dock-fx-border: rgba(102, 167, 255, 0.34);
  --dock-fx-text: #8eb8ff;
  --dock-hit-bg: rgba(74, 116, 255, 0.18);
}
.dock-btn[data-fx="documents"] {
  --dock-fx: #49d8c1;
  --dock-fx-soft: rgba(34, 211, 190, 0.16);
  --dock-fx-border: rgba(73, 216, 193, 0.28);
  --dock-fx-text: #7fe7d5;
  --dock-hit-bg: rgba(44, 196, 174, 0.18);
}
.dock-btn[data-fx="scan"] {
  --dock-fx: color-mix(in srgb, var(--accent) 95%, white 5%);
  --dock-fx-soft: color-mix(in srgb, var(--accent) 20%, transparent);
  --dock-fx-border: color-mix(in srgb, var(--accent) 38%, transparent);
  --dock-fx-text: white;
}
.dock-btn[data-fx="agent"] {
  --dock-fx: #b16bff;
  --dock-fx-soft: rgba(177, 107, 255, 0.17);
  --dock-fx-border: rgba(177, 107, 255, 0.30);
  --dock-fx-text: #d5b7ff;
  --dock-hit-bg: rgba(177,107,255,0.16);
}
.dock-btn[data-fx="more"] {
  --dock-fx: #ffc14d;
  --dock-fx-soft: rgba(255, 193, 77, 0.15);
  --dock-fx-border: rgba(255, 193, 77, 0.28);
  --dock-fx-text: #ffd98d;
  --dock-hit-bg: rgba(255,193,77,0.16);
}

/* 3D Chameleon active states */
.dock-btn.active:not(.dock-center) {
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--dock-hit-bg) 85%, rgba(255,255,255,0.08)) 0%,
      color-mix(in srgb, var(--dock-hit-bg) 50%, rgba(255,255,255,0.03)) 100%);
  border-color: color-mix(in srgb, var(--dock-fx-border) 95%, rgba(255,255,255,0.08));
  box-shadow:
    0 20px 48px color-mix(in srgb, var(--dock-fx) 22%, transparent),
    0 0 0 1px color-mix(in srgb, var(--dock-fx) 20%, transparent),
    0 1px 0 rgba(255,255,255,0.14) inset,
    0 -10px 24px rgba(255,255,255,0.03) inset;
}
@keyframes dockChameleonBg {
  0% { filter: hue-rotate(0deg) brightness(1); }
  50% { filter: hue-rotate(15deg) brightness(1.05); }
  100% { filter: hue-rotate(-10deg) brightness(1); }
}

/* Icon 3D glow */
.dock-btn.active:not(.dock-center) .dock-icon {
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3)) drop-shadow(0 0 14px color-mix(in srgb, var(--dock-fx) 55%, transparent));
  transform: translateY(-2px) scale(1.12);
}

/* Label active */
.dock-btn.active:not(.dock-center) .dock-label {
  color: var(--dock-fx-text);
  text-shadow: 0 0 10px color-mix(in srgb, var(--dock-fx) 35%, transparent);
}

/* Inactive buttons subtle 3D */
.dock-btn:not(.active):not(.dock-center) .dock-icon {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
  transition: filter 220ms ease, transform 240ms cubic-bezier(.22,.9,.25,1);
}
.dock-btn:not(.active):not(.dock-center):active .dock-icon {
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--dock-fx) 50%, transparent)) drop-shadow(0 2px 3px rgba(0,0,0,0.3));
  transform: translateY(-1px) scale(1.1);
}

.dock-btn[data-fx="home"].active:not(.dock-center) {
  box-shadow:
    0 24px 52px rgba(78,132,255,0.28),
    0 0 0 1px rgba(102,167,255,0.24),
    0 1px 0 rgba(255,255,255,0.16) inset;
}
.dock-btn[data-fx="documents"].active:not(.dock-center) {
  box-shadow:
    0 22px 48px rgba(73,216,193,0.24),
    0 0 0 1px rgba(73,216,193,0.22),
    0 1px 0 rgba(255,255,255,0.14) inset;
}
.dock-btn[data-fx="agent"].active:not(.dock-center) {
  box-shadow:
    0 24px 52px rgba(177,107,255,0.26),
    0 0 0 1px rgba(177,107,255,0.22),
    0 1px 0 rgba(255,255,255,0.14) inset;
}
.dock-btn[data-fx="more"].active:not(.dock-center) {
  box-shadow:
    0 24px 52px rgba(255,193,77,0.24),
    0 0 0 1px rgba(255,193,77,0.22),
    0 1px 0 rgba(255,255,255,0.14) inset;
}

.dock-btn[data-fx="home"].active .dock-icon {
  filter: drop-shadow(0 0 10px rgba(102,167,255,0.5));
}
.dock-btn[data-fx="documents"].active .dock-icon {
  filter: drop-shadow(0 0 10px rgba(73,216,193,0.5));
}
.dock-btn[data-fx="agent"].active .dock-icon {
  filter: drop-shadow(0 0 10px rgba(177,107,255,0.5));
}
.dock-btn[data-fx="more"].active .dock-icon {
  filter: drop-shadow(0 0 10px rgba(255,193,77,0.5));
}
.dock-btn[data-fx="home"].dock-pressed .dock-icon,
.dock-btn[data-fx="home"].dock-hit .dock-icon { animation: dockTapBurst 480ms cubic-bezier(.2,.9,.2,1) 1; }
.dock-btn[data-fx="documents"].dock-pressed .dock-icon,
.dock-btn[data-fx="documents"].dock-hit .dock-icon { animation: dockDocsTap 480ms cubic-bezier(.2,.9,.2,1) 1; }
.dock-btn[data-fx="agent"].dock-pressed .dock-icon,
.dock-btn[data-fx="agent"].dock-hit .dock-icon { animation: dockAgentTap 480ms cubic-bezier(.2,.9,.2,1) 1; }
.dock-btn[data-fx="more"].dock-pressed .dock-icon,
.dock-btn[data-fx="more"].dock-hit .dock-icon { animation: dockMoreTap 480ms cubic-bezier(.2,.9,.2,1) 1; }

.dock-center {
  width: 70px;
  height: 70px;
  margin-top: 2px;
  min-width: unset;
  padding: 0;
  border-radius: 50%;
  overflow: visible;
  background:
    radial-gradient(circle at 30% 18%, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.09) 18%, transparent 34%),
    radial-gradient(circle at 50% 118%, rgba(96,165,250,0.22) 0%, transparent 62%),
    conic-gradient(from 210deg,
      #66a7ff 0deg,
      #49d8c1 72deg,
      #9d6bff 144deg,
      #ff6d8e 216deg,
      #ffc14d 288deg,
      #66a7ff 360deg);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.07) inset,
    0 14px 34px color-mix(in srgb, var(--dock-fx) 22%, transparent),
    0 10px 22px rgba(0,0,0,0.26),
    0 -8px 18px rgba(255,255,255,0.04) inset;
  filter: saturate(1.02) brightness(0.99);
}
.dock-center::before {
  inset: -10px;
  height: auto;
  border-radius: inherit;
  background:
    radial-gradient(circle,
      rgba(102,167,255,0.50) 0%,
      rgba(73,216,193,0.34) 24%,
      rgba(177,107,255,0.28) 46%,
      rgba(255,193,77,0.18) 68%,
      transparent 80%);
  filter: blur(14px);
  transform: scale(0.86);
  opacity: 0.52;
}
.dock-center::after {
  inset: -3px;
  height: auto;
  border-radius: inherit;
  background:
    conic-gradient(from 0deg,
      rgba(102,167,255,0.00) 0deg,
      rgba(102,167,255,0.78) 22deg,
      rgba(73,216,193,0.76) 96deg,
      rgba(157,107,255,0.76) 168deg,
      rgba(255,109,142,0.76) 242deg,
      rgba(255,193,77,0.76) 312deg,
      rgba(102,167,255,0.00) 360deg);
  -webkit-mask: radial-gradient(circle, transparent calc(100% - 7px), #000 calc(100% - 6px));
  mask: radial-gradient(circle, transparent calc(100% - 7px), #000 calc(100% - 6px));
  opacity: 0.44;
  filter: drop-shadow(0 0 7px rgba(102,167,255,0.18));
}
.dock-center .dock-icon {
  position: relative;
  top: 3px;
  z-index: 2;
  font-size: 1.92rem;
  color: white;
  text-shadow: 0 0 14px rgba(255,255,255,0.14);
  transform-origin: 50% 50%;
  background: none;
  border: none;
  width: auto;
  height: auto;
}
.dock-center.active,
.dock-center.dock-pressed,
.dock-center.dock-hit {
  transform: translateY(0) scale(1.03);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.10) inset,
    0 18px 40px color-mix(in srgb, var(--dock-fx) 28%, transparent),
    0 10px 20px rgba(0,0,0,0.28),
    0 -8px 18px rgba(255,255,255,0.05) inset;
  filter: saturate(1.08) brightness(1.01);
}
.dock-center.active::before,
.dock-center.active::after,
.dock-center.dock-pressed::before,
.dock-center.dock-pressed::after,
.dock-center.dock-hit::before,
.dock-center.dock-hit::after {
  opacity: 1;
}
.dock-center.active::before { animation: dockPlusHalo 2.7s ease-in-out infinite, dockPlusHue 4.6s linear infinite; }
.dock-center.active::after { animation: dockPlusRingSpin 3.5s linear infinite, dockPlusHue 3.8s linear infinite; }
.dock-center.active .dock-icon {
  animation: dockPlusActive 2.15s ease-in-out infinite;
}
.dock-center.dock-pressed .dock-icon,
.dock-center.dock-hit .dock-icon {
  animation: dockPlusTapSpin 760ms cubic-bezier(.16,.92,.18,1) 1;
}
.dock-center.dock-pressed::before,
.dock-center.dock-hit::before {
  animation: dockPlusHaloTap 760ms cubic-bezier(.18,.9,.18,1) 1, dockPlusHueFast 880ms linear 1;
}
.dock-center.dock-pressed::after,
.dock-center.dock-hit::after {
  animation: dockPlusRingTap 860ms cubic-bezier(.18,.9,.18,1) 1, dockPlusHueFast 960ms linear 1;
}

@keyframes dockHomePulse {
  0%, 100% { transform: translateY(0) scale(1); text-shadow: 0 0 0 rgba(102,167,255,0); }
  50% { transform: translateY(-1px) scale(1.08); text-shadow: 0 0 16px rgba(102,167,255,0.34); }
}
@keyframes dockDocsLift {
  0%, 100% { transform: translateY(0) rotate(0deg) scale(1); }
  40% { transform: translateY(-2px) rotate(-2deg) scale(1.06); }
  70% { transform: translateY(-1px) rotate(1deg) scale(1.03); }
}
@keyframes dockAgentBlink {
  0%, 100% { transform: translateY(0) scale(1); filter: drop-shadow(0 0 8px rgba(177,107,255,0.42)); }
  45% { transform: translateY(-1px) scale(1.06); filter: drop-shadow(0 0 16px rgba(177,107,255,0.72)); }
}
@keyframes dockMoreOrbit {
  0%, 100% { transform: rotate(0deg) scale(1); text-shadow: 0 0 0 rgba(255,193,77,0); }
  50% { transform: rotate(12deg) scale(1.08); text-shadow: 0 0 14px rgba(255,193,77,0.32); }
}
@keyframes dockPlusIdle {
  0%, 100% { transform: translateY(0) rotate(0deg) scale(1); filter: drop-shadow(0 0 0 rgba(255,255,255,0)); }
  50% { transform: translateY(0) rotate(7deg) scale(1.025); filter: drop-shadow(0 0 8px color-mix(in srgb, var(--dock-fx) 18%, white 6%)); }
}
@keyframes dockPlusActive {
  0%, 100% { transform: translateY(0) rotate(0deg) scale(1); filter: drop-shadow(0 0 8px color-mix(in srgb, var(--dock-fx) 18%, transparent)); }
  34% { transform: translateY(0) rotate(10deg) scale(1.05); filter: drop-shadow(0 0 14px color-mix(in srgb, var(--dock-fx) 32%, white 8%)); }
  66% { transform: translateY(0) rotate(-6deg) scale(1.08); filter: drop-shadow(0 0 18px color-mix(in srgb, var(--dock-fx) 36%, white 10%)); }
}
@keyframes dockPlusHalo {
  0%, 100% { transform: scale(0.84); opacity: 0.42; }
  50% { transform: scale(0.98); opacity: 0.58; }
}
/* Hue-rotate ranges trimmed: 360° (full rainbow) → ±60–90° (tonal sweep).
   The plus button now breathes within a refined neighbourhood of the
   current accent instead of cycling through every primary colour. */
@keyframes dockPlusChameleon {
  0%   { filter: hue-rotate(-30deg) saturate(1.02) brightness(0.99); }
  50%  { filter: hue-rotate(30deg)  saturate(1.04) brightness(1.01); }
  100% { filter: hue-rotate(-30deg) saturate(1.02) brightness(0.99); }
}
@keyframes dockPlusHue {
  0%   { filter: hue-rotate(-45deg) saturate(1.02); }
  50%  { filter: hue-rotate(45deg)  saturate(1.05); }
  100% { filter: hue-rotate(-45deg) saturate(1.02); }
}
@keyframes dockPlusHueFast {
  0%   { filter: hue-rotate(-60deg) saturate(1.04) brightness(1); }
  100% { filter: hue-rotate(60deg)  saturate(1.08) brightness(1.02); }
}
@keyframes dockPlusHaloTap {
  0% { transform: scale(0.84); opacity: 0.48; }
  45% { transform: scale(1.12); opacity: 0.66; }
  100% { transform: scale(0.98); opacity: 0.40; }
}
@keyframes dockPlusRingSpin {
  0% { transform: rotate(0deg) scale(1); opacity: 0.34; }
  100% { transform: rotate(360deg) scale(1); opacity: 0.46; }
}
@keyframes dockPlusRingTap {
  0% { transform: rotate(0deg) scale(1); opacity: 0.44; }
  50% { transform: rotate(180deg) scale(1.08); opacity: 0.68; }
  100% { transform: rotate(320deg) scale(1.02); opacity: 0.46; }
}
@keyframes dockPlusTapSpin {
  0% { transform: scale(1) rotate(0deg); filter: drop-shadow(0 0 0 rgba(255,255,255,0)); }
  42% { transform: scale(1.10) rotate(90deg); filter: drop-shadow(0 0 12px color-mix(in srgb, var(--dock-fx) 28%, white 10%)); }
  100% { transform: scale(1) rotate(180deg); filter: drop-shadow(0 0 6px color-mix(in srgb, var(--dock-fx) 16%, transparent)); }
}
@keyframes dockTapBurst {
  0% { transform: scale(1); }
  45% { transform: translateY(-3px) scale(1.18); }
  100% { transform: scale(1); }
}
@keyframes dockDocsTap {
  0% { transform: translateX(0) scale(1); }
  35% { transform: translateY(-2px) translateX(-1px) scale(1.13); }
  100% { transform: translateX(0) scale(1); }
}
@keyframes dockAgentTap {
  0% { transform: scale(1) rotate(0deg); }
  40% { transform: scale(1.14) rotate(6deg); }
  100% { transform: scale(1) rotate(0deg); }
}
@keyframes dockMoreTap {
  0% { transform: scale(1) rotate(0deg); }
  30% { transform: scale(1.12) rotate(14deg); }
  100% { transform: scale(1) rotate(0deg); }
}
@keyframes dockScanTap {
  0% { transform: scale(1) rotate(0deg); }
  36% { transform: scale(1.2) rotate(0deg); }
  100% { transform: scale(1) rotate(0deg); }
}

@media (prefers-reduced-motion: reduce) {
  .dock-btn,
  .dock-icon,
  .dock-label,
  .dock-btn::before,
  .dock-btn::after,
  .bottom-dock::before,
  .bottom-dock::after { transition-duration: 0.01ms !important; }
  .dock-btn.active .dock-icon,
  .dock-btn.dock-pressed .dock-icon,
  .dock-btn.dock-hit .dock-icon,
  .dock-center::before,
  .dock-center::after { animation: none !important; }
}

/* ---------- Clock Widget ---------- */
.clock-widget {
  padding: 1.5rem;
  margin-bottom: 1rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.clock-widget::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 140px; height: 140px;
  background: var(--accent-glow);
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
}
.clock-time {
  font-size: 3.2rem;
  font-weight: 800;
  letter-spacing: -2px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-bottom: 0.3rem;
}
.clock-date { font-size: 0.95rem; color: var(--text2); margin-bottom: 0.1rem; }
.clock-weekday { font-size: 0.8rem; color: var(--accent); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.clock-divider { height: 1px; background: var(--border); margin: 1rem 0; }
.calendar-mini { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-header-cell { font-size: 0.55rem; color: var(--text3); text-align: center; padding: 2px 0; font-weight: 600; text-transform: uppercase; }
.cal-day {
  font-size: 0.68rem;
  text-align: center;
  padding: 4px 2px;
  border-radius: 6px;
  color: var(--text2);
  line-height: 1;
}
.cal-day.today { background: var(--accent); color: white; font-weight: 700; }
.cal-day.other-month { color: var(--text3); }
.cal-day.has-deadline { position: relative; }
.cal-day.has-deadline::after { content:''; position:absolute; bottom:1px; left:50%; transform:translateX(-50%); width:3px; height:3px; background:var(--warning); border-radius:50%; }

/* ---------- PASS1: Dashboard Hero ---------- */
.dash-hero {
  text-align: center;
  padding: 1.2rem 1rem 1rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.dash-hero::before {
  content: '';
  position: absolute;
  top: -80px; left: 50%; transform: translateX(-50%);
  width: 300px; height: 200px;
  background: radial-gradient(circle, var(--accent-glow) 0%, rgba(59,130,246,0.06) 50%, transparent 70%);
  filter: blur(40px);
  pointer-events: none;
  opacity: 0.5;
}
@keyframes heroGlow {
  0% { opacity: 0.4; transform: translateX(-50%) scale(0.95); }
  100% { opacity: 0.8; transform: translateX(-50%) scale(1.05); }
}
.dash-hero-greeting {
  font-size: 0.76rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-weight: 700;
  margin-bottom: 0.5rem;
  position: relative;
}
.dash-hero-time {
  font-size: 3.2rem;
  font-weight: 900;
  letter-spacing: -3px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-bottom: 0.25rem;
  position: relative;
  background: linear-gradient(180deg, var(--text) 30%, var(--text2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.dash-hero-date {
  font-size: 0.82rem;
  color: var(--text2);
  font-weight: 500;
  position: relative;
  letter-spacing: 0.3px;
}

/* Storage Pill in Hero */
.dash-hero-storage-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.75rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  position: relative;
}
.dash-hero-storage-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 8px rgba(34,197,94,0.5);
  animation: storageDotPulse 3s ease-in-out infinite;
}
@keyframes storageDotPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 8px rgba(34,197,94,0.5); }
  50% { opacity: 0.6; box-shadow: 0 0 4px rgba(34,197,94,0.3); }
}
.dash-hero-storage-text {
  font-size: 0.68rem;
  color: var(--text3);
  font-weight: 600;
  letter-spacing: 0.3px;
}

/* ---------- PASS1: Dashboard Stats ---------- */
.dash-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.dash-stat-card {
  background: var(--card-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.75rem 0.4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: var(--card-shadow);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.dash-stat-card:active {
  border-color: var(--accent);
  box-shadow: 0 0 20px var(--accent-glow), var(--card-shadow);
}
.dash-stat-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.5;
}
.dash-stat-num {
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--accent);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.5px;
}
.dash-stat-label {
  font-size: 0.55rem;
  color: var(--text3);
  margin-top: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 700;
}
.dash-stat-storage { overflow: hidden; }
.dash-storage-micro-bar {
  margin-top: 0.35rem;
  height: 3px;
  background: var(--bg5);
  border-radius: 999px;
  overflow: hidden;
}
.dash-storage-micro-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--success));
  border-radius: inherit;
  transition: width 0.4s ease;
}

/* ---------- PASS1: Quick Actions ---------- */
.dash-storage-widget {
  padding: 0.9rem 1rem;
  margin-bottom: 1rem;
}
.dash-storage-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.6rem;
}
.dash-storage-title-row {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.dash-storage-icon { font-size: 1rem; }
.dash-storage-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.dash-storage-health {
  font-size: 0.62rem;
  font-weight: 700;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: rgba(34,197,94,0.12);
  color: var(--success);
}
.dash-storage-health.warn { background: rgba(245,158,11,0.12); color: var(--warning); }
.dash-storage-health.danger { background: rgba(239,68,68,0.12); color: var(--danger); }
.dash-storage-bar-wrap { margin-bottom: 0.45rem; }
.dash-storage-bar {
  height: 8px;
  background: var(--bg5);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.04);
}
.dash-storage-bar-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--success)));
  border-radius: inherit;
  transition: width 0.5s ease;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 30%, transparent);
}
.dash-storage-meta {
  display: flex;
  justify-content: space-between;
  font-size: 0.68rem;
  color: var(--text3);
  font-weight: 600;
}
.dash-storage-persist-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.6rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--border);
}
.dash-persist-warn {
  font-size: 0.68rem;
  color: var(--text2);
  font-weight: 600;
}
.dash-persist-btn {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  transition: all 0.2s ease;
}
.dash-persist-btn:active { background: var(--accent); color: white; }
.dash-actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.55rem;
  margin-bottom: 1.2rem;
}
.dash-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  padding: 0.9rem 0.4rem;
  background: var(--card-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
  box-shadow: var(--card-shadow);
  position: relative;
  overflow: hidden;
}
.dash-action-btn::before {
  content: '';
  position: absolute;
  top: -20px; left: 50%; transform: translateX(-50%);
  width: 60px; height: 60px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.dash-action-btn:active {
  transform: scale(0.95);
  border-color: var(--accent);
  box-shadow: 0 0 24px var(--accent-glow), var(--card-shadow);
}
.dash-action-btn:active::before {
  opacity: 0.7;
}
.dash-action-ico { font-size: 1.5rem; }
.dash-action-text {
  font-size: 0.64rem;
  color: var(--text2);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ---------- PASS1: Calendar Wrap ---------- */
.dash-calendar-wrap {
  padding: 1rem;
  margin-bottom: 1rem;
}

/* ---------- Cards ---------- */
.card-premium {
  background: var(--card-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  position: relative;
  box-shadow: var(--card-shadow);
}
.card-premium:hover { border-color: rgba(255,255,255,0.12); }

/* ---------- Stats Row (legacy compat) ---------- */
.stats-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.2rem; }
.stat-card {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 1rem 0.5rem;
  text-align: center;
}
.stat-num { font-size: 1.8rem; font-weight: 800; color: var(--accent); line-height: 1; }
.stat-label { font-size: 0.65rem; color: var(--text3); margin-top: 0.2rem; text-transform: uppercase; letter-spacing: 0.5px; }

/* ---------- Section Header ---------- */
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.6rem; }
.section-title { font-size: 0.76rem; font-weight: 800; color: var(--text2); text-transform: uppercase; letter-spacing: 1px; }
.link-btn { font-size: 0.76rem; color: var(--accent); font-weight: 700; letter-spacing: 0.2px; }
.link-btn:active { opacity: 0.7; }

/* Hard refresh button — prominent, clear, single-tap */
.hard-refresh-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  width: 100%;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(212,168,67,0.16), rgba(212,168,67,0.06));
  border: 1px solid rgba(212,168,67,0.32);
  border-radius: 14px;
  color: var(--accent);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.2px;
  text-align: left;
  cursor: pointer;
  transition: transform .15s ease, background .15s ease;
}
.hard-refresh-btn:active { transform: scale(0.97); background: linear-gradient(135deg, rgba(212,168,67,0.26), rgba(212,168,67,0.12)); }
.hard-refresh-btn .link-btn-sub {
  font-size: 0.74rem;
  font-weight: 500;
  color: var(--text2);
  letter-spacing: 0;
}
.hard-refresh-btn[disabled] { opacity: 0.6; cursor: wait; }
.hard-refresh-btn.spinning span:first-child::after {
  content: ' ⏳';
}

/* ---------- Deadlines ---------- */
.deadlines-list { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.2rem; }
.deadline-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.75rem 1rem;
}
.deadline-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--warning); flex-shrink: 0; }
.deadline-dot.overdue { background: var(--danger); }
.deadline-dot.ok { background: var(--success); }
.deadline-text { flex: 1; font-size: 0.85rem; }
.deadline-date { font-size: 0.72rem; color: var(--text3); }
.deadline-del { font-size: 0.85rem; opacity: 0.4; }
.deadline-del:active { opacity: 1; }

/* ---------- Recent Docs ---------- */
.recent-docs-list { display: flex; flex-direction: column; gap: 0.5rem; }

/* ---------- Search ---------- */
.search-bar-wrap { margin-bottom: 0.75rem; }
.search-input {
  width: 100%;
  background: rgba(15,16,20,0.8);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.7rem 1rem;
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 500;
  outline: none;
  transition: all 0.25s ease;
  box-shadow: var(--card-shadow);
}
.search-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft), var(--card-shadow); }
.search-input::placeholder { color: var(--text3); font-weight: 500; }

/* ---------- Filter Chips ---------- */
.filter-row { display: flex; gap: 0.5rem; overflow-x: auto; margin-bottom: 1rem; padding-bottom: 2px; }
.filter-row::-webkit-scrollbar { display: none; }
.filter-chip {
  flex-shrink: 0;
  padding: 0.38rem 0.9rem;
  border-radius: 20px;
  font-size: 0.74rem;
  font-weight: 700;
  background: rgba(15,16,20,0.7);
  border: 1px solid var(--glass-border);
  color: var(--text2);
  transition: all 0.2s ease;
  letter-spacing: 0.2px;
}
.filter-chip.active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }

/* ---------- Sort Select ---------- */
.sort-select {
  background: rgba(15,16,20,0.7);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xs);
  color: var(--text2);
  font-size: 0.74rem;
  font-weight: 600;
  padding: 0.35rem 0.65rem;
  outline: none;
}
.sort-select.full-width { width: 100%; padding: 0.65rem 1rem; font-size: 0.9rem; margin-bottom: 1rem; border-radius: var(--radius-sm); }

/* ---------- Folder Grid ---------- */
.folder-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; margin-bottom: 0.5rem; }
.folder-card {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 1rem;
  cursor: pointer;
  transition: var(--transition);
  position: relative;
}
.folder-card:active { transform: scale(0.97); border-color: var(--accent); }
.folder-card-icon { font-size: 1.8rem; margin-bottom: 0.4rem; }
.folder-card-name { font-size: 0.85rem; font-weight: 600; margin-bottom: 0.2rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.folder-card-count { font-size: 0.7rem; color: var(--text3); }
.folder-card-badge { position: absolute; top: 0.5rem; right: 0.5rem; background: var(--accent); color: white; font-size: 0.6rem; font-weight: 700; border-radius: 10px; padding: 1px 6px; }

/* ---------- Doc List ---------- */
.doc-list { display: flex; flex-direction: column; gap: 0.5rem; }
.doc-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.75rem;
  cursor: pointer;
  transition: var(--transition);
}
.doc-item:active { border-color: var(--accent); transform: scale(0.98); }
.doc-thumb {
  width: 44px;
  height: 52px;
  border-radius: 8px;
  background: var(--bg4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid var(--glass-border);
}
.doc-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: high-quality;
}
.doc-info { flex: 1; min-width: 0; }
.doc-title { font-size: 0.85rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 0.15rem; }
.doc-meta-row { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.doc-type-badge { font-size: 0.62rem; background: var(--bg5); border: 1px solid var(--glass-border); border-radius: 4px; padding: 1px 5px; color: var(--text3); }
.doc-institution { font-size: 0.68rem; color: var(--text2); }
.doc-date { font-size: 0.65rem; color: var(--text3); }
.confidence-badge {
  position: relative;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2px;
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
}
.confidence-badge:empty { display: none; }
.confidence-badge.high { background: rgba(34,197,94,0.2); color: #22C55E; }
.confidence-badge.medium { background: rgba(234,179,8,0.2); color: #EAB308; }
.confidence-badge.low { display: none; }
.doc-status { font-size: 0.65rem; }
.doc-status.pending { color: var(--warning); }
.doc-status.saved { color: var(--success); }

/* ---------- Folder Detail ---------- */
.folder-detail-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.back-btn { font-size: 0.9rem; color: var(--accent); font-weight: 600; white-space: nowrap; }
.folder-detail-title-wrap { flex: 1; display: flex; align-items: center; gap: 0.4rem; min-width: 0; }
.folder-detail-icon { font-size: 1.2rem; }
.folder-detail-name { font-size: 1rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.folder-detail-actions { display: flex; gap: 0.25rem; flex-shrink: 0; }

/* ---------- Scan Tab ---------- */
.scan-actions-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.25rem; }
.scan-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 1.1rem 0.5rem;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  color: var(--text2);
  font-weight: 600;
  transition: var(--transition);
}
.scan-action-btn:active { border-color: var(--accent); color: var(--accent); transform: scale(0.96); }
.scan-action-icon { font-size: 1.5rem; }

.intake-queue { display: flex; flex-direction: column; gap: 0.75rem; }
.queue-count { background: var(--accent); color: white; font-size: 0.65rem; font-weight: 700; border-radius: 10px; padding: 1px 7px; }

/* Intake Queue Item */
.intake-item {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: var(--transition);
}
.intake-item-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
}
.intake-thumb {
  width: 44px;
  height: 52px;
  border-radius: 8px;
  background: var(--bg4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid var(--glass-border);
}
.intake-thumb img { width: 100%; height: 100%; object-fit: cover; }
.intake-info { flex: 1; min-width: 0; }
.intake-filename { font-size: 0.78rem; color: var(--text2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 0.2rem; }
.intake-suggested-title { font-size: 0.88rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.intake-meta-chips { display: flex; gap: 0.35rem; flex-wrap: wrap; margin-top: 0.3rem; }
.intake-chip {
  font-size: 0.6rem;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 600;
}
.intake-chip.type { background: var(--accent-soft); color: var(--accent); }
.intake-chip.institution { background: rgba(168,85,247,0.12); color: #A855F7; }
.intake-chip.date { background: rgba(34,197,94,0.1); color: #22C55E; }
.intake-chip.folder { background: rgba(245,158,11,0.1); color: #F59E0B; }
.intake-chip.nofoldr { background: var(--bg5); color: var(--text3); }
.intake-chip.error { background: rgba(239,68,68,0.12); color: #FCA5A5; }
.intake-chip.wait { background: rgba(59,130,246,0.12); color: #93C5FD; }
.batch-summary {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.8rem;
  padding:.9rem 1rem;
  margin-bottom:.8rem;
  border-radius:18px;
  border:1px solid rgba(59,130,246,.22);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.batch-summary.has-failed { border-color: rgba(239,68,68,.28); }
.batch-summary-copy { display:flex; flex-direction:column; gap:.22rem; min-width:0; }
.batch-summary-copy strong { font-size:.95rem; color:var(--text); }
.batch-summary-copy small { color:var(--text2); line-height:1.35; }
.batch-summary-actions { display:flex; gap:.55rem; flex-wrap:wrap; justify-content:flex-end; }
.batch-mini-btn {
  border:1px solid rgba(255,255,255,.1);
  background:var(--bg4);
  color:var(--text);
  border-radius:12px;
  padding:.58rem .85rem;
  font-weight:800;
  font-size:.8rem;
}
.batch-mini-btn.primary { color:var(--accent); border-color: rgba(59,130,246,.35); }
.intake-item.is-error { border-color: rgba(239,68,68,.22); box-shadow: 0 0 0 1px rgba(239,68,68,.08) inset; }
.intake-item-actions {
  display: flex;
  border-top: 1px solid var(--border);
}
.intake-item-btn {
  flex: 1;
  padding: 0.6rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text2);
  border-right: 1px solid var(--border);
  transition: var(--transition);
}
.intake-item-btn:last-child { border-right: none; }
.intake-item-btn:active { background: var(--bg5); }
.intake-item-btn.primary { color: var(--accent); }
.intake-item-btn.danger { color: var(--danger); }

/* ---------- Intake Sheet ---------- */
.intake-preview-area {
  background: var(--bg4);
  border-radius: var(--radius-sm);
  min-height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  overflow: hidden;
  border: 1px solid var(--glass-border);
}
.intake-preview-area img { max-width: 100%; max-height: 200px; object-fit: contain; }
.intake-preview-area .pdf-preview-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 1.5rem;
  color: var(--text2);
}
.intake-preview-area .pdf-icon { font-size: 3rem; }
.intake-preview-area .pdf-name { font-size: 0.8rem; text-align: center; word-break: break-all; }
.intake-meta-form { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 1rem; }

/* ---------- Agent ---------- */
.agent-header-card { display: flex; align-items: center; gap: 1rem; padding: 1.25rem; margin-bottom: 1rem; }
.agent-avatar { font-size: 2.5rem; }
.agent-title { font-size: 1.1rem; font-weight: 700; }
.agent-sub { font-size: 0.78rem; color: var(--text2); }

.agent-doc-panel {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 1rem;
  margin-bottom: 1rem;
}
.agent-meta-row { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 0.5rem; }
.agent-meta-label { font-size: 0.7rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.4px; }
.agent-meta-val { font-size: 0.82rem; font-weight: 600; text-align: right; max-width: 60%; }
.agent-meta-divider { height: 1px; background: var(--border); margin: 0.5rem 0; }

.agent-actions-panel { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }
.agent-action-card {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.85rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: var(--transition);
  cursor: pointer;
}
.agent-action-card:active { border-color: var(--accent); transform: scale(0.98); }
.agent-action-icon { font-size: 1.2rem; }
.agent-action-text { flex: 1; }
.agent-action-title { font-size: 0.85rem; font-weight: 600; }
.agent-action-desc { font-size: 0.72rem; color: var(--text2); margin-top: 0.1rem; }

/* ---------- Preview Sheet ---------- */
.preview-area {
  min-height: 280px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%), var(--bg4);
  border-radius: 22px;
  display: flex;
  align-items: stretch;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 1rem;
  min-width: 0;
}
.preview-stage {
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 0.8rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.00) 100%);
}
.preview-stage-clean { gap: 0.9rem; padding: 0.9rem; }
.preview-stage-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.7rem;
  min-width: 0;
}
.preview-stage-top-compact {
  align-items: center;
  gap: 0.8rem;
}
.preview-stage-copy { min-width: 0; display: flex; flex-direction: column; gap: 0.2rem; }
.preview-stage-copy strong { font-size: 0.9rem; font-weight: 900; color: var(--text); }
.preview-stage-copy span { font-size: 0.7rem; color: var(--text3); line-height: 1.4; }
.preview-stage-chip {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0.5rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015));
  color: var(--text2);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 10px 18px rgba(0,0,0,0.2);
}
.preview-zoom-viewport {
  position: relative;
  width: 100%;
  min-width: 0;
  height: clamp(420px, 68svh, 780px);
  min-height: 420px;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(3,3,6,0.98);
  border: 1px solid var(--glass-border);
  touch-action: pan-y pinch-zoom;
  isolation: isolate;
}
.preview-zoom-viewport.is-portraitish {
  height: clamp(520px, 78svh, 880px);
  min-height: 520px;
}
.preview-zoom-backdrop {
  position: absolute;
  inset: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  filter: blur(40px) saturate(1.4) brightness(0.6);
  opacity: 0.5;
  transform: scale(1.2);
  pointer-events: none;
}
.preview-zoom-viewport-clean::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.1));
  pointer-events: none;
}
.preview-zoom-viewport.is-zoomed { touch-action: none; }
.preview-zoom-viewport.is-dragging { cursor: grabbing; }
.preview-zoom-surface {
  --preview-scale: 1;
  --preview-x: 0px;
  --preview-y: 0px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(calc(-50% + var(--preview-x)), calc(-50% + var(--preview-y)), 0) scale(var(--preview-scale));
  transform-origin: center center;
  will-change: transform;
}
.preview-zoom-image {
  display: block;
  width: auto;
  height: auto;
  max-width: none;
  max-height: none;
  border-radius: 12px;
  background: rgba(0,0,0,0.15);
  box-shadow: 0 16px 40px rgba(0,0,0,0.5);
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
}
/* ---------- Video Player ---------- */
.preview-video-viewport {
  position: relative;
  width: 100%;
  border-radius: 20px;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--glass-border);
  aspect-ratio: 16/9;
}
.preview-video-player {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  background: #000;
  border-radius: 20px;
}
.preview-video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  transition: opacity 0.2s ease;
}
.preview-video-play-btn {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 90%, white 12%) 0%, color-mix(in srgb, var(--accent) 80%, black 8%) 100%);
  border: 2px solid rgba(255,255,255,0.2);
  color: white;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 4px;
  box-shadow: 0 8px 30px color-mix(in srgb, var(--accent) 35%, transparent), 0 4px 12px rgba(0,0,0,0.3);
  transition: all 0.2s ease;
  cursor: pointer;
}
.preview-video-play-btn:active {
  transform: scale(0.92);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--accent) 25%, transparent);
}
.preview-video-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0;
}
.preview-video-badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0.22rem 0.6rem;
  border-radius: 999px;
  background: rgba(168,85,247,0.15);
  color: #C084FC;
  border: 1px solid rgba(168,85,247,0.25);
}
.preview-video-name {
  font-size: 0.72rem;
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.preview-area img { max-width: 100%; max-height: 100%; object-fit: contain; }
.meta-panel {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 22px;
  padding: 1rem;
  margin-bottom: 1rem;
  min-width: 0;
  overflow: hidden;
}
.meta-row {
  display: grid;
  grid-template-columns: minmax(90px, 0.6fr) minmax(0, 1fr);
  gap: 0.75rem;
  align-items: start;
  padding: 0.42rem 0;
  border-bottom: 1px solid var(--border);
  min-width: 0;
}
.meta-row:last-child { border-bottom: none; }
.meta-key { font-size: 0.72rem; color: var(--text3); min-width: 0; }
.meta-val { font-size: 0.78rem; font-weight: 600; text-align: right; min-width: 0; max-width: none; overflow-wrap: anywhere; word-break: break-word; }
.preview-sheet-actions { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.65rem; }
.preview-action-btn {
  min-width: 0;
  min-height: 74px;
  padding: 0.85rem 0.6rem;
  font-size: 0.82rem;
  font-weight: 800;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.015) 100%), var(--bg4);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--text2);
  transition: var(--transition);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 12px 22px rgba(0,0,0,0.18);
}
.preview-action-btn:active { background: var(--bg5); border-color: var(--accent); color: var(--accent); }
.preview-action-btn.download {
  color: color-mix(in srgb, var(--accent) 86%, white);
  border-color: color-mix(in srgb, var(--accent) 24%, rgba(255,255,255,0.08));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 14px 26px color-mix(in srgb, var(--accent) 12%, rgba(0,0,0,0.18));
}
.preview-action-btn.download:active { border-color: var(--accent); color: var(--accent); }
.preview-action-btn.danger:active { border-color: var(--danger); color: var(--danger); }

/* ---------- Move Sheet ---------- */
.move-folder-list { display: flex; flex-direction: column; gap: 0.5rem; max-height: 300px; overflow-y: auto; margin-bottom: 1rem; }
.move-folder-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition);
}
.move-folder-item:active { border-color: var(--accent); }
.move-folder-item-icon { font-size: 1.3rem; }
.move-folder-item-name { font-size: 0.9rem; font-weight: 600; }
.move-unassign {
  color: var(--text3);
  font-style: italic;
}

/* ---------- Settings ---------- */
.settings-group { margin-bottom: 1.5rem; scroll-margin-top: 0.75rem; }
#themeSection { padding-top: 0.15rem; }
.settings-group-title { font-size: 0.75rem; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 0.75rem; }
.settings-item { display: flex; justify-content: space-between; align-items: center; padding: 0.65rem 0; border-bottom: 1px solid var(--border); font-size: 0.88rem; }
.settings-item:last-child { border-bottom: none; }
.settings-value { color: var(--text2); font-size: 0.82rem; }
.danger-btn { width: 100%; padding: 0.8rem; background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3); border-radius: var(--radius-sm); color: var(--danger); font-weight: 600; font-size: 0.9rem; transition: var(--transition); }
.danger-btn:active { background: rgba(239,68,68,0.2); }

/* ---------- Theme Grid ---------- */
.theme-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.6rem; scroll-margin-top: 0.75rem; }
.theme-swatch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 0.75rem 0.5rem;
  background: var(--bg3);
  border: 2px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition);
}
.theme-swatch:active { transform: scale(0.95); }
.theme-swatch.active { border-color: var(--accent); }
.theme-dot { width: 28px; height: 28px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.15); }
.theme-swatch-label { font-size: 0.65rem; color: var(--text2); font-weight: 600; text-align: center; }

/* ---------- Storage Bar ---------- */
.storage-bar-wrap { display: flex; flex-direction: column; gap: 0.4rem; }
.storage-bar { height: 6px; background: var(--bg5); border-radius: 3px; overflow: hidden; }
.storage-bar-fill { height: 100%; background: var(--accent); border-radius: 3px; transition: width 0.5s ease; }
.storage-labels { display: flex; justify-content: space-between; font-size: 0.72rem; color: var(--text3); }

/* ---------- Quick Links Premium ---------- */
.quick-link-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.7rem 0.75rem;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
  margin-bottom: 0.45rem;
  transition: all 0.15s ease;
  text-decoration: none;
  color: inherit;
}
.quick-link-item:active { border-color: var(--accent); transform: scale(0.98); }
.quick-link-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--bg4);
  border: 1px solid rgba(255,255,255,0.06);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.quick-link-icon img { width: 26px; height: 26px; object-fit: contain; }
.quick-link-icon .ql-fallback { font-size: 1.1rem; }
.quick-link-body { flex: 1; min-width: 0; }
.quick-link-name { font-size: 0.85rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.quick-link-desc { font-size: 0.72rem; color: var(--text2); margin-top: 0.15rem; line-height: 1.35; }
.quick-link-note { font-size: 0.65rem; color: var(--accent); margin-top: 0.15rem; font-weight: 600; }
.quick-link-del { font-size: 0.8rem; color: var(--text3); padding: 0.3rem; flex-shrink: 0; }
.quick-link-del:active { color: var(--danger); }
.ql-cat-title {
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 0.6rem 0 0.3rem;
  margin-top: 0.3rem;
}
.ql-cat-title:first-child { margin-top: 0; }
/* Preview Card in Sheet */
.ql-preview-card {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.7rem 0.8rem;
  border: 1px solid color-mix(in srgb, var(--accent) 25%, rgba(255,255,255,0.06));
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(59,130,246,0.06), rgba(59,130,246,0.02));
  margin-bottom: 0.85rem;
}
.ql-preview-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--bg4);
  object-fit: contain;
  flex-shrink: 0;
}
.ql-preview-info { flex: 1; min-width: 0; }
.ql-preview-name { font-size: 0.85rem; font-weight: 700; color: var(--text); }
.ql-preview-desc { font-size: 0.72rem; color: var(--text2); margin-top: 0.15rem; line-height: 1.35; }

/* ---------- Sheets / Modals ---------- */
.sheet-backdrop {
  position: fixed;
  inset: 0;
  display: none;
  opacity: 0;
  background: rgba(0,0,0,0.6);
  z-index: 200;
  backdrop-filter: blur(16px) saturate(120%);
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  overscroll-behavior: contain;
  touch-action: none;
  transition: opacity 0.22s ease;
}
.sheet-backdrop.is-open { opacity: 1; }
.sheet {
  position: fixed;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: max(8px, env(safe-area-inset-bottom, 0px));
  transform: translateY(calc(100% + 18px));
  width: min(calc(100% - 12px), 430px);
  max-width: calc(100% - 12px);
  background:
    radial-gradient(circle at top center, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 30%),
    linear-gradient(180deg, rgba(15,16,20,0.97) 0%, rgba(8,8,12,0.98) 100%);
  backdrop-filter: blur(30px) saturate(1.2);
  -webkit-backdrop-filter: blur(30px) saturate(1.2);
  border-radius: 28px;
  border: 1px solid var(--glass-border);
  box-shadow: 0 24px 70px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.02) inset;
  z-index: 201;
  padding: 0 max(.95rem, env(safe-area-inset-right, 0px)) calc(1.15rem + env(safe-area-inset-bottom, 0px)) max(.95rem, env(safe-area-inset-left, 0px));
  max-height: calc(var(--docos-vvh, 100dvh) - max(10px, env(safe-area-inset-top, 0px)) - 10px);
  overflow-y: auto;
  overflow-x: clip;
  overscroll-behavior-y: contain;
  overscroll-behavior-x: none;
  touch-action: pan-y pinch-zoom;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  contain: layout paint style;
  opacity: 0;
  transition: transform 0.24s cubic-bezier(.22,1,.36,1), opacity 0.22s ease;
}
.sheet > * { max-width: 100%; }
.sheet.is-open {
  transform: translateY(0);
  opacity: 1;
}
.sheet-tall { max-height: calc(var(--docos-vvh, 100dvh) - max(8px, env(safe-area-inset-top, 0px)) - 8px); }
.sheet::-webkit-scrollbar { display: none; }
.sheet-handle {
  width: auto;
  height: auto;
  margin: 0 calc(-1 * max(1rem, env(safe-area-inset-left, 0px))) 14px calc(-1 * max(1rem, env(safe-area-inset-right, 0px)));
  padding: max(12px, env(safe-area-inset-top, 0px)) 0 10px;
  position: sticky;
  top: 0;
  z-index: 3;
  background: linear-gradient(180deg, rgba(10,10,10,0.98) 0%, rgba(10,10,10,0.9) 74%, rgba(10,10,10,0) 100%);
}
.sheet-handle::before {
  content: '';
  display: block;
  width: 42px;
  height: 5px;
  border-radius: 999px;
  margin: 0 auto;
  background: rgba(255,255,255,0.14);
}
.sheet-title {
  font-size: 1.05rem;
  font-weight: 800;
  margin-bottom: 1.1rem;
  text-align: center;
  letter-spacing: -0.01em;
}
.sheet-actions { display: flex; gap: 0.75rem; margin-top: 1rem; }

/* ---------- Form Elements ---------- */
.form-group { margin-bottom: 0.85rem; }
.form-label { font-size: 0.75rem; color: var(--text2); font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; display: block; margin-bottom: 0.35rem; }
.form-input {
  width: 100%;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.7rem 0.9rem;
  color: var(--text);
  font-size: 0.9rem;
  outline: none;
  transition: var(--transition);
}
.form-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.form-select {
  width: 100%;
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.7rem 0.9rem;
  color: var(--text);
  font-size: 0.9rem;
  outline: none;
}

/* ---------- Buttons ---------- */
.btn-primary {
  flex: 1;
  padding: 0.8rem;
  background: var(--accent);
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  text-align: center;
}
.btn-primary:active { opacity: 0.85; transform: scale(0.97); }
.btn-primary.danger { background: var(--danger); }
.btn-secondary {
  flex: 1;
  padding: 0.8rem;
  background: var(--bg4);
  border: 1px solid var(--glass-border);
  color: var(--text2);
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  text-align: center;
}
.btn-secondary:active { background: var(--bg5); }

/* ---------- Emoji Picker ---------- */
.emoji-picker { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.emoji-opt { font-size: 1.5rem; padding: 0.4rem; border-radius: 8px; border: 2px solid transparent; transition: var(--transition); cursor: pointer; }
.emoji-opt.selected { border-color: var(--accent); background: var(--accent-soft); }
.emoji-opt:active { transform: scale(0.9); }

/* ---------- Empty State ---------- */
.empty-state {
  text-align: center;
  padding: 3rem 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.empty-icon {
  font-size: 3.5rem;
  margin-bottom: 1rem;
  opacity: 0.7;
  filter: grayscale(0.3);
}
.empty-text { font-size: 1rem; font-weight: 800; color: var(--text); margin-bottom: 0.4rem; letter-spacing: -0.2px; }
.empty-sub { font-size: 0.8rem; color: var(--text3); line-height: 1.5; max-width: 260px; }
.empty-action {
  margin-top: 1.2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.65rem 1.4rem;
  background: var(--accent);
  color: white;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  border: none;
  box-shadow: 0 4px 16px var(--accent-glow);
  transition: all 0.2s ease;
}
.empty-action:active { transform: scale(0.96); opacity: 0.9; }
.empty-actions-row {
  display: flex;
  gap: 0.7rem;
  margin-top: 1.2rem;
  width: 100%;
  max-width: 320px;
  justify-content: center;
}
.empty-action-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 72px;
  padding: 0.9rem 0.6rem;
  border-radius: 14px;
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.2px;
  cursor: pointer;
  transition: all 0.18s ease;
}
.empty-action-btn:active { transform: scale(0.96); background: var(--accent); color: white; }
.empty-action-ico { font-size: 1.5rem; }

/* ---------- Badge ---------- */
.badge { display: inline-block; background: var(--accent); color: white; font-size: 0.65rem; font-weight: 700; border-radius: 10px; padding: 1px 7px; }

/* ---------- Toast ---------- */
.toast {
  position: fixed;
  bottom: calc(var(--dock-h) + 12px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--glass);
  backdrop-filter: blur(20px) saturate(1.3);
  -webkit-backdrop-filter: blur(20px) saturate(1.3);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  padding: 0.7rem 1.4rem;
  font-size: 0.82rem;
  font-weight: 700;
  z-index: 999;
  white-space: nowrap;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  color: var(--text);
}

/* ---------- Confirm ---------- */
.confirm-message { font-size: 0.9rem; color: var(--text2); text-align: center; margin-bottom: 0.5rem; line-height: 1.5; }

/* ---------- Chameleon Animation ---------- */
[data-theme="chameleon"] {
  /* Refined 3-tone professional palette: Indigo → Sky → Teal.
     Cool, tonal, slow loop — feels like iOS Control Center, not a toy. */
  animation: chameleon 18s ease-in-out infinite;
}
@keyframes chameleon {
  0%   { --accent: #6366F1; } /* Indigo  */
  33%  { --accent: #0EA5E9; } /* Sky     */
  66%  { --accent: #14B8A6; } /* Teal    */
  100% { --accent: #6366F1; }
}

/* ---------- Animations ---------- */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.screen.active .screen-scroll > * { animation: fadeIn 0.15s ease both; }
.screen.active .screen-scroll > *:nth-child(1) { animation-delay: 0s; }
.screen.active .screen-scroll > *:nth-child(2) { animation-delay: 0.04s; }
.screen.active .screen-scroll > *:nth-child(3) { animation-delay: 0.08s; }
.screen.active .screen-scroll > *:nth-child(4) { animation-delay: 0.12s; }
.screen.active .screen-scroll > *:nth-child(5) { animation-delay: 0.16s; }
.screen.active .screen-scroll > *:nth-child(6) { animation-delay: 0.2s; }
.screen.active .screen-scroll > *:nth-child(7) { animation-delay: 0.24s; }
.screen.active .screen-scroll > *:nth-child(8) { animation-delay: 0.28s; }
.screen.active .screen-scroll > *:nth-child(n+9) { animation-delay: 0.32s; }

/* ---------- Utilities ---------- */
.text-accent { color: var(--accent); }
.text-muted { color: var(--text2); }
.text-danger { color: var(--danger); }
.mt-sm { margin-top: 0.5rem; }
.hidden { display: none !important; }


/* ---------- External-Inspired Premium Storage Dashboard ---------- */
.section-hint { font-size: 0.7rem; color: var(--text3); font-weight: 600; letter-spacing: 0.3px; }
.storage-control-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 0.85rem; margin-bottom: 1rem; align-items: start; }
.storage-command-stack { display: flex; flex-direction: column; gap: 0.85rem; }
.storage-orb, .storage-plan { padding: 1rem; overflow: hidden; }
.storage-orb::after, .storage-plan::after {
  content: ''; position: absolute; inset: auto -30px -30px auto; width: 120px; height: 120px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 68%); pointer-events: none;
}
.storage-orb-top, .storage-plan-top { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.8rem; }
.storage-orb-eyebrow, .storage-plan-title { font-size: 0.72rem; color: var(--text2); text-transform: uppercase; letter-spacing: 0.6px; font-weight: 700; }
.storage-plan-note, .storage-health-pill { font-size: 0.62rem; padding: 3px 8px; border-radius: 999px; font-weight: 700; }
.storage-health-pill { background: rgba(34,197,94,0.12); color: var(--success); }
.storage-health-pill.warn { background: rgba(245,158,11,0.12); color: var(--warning); }
.storage-health-pill.danger { background: rgba(239,68,68,0.12); color: var(--danger); }
.storage-plan-note { background: var(--accent-soft); color: var(--accent); }
.storage-ring {
  --ring-pct: 0deg;
  --ring-rot: 0deg;
  width: 168px; height: 168px; margin: 0 auto 0.65rem; border-radius: 50%; position: relative;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0.06) 0 36%, transparent 37%),
    conic-gradient(from -90deg, rgba(255,255,255,0.10) 0deg, rgba(255,255,255,0.06) 360deg),
    conic-gradient(from -90deg, rgba(96,165,250,0.24) 0deg, rgba(96,165,250,0.12) var(--ring-pct), rgba(255,255,255,0.04) var(--ring-pct) 360deg);
  padding: 14px;
  box-shadow: inset 0 0 0 1px var(--border), 0 0 34px rgba(59,130,246,0.14), 0 20px 40px rgba(0,0,0,0.22);
}
.storage-ring::before {
  content: '';
  position: absolute; inset: 8px; border-radius: 50%;
  box-shadow: inset 0 0 0 10px rgba(255,255,255,0.045), inset 0 0 28px rgba(59,130,246,0.07);
  pointer-events: none;
}
.storage-ring-head {
  position: absolute; left: 50%; top: 50%; width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #ffffff 0 24%, #9cc6ff 25% 58%, #4f8cff 59% 100%);
  box-shadow: 0 0 0 4px rgba(96,165,250,0.18), 0 0 18px rgba(96,165,250,0.55), 0 0 30px rgba(96,165,250,0.28);
  transform: translate(-50%, -50%) rotate(var(--ring-rot)) translateY(-74px);
  transition: transform 0.35s ease;
  z-index: 2;
}
.storage-ring-inner {
  position: relative;
  width: 100%; height: 100%; border-radius: 50%;
  background: radial-gradient(circle at 50% 30%, rgba(21,24,33,0.98) 0, #0a0b10 75%);
  display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center;
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), inset 0 -20px 40px rgba(0,0,0,0.22);
  z-index: 1;
}
.storage-ring-value { font-size: 1.95rem; font-weight: 900; color: var(--text); line-height: 1; letter-spacing: -0.03em; }
.storage-ring-sub { font-size: 0.66rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.7px; margin-top: 0.28rem; }
.storage-ring-detail { margin-top: 0.52rem; padding: 0.38rem 0.62rem; border-radius: 999px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); display: flex; flex-direction: column; align-items: center; gap: 0.08rem; }
.storage-ring-detail strong { font-size: 0.82rem; font-weight: 800; color: var(--text); line-height: 1.05; }
.storage-ring-detail span { font-size: 0.58rem; color: var(--text3); letter-spacing: 0.35px; text-transform: uppercase; }
.storage-ring-legend { display: flex; justify-content: center; gap: 0.8rem; align-items: center; margin: -0.05rem auto 0.8rem; font-size: 0.6rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.55px; }
.storage-ring-legend span { display: inline-flex; align-items: center; gap: 0.32rem; }
.storage-ring-legend i { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.storage-ring-legend .is-used { background: var(--accent); box-shadow: 0 0 10px rgba(96,165,250,0.45); }
.storage-ring-legend .is-free { background: rgba(255,255,255,0.20); }
.storage-orb-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem; }
.storage-mini-card { background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); border-radius: 12px; padding: 0.7rem 0.75rem; }
.storage-mini-card strong { display: block; font-size: 0.98rem; font-weight: 700; color: var(--text); }
.storage-mini-k { display: block; font-size: 0.62rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.45px; margin-bottom: 0.2rem; }
.storage-plan-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; margin-bottom: 0.75rem; }
.storage-plan-num { font-size: 1.02rem; font-weight: 800; color: var(--text); }
.storage-plan-num.muted { color: var(--accent); }
.storage-plan-sub { font-size: 0.64rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 0.15rem; }
.storage-plan-bar { height: 10px; background: var(--bg5); border-radius: 999px; overflow: hidden; border: 1px solid var(--glass-border); }
.storage-plan-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent), rgba(255,255,255,0.85)); border-radius: inherit; transition: width 0.35s ease; }
.command-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.65rem; }
.command-card {
  min-height: 88px; background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.018));
  border: 1px solid var(--glass-border); border-radius: 16px; padding: 0.8rem 0.65rem; text-align: left;
  display: flex; flex-direction: column; justify-content: space-between; gap: 0.45rem; transition: var(--transition);
}
.command-card:active { transform: scale(0.97); border-color: var(--accent); box-shadow: 0 0 18px var(--accent-glow); }
.command-ico { font-size: 1.15rem; }
.command-copy { display: flex; flex-direction: column; gap: 0.1rem; }
.command-copy strong { font-size: 0.76rem; color: var(--text); }
.command-copy small { font-size: 0.62rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.45px; }
.memory-kpi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; margin-bottom: 1rem; }
.memory-kpi { padding: 0.9rem; }
.memory-kpi-label { display: block; font-size: 0.65rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 0.35rem; }
.memory-kpi strong { display: block; font-size: 1.25rem; font-weight: 800; color: var(--accent); line-height: 1.05; }
.memory-kpi small { display: block; margin-top: 0.2rem; font-size: 0.66rem; color: var(--text2); }
.storage-breakdown-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; margin-bottom: 1rem; }
.storage-break-card { padding: 0.85rem 0.9rem; }
.storage-break-card span { display: block; font-size: 0.68rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.45px; }
.storage-break-card strong { display: block; font-size: 1rem; font-weight: 800; color: var(--text); margin: 0.3rem 0 0.15rem; }
.storage-break-card small { color: var(--accent); font-size: 0.68rem; }
.dash-folder-rail { display: flex; gap: 0.7rem; overflow-x: auto; padding-bottom: 0.2rem; margin-bottom: 1rem; }
.dash-folder-rail::-webkit-scrollbar { display:none; }
.dash-folder-card {
  min-width: 132px; background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  border: 1px solid var(--glass-border); border-radius: 16px; padding: 0.85rem; text-align: left; transition: var(--transition);
}
.dash-folder-card:active { transform: scale(0.97); border-color: var(--accent); }
.dash-folder-card .dash-folder-icon { font-size: 1.5rem; margin-bottom: 0.45rem; display: block; }
.dash-folder-name { font-size: 0.8rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-folder-meta { font-size: 0.64rem; color: var(--text3); margin-top: 0.2rem; }
.queue-snapshot { display: flex; flex-direction: column; gap: 0.65rem; margin-bottom: 1rem; }
.queue-snapshot-card {
  display: grid; grid-template-columns: 52px 1fr auto; align-items: center; gap: 0.75rem; background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border); border-radius: 14px; padding: 0.7rem 0.75rem;
}
.queue-snapshot-thumb {
  width: 52px; height: 52px; border-radius: 12px; background: var(--bg4); border: 1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:center; overflow:hidden; font-size: 1.2rem;
}
.queue-snapshot-thumb img { width: 100%; height: 100%; object-fit: cover; }
.queue-snapshot-copy strong { display: block; font-size: 0.8rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.queue-snapshot-copy small { display: block; font-size: 0.66rem; color: var(--text3); margin-top: 0.18rem; }
.queue-snapshot-side { display:flex; flex-direction:column; gap:0.25rem; align-items:flex-end; }
.storage-safe-note { font-size: 0.68rem; color: var(--text3); margin-top: 0.5rem; line-height: 1.35; }
.storage-bar-wrap .storage-labels.compact { margin-top: 0.25rem; }
@media (max-width: 860px) {
  .storage-control-grid { grid-template-columns: 1fr; gap: 0.9rem; }
  .storage-orb, .storage-plan { padding: 0.92rem; }
  .storage-orb-top, .storage-plan-top { margin-bottom: 0.7rem; }
  .storage-ring { width: 176px; height: 176px; margin-bottom: 0.55rem; }
  .storage-ring-head { transform: translate(-50%, -50%) rotate(var(--ring-rot)) translateY(-78px); }
  .storage-ring-inner { padding-inline: 0.35rem; }
  .storage-orb-metrics { margin-top: 0.15rem; }
  .storage-mini-card { padding: 0.72rem 0.78rem; }
  .storage-plan-row { gap: 0.62rem; }
  .storage-truth-chart { min-height: 174px; }
  .storage-truth-chart canvas { height: 152px !important; }
}

@media (max-width: 520px) {
  .storage-control-grid { gap: 0.82rem; }
  .storage-orb, .storage-plan { padding: 0.88rem; }
  .storage-ring { width: 170px; height: 170px; }
  .storage-ring-head { transform: translate(-50%, -50%) rotate(var(--ring-rot)) translateY(-75px); }
  .storage-plan-num { font-size: 0.98rem; }
  .storage-truth-chart { padding: 0.62rem; min-height: 166px; }
  .storage-truth-chart canvas { height: 144px !important; }
  .storage-truth-foot { font-size: 0.78rem; }
}

@media (max-width: 390px) {
  .storage-control-grid { grid-template-columns: 1fr; }
  .command-grid { grid-template-columns: repeat(3, 1fr); }
}


/* ---------- External-source power layer ---------- */
.doc-thumb.is-preview,
.intake-thumb.is-preview,
.queue-snapshot-thumb.is-preview {
  padding: 0;
  font-size: 0;
}
.doc-thumb.is-preview img,
.intake-thumb.is-preview img,
.queue-snapshot-thumb.is-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.doc-thumb.is-preview,
.intake-thumb.is-preview,
.queue-snapshot-thumb.is-preview {
  position: relative;
}
.thumb-play-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: white;
  background: rgba(0,0,0,0.35);
  z-index: 1;
  pointer-events: none;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}
.pdf-canvas-wrap {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem;
}
.pdf-canvas-wrap canvas {
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
  background: #fff;
  box-shadow: 0 10px 25px rgba(0,0,0,0.22);
}
.pdf-preview-meta {
  width: 100%;
  text-align: center;
  font-size: 0.72rem;
  color: var(--text3);
  padding: 0.2rem 0 0.6rem;
}
.preview-area .preview-download-link,
.intake-preview-area .preview-download-link {
  font-size: 0.72rem;
  color: var(--accent);
  font-weight: 700;
  padding-bottom: 0.4rem;
}
.agent-result-panel {
  background: var(--card-bg); box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.9rem;
  margin-bottom: 1rem;
}
.agent-result-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.65rem;
}
.agent-result-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.agent-result-meta {
  font-size: 0.7rem;
  color: var(--text3);
}
.agent-result-body {
  font-size: 0.76rem;
  line-height: 1.45;
  color: var(--text);
  white-space: pre-wrap;
  max-height: 34vh;
  overflow: auto;
}
.agent-result-empty {
  font-size: 0.74rem;
  color: var(--text3);
}
.backup-action-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
  margin-bottom: 0.55rem;
}
.settings-note {
  font-size: 0.72rem;
  color: var(--text3);
  margin: 0 0 0.8rem;
}
.preview-action-btn[disabled],
.btn-secondary[disabled],
.btn-primary[disabled] {
  opacity: 0.55;
  pointer-events: none;
}

/* PASS 3 — Smart Parse UI */
.smart-summary-block {
  min-width: 0;
  overflow: hidden;
  margin-bottom: 0.85rem;
  padding: 0.9rem;
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(59,130,246,0.04));
}
.smart-summary-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  font-size: 0.76rem;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.smart-parse-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
  margin-bottom: 0.65rem;
}
.smart-parse-card {
  padding: 0.7rem 0.78rem;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 16px;
  background: rgba(255,255,255,0.025);
  min-width: 0;
}
.smart-parse-key {
  display: block;
  font-size: 0.65rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.22rem;
}
.smart-parse-val {
  display: block;
  font-size: 0.84rem;
  line-height: 1.28;
  color: var(--text);
  word-break: break-word;
}
.smart-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.smart-tag {
  padding: 0.34rem 0.56rem;
  border-radius: 999px;
  border: 1px solid rgba(59,130,246,0.22);
  background: rgba(59,130,246,0.08);
  color: var(--accent);
  font-size: 0.68rem;
  font-weight: 700;
}
.raw-text-details {
  margin-top: 0.75rem;
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  background: rgba(255,255,255,0.02);
  overflow: hidden;
}
.raw-text-details summary {
  list-style: none;
  cursor: pointer;
  padding: 0.78rem 0.9rem;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
}
.raw-text-details summary::-webkit-details-marker { display: none; }
.raw-text-body {
  padding: 0 0.9rem 0.95rem;
  font-size: 0.8rem;
  line-height: 1.46;
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-word;
}
.preview-area .pdf-canvas-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.35rem;
}
.preview-area .pdf-canvas-wrap canvas {
  width: 100%;
  height: auto;
  max-width: 420px;
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.28);
}
@media (max-width: 520px) {
  .smart-parse-grid {
    grid-template-columns: 1fr;
  }
}


/* PASS 4 — External structured editor */
.field-editor-docmeta {
  margin-bottom: 0.9rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(59,130,246,0.05));
}
.field-editor-docline {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}
.field-editor-docline strong {
  font-size: 0.94rem;
  color: var(--text);
}
.field-editor-docsub,
.field-editor-state {
  font-size: 0.72rem;
  color: var(--text3);
}
.field-editor-state { margin-top: 0.45rem; text-transform: uppercase; letter-spacing: 0.06em; }
.field-editor-mount {
  min-height: 320px;
  padding: 0.25rem 0 0.5rem;
}
.field-editor-mount .je-header,
.field-editor-mount h3,
.field-editor-mount h4 {
  color: var(--text);
}
.field-editor-mount .je-object__container,
.field-editor-mount fieldset {
  border: 1px solid var(--border) !important;
  border-radius: 18px;
  padding: 0.85rem 0.85rem 0.35rem !important;
  background: rgba(255,255,255,0.02);
  margin-bottom: 0.85rem;
}
.field-editor-mount legend,
.field-editor-mount .je-object__title {
  color: var(--text2) !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.5rem !important;
}
.field-editor-mount label {
  display: block;
  color: var(--text3) !important;
  font-size: 0.67rem !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.28rem !important;
}
.field-editor-mount input[type="text"],
.field-editor-mount input[type="email"],
.field-editor-mount input[type="number"],
.field-editor-mount select,
.field-editor-mount textarea {
  width: 100%;
  background: var(--bg3) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  color: var(--text) !important;
  padding: 0.76rem 0.86rem !important;
  font-size: 0.9rem !important;
  box-shadow: none !important;
  outline: none;
}
.field-editor-mount textarea { min-height: 92px; resize: vertical; }
.field-editor-mount input:focus,
.field-editor-mount select:focus,
.field-editor-mount textarea:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-soft) !important;
}
.field-editor-mount .help-block,
.field-editor-mount .errmsg {
  color: var(--text3) !important;
  font-size: 0.68rem !important;
  margin-top: 0.25rem !important;
}
.field-editor-mount .errmsg { color: #fda4af !important; }
.field-editor-mount .tabs,
.field-editor-mount .tab-holder {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.8rem;
}
.field-editor-mount .tabs a,
.field-editor-mount .tab-holder a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.56rem 0.8rem;
  border-radius: 999px;
  border: 1px solid var(--glass-border);
  background: var(--bg3);
  color: var(--text2) !important;
  font-size: 0.74rem;
  font-weight: 700;
  text-decoration: none !important;
}
.field-editor-mount .tabs .active a,
.field-editor-mount .tab-holder .active a,
.field-editor-mount .tabs a.active,
.field-editor-mount .tab-holder a.active {
  background: rgba(59,130,246,0.14);
  border-color: rgba(59,130,246,0.34);
  color: var(--accent) !important;
}
.smart-tag.is-confirmed {
  border-color: rgba(34,197,94,0.32);
  background: rgba(34,197,94,0.12);
  color: #86efac;
}

.form-hint {
  margin-top: 0.45rem;
  font-size: 0.72rem;
  color: var(--text3);
}


/* PASS 6 — Search / Filters / Tags / Duplicates */
.advanced-filter-card{padding:1rem;border:1px solid rgba(255,255,255,.08);border-radius:1rem;margin-bottom:1rem;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));}
.advanced-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;}
.advanced-filter-group--full{grid-column:1/-1;}
.advanced-filter-label{display:block;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.35rem;}
.pass6-select{width:100%;min-height:44px;background:#0d0f14;color:var(--text);border:1px solid rgba(255,255,255,.12);border-radius:.9rem;padding:.85rem 1rem;}
.advanced-filter-actions{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.75rem;flex-wrap:wrap;}
.advanced-filter-summary{font-size:.85rem;color:var(--text-dim);}
.duplicate-panel{display:grid;grid-template-columns:1fr;gap:.55rem;margin-bottom:1rem;}
.duplicate-card{border:1px solid rgba(239,68,68,.25);background:rgba(127,29,29,.16);border-radius:1rem;padding:.85rem 1rem;color:var(--text);display:flex;flex-direction:column;gap:.2rem;text-align:left;}
.duplicate-card strong{font-size:.95rem;}
.duplicate-card small{color:#fca5a5;}
.duplicate-card span{color:var(--text-dim);font-size:.82rem;}
.duplicate-badge{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.1rem .45rem;border-radius:999px;background:rgba(239,68,68,.18);color:#fca5a5;font-size:.72rem;margin-left:.35rem;vertical-align:middle;}
.doc-item.is-duplicate{border-color:rgba(239,68,68,.28);box-shadow:0 0 0 1px rgba(239,68,68,.12) inset;}
.duplicate-inline{margin-top:.35rem;color:#fca5a5;font-size:.78rem;}
.folder-card-ghost{opacity:.45;transform:scale(.98);}
.docos-choices .choices__inner,.docos-choices .choices__list--single,.docos-choices .choices__input{background:#0d0f14 !important;color:var(--text) !important;border:none !important;box-shadow:none !important;}
.docos-choices.choices{margin-bottom:0;}
.docos-choices .choices__inner{min-height:46px;border-radius:.9rem;border:1px solid rgba(255,255,255,.12) !important;padding:.55rem .8rem !important;}
.docos-choices .choices__list--dropdown,.docos-choices .choices__list[aria-expanded]{background:#0d0f14;border:1px solid rgba(255,255,255,.12);color:var(--text);}
.docos-choices .choices__item{color:var(--text);}
.docos-choices .choices__item--selectable.is-highlighted{background:rgba(59,130,246,.18);}
.docos-choices-multi .choices__list--multiple .choices__item{background:rgba(59,130,246,.18);border:1px solid rgba(59,130,246,.3);}
@media (max-width: 640px){.advanced-filter-grid{grid-template-columns:1fr;}}


/* PASS 6.1 — Truth Dashboard */
.storage-truth-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.6rem;
  margin-top:.9rem;
}
.storage-truth-item{
  padding:.75rem .85rem;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  gap:.2rem;
}
.storage-truth-item span{
  font-size:.72rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  opacity:.72;
}
.storage-truth-item strong{
  font-size:.95rem;
  font-weight:800;
  line-height:1.15;
}
.storage-truth-chart{
  margin-top:.8rem;
  padding:.7rem;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));
  min-height:190px;
}
.storage-truth-chart canvas{
  width:100% !important;
  height:170px !important;
  display:block;
}
.storage-truth-foot{
  margin-top:.7rem;
  font-size:.82rem;
  line-height:1.35;
  color:rgba(255,255,255,.7);
}
@media (max-width: 430px){
  .storage-truth-grid{
    grid-template-columns:1fr 1fr;
    gap:.55rem;
  }
  .storage-truth-item{
    padding:.68rem .75rem;
  }
  .storage-truth-item strong{
    font-size:.88rem;
  }
  .storage-truth-chart{
    min-height:176px;
  }
  .storage-truth-chart canvas{
    height:156px !important;
  }
}

@media (max-width: 640px) {
  .storage-ring { width: 162px; height: 162px; }
  .storage-ring-head { transform: translate(-50%, -50%) rotate(var(--ring-rot)) translateY(-71px); }
  .storage-ring-value { font-size: 1.82rem; }
}

.storage-control-grid > .storage-orb,
.storage-control-grid > .storage-command-stack { align-self: start; }
.storage-orb { min-height: auto; }
.storage-truth-grid-compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.storage-truth-grid-compact .storage-truth-item { min-height: 0; }
.storage-truth-chart { margin-top: 0.7rem; }
.storage-truth-foot { margin-top: 0.7rem; }
@media (max-width: 640px) {
  .storage-truth-grid-compact { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .batch-summary { flex-direction:column; align-items:stretch; }
  .batch-summary-actions { justify-content:stretch; }
  .batch-mini-btn { width:100%; }
}



.folder-local-summary {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  padding:.9rem 1rem;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(17,17,17,.96), rgba(10,10,10,.96));
  border-radius:1rem;
  margin-bottom:.75rem;
}
.folder-local-summary-copy { display:flex; flex-direction:column; gap:.18rem; min-width:0; }
.folder-local-summary-copy strong { font-size:.95rem; color:var(--text); }
.folder-local-summary-copy small { color:var(--text2); line-height:1.35; }
.folder-local-action {
  flex-shrink:0;
  padding:.62rem .9rem;
  border-radius:.85rem;
  border:1px solid rgba(59,130,246,.35);
  background:rgba(59,130,246,.12);
  color:var(--accent);
  font-weight:700;
}
.folder-local-queue { display:grid; grid-template-columns:1fr; gap:.65rem; margin-bottom:.85rem; }
.folder-local-item {
  display:flex;
  align-items:center;
  gap:.75rem;
  padding:.8rem .9rem;
  border-radius:1rem;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
.folder-local-item.has-error { border-color:rgba(239,68,68,.25); background:rgba(127,29,29,.12); }
.folder-local-thumb {
  width:52px;
  height:52px;
  border-radius:.85rem;
  overflow:hidden;
  background:var(--bg4);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--text2);
}
.folder-local-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.folder-local-copy { min-width:0; flex:1; display:flex; flex-direction:column; gap:.2rem; }
.folder-local-copy strong { font-size:.86rem; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.folder-local-copy small { font-size:.72rem; color:var(--text2); line-height:1.3; }
.folder-local-actions { display:flex; gap:.45rem; flex-wrap:wrap; justify-content:flex-end; }

html, body, #app, #mainContent, .screen { overscroll-behavior-x:none; }
body { overflow-x:clip; }
#app { overflow-x:clip; }
#mainContent, .screen, .sheet-backdrop, .sheet { overflow-x: clip; }
.screen-scroll {
  overflow-x:clip;
  overscroll-behavior-x:none;
  touch-action: pan-y;
}
.screen-scroll > * { max-width:100%; }
.dashboard-grid, .quick-actions-grid, .stats-grid { min-width:0; }
.card, .dashboard-grid > *, .quick-actions-grid > *, .stats-grid > * { max-width:100%; }

@media (max-width: 430px) {
  .folder-local-summary { flex-direction:column; align-items:stretch; }
  .folder-local-action { width:100%; }
  .folder-local-item { align-items:flex-start; }
  .folder-local-actions { width:100%; justify-content:stretch; }
  .folder-local-actions .batch-mini-btn { flex:1; }
}


/* PASS 73 — iPhone viewport lock + premium sheet stability */
:root {
  --docos-vvh: 100dvh;
  --docos-vw: 100vw;
}
html, body, #app, #mainContent, .screen { overscroll-behavior-x: none; }
body.docos-sheet-open {
  overflow: hidden;
  overflow: clip;
}
#app.docos-sheet-open #mainContent {
  pointer-events: none;
}
#app.docos-sheet-open .sheet,
#app.docos-sheet-open .sheet-backdrop {
  pointer-events: auto;
}
.screen-scroll > * { max-width: 100%; }
.dashboard-grid, .quick-actions-grid, .stats-grid { min-width: 0; }
.card, .dashboard-grid > *, .quick-actions-grid > *, .stats-grid > * { max-width: 100%; }
@media (max-width: 520px) {
  #app {
    position: fixed;
    inset: 0;
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  .storage-control-grid {
    grid-template-columns: 1fr;
    gap: 0.85rem;
  }
  .storage-command-stack {
    gap: 0.75rem;
  }
  .storage-orb,
  .storage-plan {
    width: 100%;
  }
  .storage-orb { min-height: 0; }
  .storage-plan-row,
  .storage-orb-metrics,
  .storage-truth-grid-compact,
  .storage-truth-grid {
    grid-template-columns: 1fr 1fr;
  }
  .sheet {
    width: calc(100% - 8px);
    max-width: calc(100% - 8px);
    bottom: max(4px, env(safe-area-inset-bottom, 0px));
    border-radius: 26px;
  }
}


/* PASS 77 — Sheet anti-drift + premium modal polish */
.form-row-2 > *,
.deadline-reminder-grid > *,
.sheet-actions > *,
.deadline-reminder-box > *,
.deadline-day-block > * {
  min-width: 0;
}

#deadlineSheet {
  background:
    radial-gradient(circle at top center, color-mix(in srgb, var(--accent) 18%, transparent) 0%, transparent 34%),
    linear-gradient(180deg, rgba(17,17,17,0.99) 0%, rgba(8,8,8,0.99) 100%);
}
#deadlineSheet .sheet-title {
  font-size: 1.08rem;
  letter-spacing: -0.015em;
}
#deadlineSheet .form-group,
#deadlineSheet .deadline-reminder-box,
#deadlineSheet .deadline-day-block {
  overflow-x: clip;
}
#deadlineSheet .form-row-2 {
  gap: .65rem;
}
#deadlineSheet .deadline-color-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  justify-items: center;
  gap: .6rem;
}
#deadlineSheet .deadline-color-swatch {
  width: 38px;
  height: 38px;
}
#deadlineSheet .deadline-reminder-box {
  padding: .92rem;
  border-radius: 20px;
  border-color: rgba(255,255,255,.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015)),
    rgba(14,14,16,.96);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
#deadlineSheet .sheet-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  backdrop-filter: blur(10px) saturate(110%);
  -webkit-backdrop-filter: blur(10px) saturate(110%);
}
#deadlineDeleteBtn { grid-column: 1 / -1; }
#deadlineSheet .sheet-actions .btn-primary,
#deadlineSheet .sheet-actions .btn-secondary {
  min-width: 0;
  min-height: 58px;
  border-radius: 20px;
  font-size: 1rem;
}
@media (max-width: 390px) {
  #deadlineSheet .form-row-2,
  #deadlineSheet .deadline-reminder-grid,
  #deadlineSheet .sheet-actions {
    grid-template-columns: 1fr;
  }
  #deadlineDeleteBtn { grid-column: auto; }
}

/* ---------- Календар и термини ---------- */
.notif-icon-btn { position: relative; }
.notif-dot {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 0 2px rgba(0,0,0,.55);
}
.calendar-mini { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.cal-day {
  position: relative;
  min-height: 34px;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
}
.cal-day.selected { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
.cal-day-num { display:block; font-size: .68rem; }
.cal-day-bell { position:absolute; top:2px; right:3px; font-size:.5rem; opacity:.82; }
.cal-day-dots { display:flex; gap:2px; justify-content:center; align-items:center; margin-top:3px; min-height:8px; }
.cal-day-dots i { width:5px; height:5px; border-radius:50%; display:inline-block; }
.cal-day-dots b { font-size:.48rem; color:var(--text3); font-weight:700; }
.calendar-date-pill {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:34px; padding:0 12px; border-radius:999px;
  background:var(--bg3); border:1px solid var(--border);
  color:var(--accent); font-weight:700; margin:0 auto 1rem; width:max-content;
}
.form-row-2 { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:.75rem; }
.form-textarea { min-height:92px; resize:vertical; }
.deadline-color-row { display:flex; gap:.55rem; flex-wrap:wrap; }
.deadline-color-swatch {
  width:34px; height:34px; border-radius:50%; border:2px solid transparent;
  background:var(--sw); box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.deadline-color-swatch.active { border-color:#fff; box-shadow:0 0 0 3px color-mix(in srgb, var(--sw) 25%, transparent); }
.deadline-reminder-box {
  background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:.8rem .9rem; margin-bottom:.9rem;
}
.deadline-check-row { display:flex; align-items:center; gap:.6rem; font-weight:700; color:var(--text); margin-bottom:.65rem; }
.deadline-check-row input { accent-color: var(--accent); }
.btn-inline { width:100%; flex:none; }
.deadline-help { font-size:.72rem; color:var(--text3); line-height:1.4; }
.deadline-reminder-box .form-select,
.deadline-reminder-box .btn-inline,
#deadlineSheet .form-input {
  min-height: 54px;
  border-radius: 18px;
}
#deadlineSheet .form-textarea { min-height: 126px; }
#deadlineSheet .sheet-actions {
  position: sticky;
  bottom: calc(-1.15rem - env(safe-area-inset-bottom, 0px));
  padding-top: .9rem;
  padding-bottom: calc(.25rem + env(safe-area-inset-bottom, 0px));
  background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,0.96) 22%, rgba(10,10,10,0.99) 100%);
  z-index: 3;
}


/* PASS 78 — premium sheet button system */
.sheet .btn-primary,
.sheet .btn-secondary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  min-height: 58px;
  border-radius: 22px;
  padding: .95rem 1rem;
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: -0.015em;
  line-height: 1.05;
  box-shadow: 0 12px 28px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04);
}
.sheet .btn-primary::before,
.sheet .btn-secondary::before {
  content: '';
  position: absolute;
  inset: 1px 1px auto 1px;
  height: 48%;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 100%);
  opacity: .75;
  pointer-events: none;
}
.sheet .btn-primary {
  border: 1px solid color-mix(in srgb, var(--accent) 55%, rgba(255,255,255,.28));
  color: #fff;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, white 10%) 0%, color-mix(in srgb, var(--accent) 82%, black 10%) 100%),
    linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 100%);
  box-shadow:
    0 18px 34px color-mix(in srgb, var(--accent) 26%, transparent),
    0 12px 30px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.14),
    inset 0 -1px 0 rgba(0,0,0,.18);
}
.sheet .btn-primary::after {
  content: '';
  position: absolute;
  inset: auto 14% -22% 14%;
  height: 48%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 46%, transparent);
  filter: blur(16px);
  opacity: .45;
  pointer-events: none;
}
.sheet .btn-primary:active {
  transform: translateY(1px) scale(.985);
  opacity: 1;
  box-shadow:
    0 10px 22px color-mix(in srgb, var(--accent) 18%, transparent),
    0 8px 16px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 -1px 0 rgba(0,0,0,.16);
}
.sheet .btn-secondary {
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%),
    rgba(18,18,20,.92);
  backdrop-filter: blur(14px) saturate(130%);
  -webkit-backdrop-filter: blur(14px) saturate(130%);
  box-shadow:
    0 14px 30px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.05),
    inset 0 -1px 0 rgba(255,255,255,.02);
}
.sheet .btn-secondary:active {
  transform: translateY(1px) scale(.985);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.025) 100%),
    rgba(22,22,24,.95);
}
#deadlineDeleteBtn {
  border-color: color-mix(in srgb, var(--danger) 50%, rgba(255,255,255,.16));
  color: #fff;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--danger) 72%, white 6%) 0%, color-mix(in srgb, var(--danger) 56%, black 6%) 100%),
    rgba(44,14,14,.96);
  box-shadow:
    0 18px 34px rgba(239,68,68,.18),
    0 12px 30px rgba(0,0,0,.32),
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 -1px 0 rgba(0,0,0,.18);
}
#deadlineDeleteBtn::after {
  content: '';
  position: absolute;
  inset: auto 18% -24% 18%;
  height: 46%;
  border-radius: 999px;
  background: rgba(239,68,68,.34);
  filter: blur(16px);
  opacity: .42;
  pointer-events: none;
}
#deadlineSheet .sheet-actions {
  gap: .85rem;
  margin-top: 1.15rem;
  padding: .95rem;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%),
    linear-gradient(180deg, rgba(10,10,10,.86) 0%, rgba(10,10,10,.98) 100%);
  box-shadow: 0 -12px 30px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.03);
}
#deadlineSheet .sheet-actions::before {
  content: '';
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
}
#deadlineNotifPermissionBtn,
#deadlineSheet .btn-inline {
  min-height: 54px;
  border-radius: 18px;
}
#deadlineSheet .calendar-date-pill {
  border-radius: 999px;
  padding: 0 16px;
  min-height: 38px;
  border-color: color-mix(in srgb, var(--accent) 34%, rgba(255,255,255,.1));
  background:
    linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.015) 100%),
    rgba(14,14,18,.92);
  box-shadow:
    0 12px 28px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.05),
    0 0 0 1px color-mix(in srgb, var(--accent) 16%, transparent);
}
#deadlineSheet .calendar-date-pill {
  box-shadow: 0 8px 24px rgba(0,0,0,0.24);
}
.deadline-day-block { margin-top:.9rem; }
.deadline-day-head { font-size:.8rem; color:var(--text2); font-weight:700; margin-bottom:.5rem; }
.deadline-day-list { display:flex; flex-direction:column; gap:.45rem; }
.deadline-mini-card {
  display:flex; align-items:center; gap:.65rem; width:100%; text-align:left;
  background:var(--bg3); border:1px solid var(--border); border-radius:14px; padding:.75rem .85rem;
}
.deadline-mini-card.active { border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-soft); }
.deadline-mini-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.deadline-mini-copy strong { display:block; font-size:.88rem; }
.deadline-mini-copy small { display:block; color:var(--text3); margin-top:.12rem; }
.deadline-item { text-align:left; width:100%; }
.deadline-main { flex:1; min-width:0; }
.deadline-text-row { display:flex; gap:.45rem; align-items:center; }
.deadline-note { color:var(--text3); font-size:.73rem; margin-top:.15rem; line-height:1.35; }
.deadline-side { text-align:right; flex-shrink:0; }
.deadline-label { color:var(--accent); font-size:.68rem; margin-top:.1rem; }
.deadline-bell { font-size:.75rem; }
.alerts-headline { font-size:.9rem; color:var(--text2); font-weight:700; text-align:center; margin-bottom:.9rem; }
.alerts-list { display:flex; flex-direction:column; gap:.55rem; }
.alerts-group-title { font-size:.74rem; color:var(--text3); text-transform:uppercase; letter-spacing:.4px; margin:.4rem 0 .1rem; }
.alert-card {
  width:100%; text-align:left; display:flex; gap:.7rem; align-items:flex-start;
  background:var(--bg3); border:1px solid var(--border); border-radius:16px; padding:.8rem .9rem;
}
.alert-card.is-unseen { border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-soft); }
.alert-card.is-upcoming { border-style:dashed; }
.alert-color { width:10px; height:10px; border-radius:50%; flex-shrink:0; margin-top:.25rem; }
.alert-copy strong { display:block; }
.alert-copy small { display:block; color:var(--text3); line-height:1.35; margin-top:.15rem; }

@media (max-width: 520px) {
  .form-row-2 { grid-template-columns: 1fr; gap:0; }
}


/* ---------- PWA / Home Screen ---------- */
.pwa-help-copy { display:flex; flex-direction:column; gap:.7rem; margin-bottom:.9rem; }
.pwa-help-step { display:flex; gap:.75rem; align-items:flex-start; background:var(--bg3); border:1px solid var(--border); border-radius:14px; padding:.8rem .9rem; }
.pwa-help-step strong { color:var(--accent); min-width:1.25rem; font-size:1rem; }
.pwa-help-step span { color:var(--text2); line-height:1.45; font-size:.92rem; }
.settings-item .settings-value.is-good { color: var(--success); }
.settings-item .settings-value.is-warn { color: var(--warning); }
.settings-item .settings-value.is-info { color: var(--accent); }

.icon-btn, .dock-btn, .btn-primary, .btn-secondary, .command-card, .deadline-color-swatch { touch-action: manipulation; }

/* PASS 76 — iPhone shell/scroll stability */
.move-folder-list, .agent-result-body, .raw-text-body {
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
}
@supports (height: 100svh) {
  #app {
    height: var(--docos-shell-h, 100svh);
    min-height: var(--docos-shell-h, 100svh);
  }
}


/* PASS 85 — preview pro + global anti-drift */
.screen-scroll,
.meta-panel,
.smart-summary-block,
.raw-text-details,
.raw-text-body,
.smart-parse-grid,
.smart-parse-card,
.preview-area,
.preview-stage,
.preview-zoom-viewport,
.preview-sheet-actions {
  min-width: 0;
  max-width: 100%;
}
.preview-zoom-viewport,
.preview-stage,
.meta-panel,
.smart-summary-block,
.raw-text-details {
  overflow-x: clip;
}
@media (max-width: 520px) {
  .preview-stage-top { flex-direction: column; align-items: stretch; }
  .preview-stage-top-compact { align-items: stretch; }
  .preview-stage-chip { align-self: flex-start; white-space: normal; }
  .preview-sheet-actions { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}


/* PASS 86 — standalone full-width hard lock */
@media (max-width: 520px) {
  html, body {
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
  }
  body {
    position: fixed;
    inset: 0;
  }
  #mainContent,
  .screen,
  .screen-scroll,
  .preview-area,
  .preview-stage,
  .preview-zoom-viewport,
  .meta-panel,
  .sheet,
  .sheet-backdrop {
    width: 100%;
    max-width: 100%;
  }
}

/* ============================================================
   PASS 3 MEGA — Gallery View + Enhanced Folders + Onboarding
   ============================================================ */

/* ============================================================
   CINEMA PLAYER
   ============================================================ */
.cinema-player-wrap {
  overflow: hidden;
  margin-bottom: 1rem;
  padding: 0;
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.cinema-viewport {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  overflow: hidden;
  touch-action: none;
  /* layout + paint + style containment fully isolates the iframe's
     repaints + compositing from the rest of the page (we skip "size"
     because aspect-ratio: 16/9 needs the parent's height to flow).
     This is the rule that stops the page from "shaking" when the embed
     loads, changes resolution, or repaints internally. */
  contain: layout paint style;
  isolation: isolate;
  transform: translateZ(0);
  will-change: transform;
}

/* Cinema isolation note:
   The old "kill every animation while playing" hack lived here. It caused
   visible flicker each time the flag flipped on/off (animations start →
   stop → start). With the cinema-viewport now under contain:layout-paint-style
   AND iframe playback events being the only thing that toggles the flag,
   the global killer is no longer needed. The viewport fully isolates GPU
   thrashing on its own. Keep this section intentionally empty. */

/* Honor reduced-motion preference systemwide. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

/* Iframe top bar: always-visible fallback controls */
.cinema-bar {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: linear-gradient(180deg, rgba(0,0,0,0.85), rgba(0,0,0,0.6));
  border-bottom: 1px solid rgba(212,168,67,0.18);
}
.cinema-bar.show { display: flex; }
.cinema-bar-host {
  flex: 1; min-width: 0;
  font-size: 12px; opacity: 0.85;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cinema-bar-btn {
  background: rgba(212,168,67,0.18);
  border: 1px solid rgba(212,168,67,0.35);
  color: #fff;
  padding: 6px 10px; border-radius: 8px;
  font-size: 12px; cursor: pointer;
  text-decoration: none;
}
.cinema-bar-btn.danger { background: rgba(239,68,68,0.18); border-color: rgba(239,68,68,0.35); }
.cinema-bar-btn:active { transform: scale(0.95); }

/* Loading spinner over iframe */
.cinema-iframe-loader {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; pointer-events: none; z-index: 5;
  background: rgba(0,0,0,0.55);
}
.cinema-iframe-loader.hide { display: none; }
.cinema-iframe-loader .spin {
  width: 36px; height: 36px;
  border: 3px solid rgba(212,168,67,0.25);
  border-top-color: #d4a843;
  border-radius: 50%;
  animation: cinemaSpin 0.9s linear infinite;
}
.cinema-iframe-loader .lbl { font-size: 13px; opacity: 0.85; }
@keyframes cinemaSpin { to { transform: rotate(360deg); } }
.cinema-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  background: #000;
}
.cinema-iframe {
  width: 100%;
  height: 100%;
  border: 0;
  background: #000;
}

/* URL paste modal */
.cinema-url-modal {
  position: fixed; inset: 0; z-index: 9990;
  background: rgba(0, 0, 0, 0.78);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  animation: cinemaUrlFade .25s ease;
}
@keyframes cinemaUrlFade { from { opacity: 0; } to { opacity: 1; } }
.cinema-url-card {
  width: 100%; max-width: 480px;
  background: linear-gradient(160deg, rgba(212, 168, 67, 0.1), rgba(255, 255, 255, 0.04));
  border: 1px solid rgba(212, 168, 67, 0.28);
  border-radius: 22px;
  padding: 22px 20px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6);
}
.cinema-url-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.cinema-url-title { font-size: 17px; font-weight: 700; }
.cinema-url-close {
  background: rgba(255,255,255,0.08); border: 0; color: #fff;
  width: 32px; height: 32px; border-radius: 50%;
  font-size: 16px; cursor: pointer;
}
.cinema-url-blurb { font-size: 13px; opacity: 0.7; margin-bottom: 14px; line-height: 1.45; }
.cinema-url-input {
  width: 100%; padding: 14px 16px;
  background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px; color: #fff; font-size: 14px;
  font-family: inherit; outline: none;
  transition: border-color .2s;
}
.cinema-url-input:focus { border-color: rgba(212, 168, 67, 0.6); }
.cinema-url-go {
  width: 100%; margin-top: 12px; padding: 14px;
  background: linear-gradient(135deg, #d4a843, #c8941e);
  color: #0a0e27; font-weight: 700; font-size: 15px;
  border: 0; border-radius: 12px; cursor: pointer;
}
.cinema-url-go:active { transform: scale(0.98); }
.cinema-url-hint {
  margin-top: 14px; padding: 10px 12px;
  background: rgba(234, 179, 8, 0.08);
  border: 1px solid rgba(234, 179, 8, 0.2);
  border-radius: 10px;
  font-size: 12px; opacity: 0.85; line-height: 1.5;
}
.cinema-url-history {
  margin-top: 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.cinema-url-history-item {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  cursor: pointer; transition: background .15s;
  font-size: 12px;
}
.cinema-url-history-item:hover { background: rgba(255,255,255,0.08); }
.cinema-url-history-item .url-host { font-weight: 600; opacity: 0.9; }
.cinema-url-history-item .url-path { opacity: 0.55; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cinema-url-history-item .url-del {
  margin-left: auto; background: transparent; border: 0;
  color: rgba(255,255,255,0.5); cursor: pointer; padding: 2px 6px;
}

/* Iframe blocked fallback */
.cinema-iframe-fallback {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px; padding: 20px; text-align: center;
  background: linear-gradient(160deg, rgba(212, 168, 67, 0.08), rgba(0,0,0,0.4));
  color: #fff;
}
.cinema-iframe-fallback .ico { font-size: 48px; }
.cinema-iframe-fallback .title { font-size: 16px; font-weight: 700; }
.cinema-iframe-fallback .sub { font-size: 13px; opacity: 0.7; max-width: 320px; line-height: 1.5; }
.cinema-iframe-fallback .open-btn {
  margin-top: 6px; padding: 12px 22px;
  background: linear-gradient(135deg, #d4a843, #c8941e);
  color: #0a0e27; font-weight: 700; font-size: 14px;
  border: 0; border-radius: 12px; cursor: pointer;
  text-decoration: none;
}
.cinema-video::cue {
  background: rgba(0,0,0,0.75);
  color: white;
  font-size: 1rem;
  font-family: var(--font);
  border-radius: 4px;
  padding: 3px 8px;
}
.cinema-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.3);
  transition: opacity 0.25s ease;
  z-index: 2;
}
.cinema-overlay.hidden { opacity: 0; pointer-events: none; }
.cinema-big-play {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.06));
  backdrop-filter: blur(24px) saturate(1.2);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  border: 2px solid rgba(255,255,255,0.2);
  color: white;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 5px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.12);
  transition: all 0.2s ease;
}
.cinema-big-play:active { transform: scale(0.88); }
.cinema-sub-display {
  position: absolute;
  bottom: 12%;
  left: 4%;
  right: 4%;
  text-align: center;
  pointer-events: none;
  z-index: 3;
}
.cinema-sub-display span {
  display: inline;
  background: rgba(0,0,0,0.78);
  color: #fff;
  font-size: 0.92rem;
  font-weight: 600;
  padding: 0.3rem 0.7rem;
  border-radius: 8px;
  line-height: 1.65;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.cinema-info-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 0.22rem 0.55rem;
  border-radius: 8px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1);
  z-index: 2;
}
.cinema-info-badge span {
  font-size: 0.6rem;
  font-weight: 800;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.5px;
}
/* Seek Indicator */
.cinema-seek-indicator {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  padding: 0.5rem 0.9rem;
  border-radius: 12px;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  color: white;
  font-size: 1.1rem;
  font-weight: 800;
  z-index: 4;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
}
.cinema-seek-indicator.left { left: 15%; }
.cinema-seek-indicator.right { right: 15%; }
.cinema-seek-indicator.visible { opacity: 1; }
/* Speed Badge */
.cinema-speed-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 0.22rem 0.55rem;
  border-radius: 8px;
  background: rgba(168,85,247,0.3);
  border: 1px solid rgba(168,85,247,0.4);
  z-index: 2;
  display: none;
}
.cinema-speed-badge span {
  font-size: 0.6rem;
  font-weight: 800;
  color: #C084FC;
  letter-spacing: 0.3px;
}
.cinema-speed-badge.visible { display: block; }
/* Controls */
.cinema-controls {
  padding: 0.45rem 0.7rem 0.6rem;
  background: linear-gradient(180deg, rgba(0,0,0,0.88), rgba(0,0,0,0.96));
  border-top: 1px solid rgba(255,255,255,0.04);
}
.cinema-progress-wrap {
  padding: 0.5rem 0 0.35rem;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.cinema-progress-bar {
  height: 3px;
  background: rgba(255,255,255,0.1);
  border-radius: 999px;
  position: relative;
  overflow: visible;
  transition: height 0.15s ease;
}
.cinema-progress-wrap:active .cinema-progress-bar { height: 6px; }
.cinema-progress-fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 80%, white));
  border-radius: inherit;
  transition: width 0.1s linear;
  z-index: 2;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 40%, transparent);
}
.cinema-progress-fill::after {
  content: '';
  position: absolute;
  right: -5px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent) 50%, transparent), 0 2px 6px rgba(0,0,0,0.3);
  opacity: 0;
  transition: opacity 0.15s ease;
}
.cinema-progress-wrap:active .cinema-progress-fill::after { opacity: 1; }
.cinema-progress-buffer {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: rgba(255,255,255,0.12);
  border-radius: inherit;
  z-index: 1;
}
.cinema-controls-row {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}
.cinema-ctrl-btn {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: rgba(255,255,255,0.85);
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.08);
  transition: all 0.15s ease;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.06);
}
.cinema-ctrl-btn:active {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 25%, transparent), color-mix(in srgb, var(--accent) 10%, transparent));
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
  color: var(--accent);
  transform: scale(0.93);
  box-shadow: 0 0 16px color-mix(in srgb, var(--accent) 20%, transparent);
}
.cinema-ctrl-btn.speed-btn {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: -0.3px;
}
.cinema-time {
  flex: 1;
  text-align: center;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.45);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  letter-spacing: 0.3px;
}
.cinema-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
  margin-bottom: 1rem;
}
.cinema-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  padding: 1rem 0.5rem;
  background: var(--card-bg);
  box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  font-size: 0.78rem;
  color: var(--text2);
  font-weight: 600;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.cinema-action-btn::before {
  content: '';
  position: absolute;
  top: -20px; left: 50%; transform: translateX(-50%);
  width: 60px; height: 60px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.cinema-action-btn:active { border-color: var(--accent); color: var(--accent); transform: scale(0.96); }
.cinema-action-btn:active::before { opacity: 0.6; }
.cinema-action-ico { font-size: 1.5rem; }
.cinema-now-card {
  background: var(--card-bg);
  box-shadow: var(--card-shadow);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  padding: 0.8rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.cinema-now-thumb {
  width: 56px;
  height: 42px;
  border-radius: 8px;
  background: #000;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,0.08);
}
.cinema-now-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cinema-now-info { flex: 1; min-width: 0; }
.cinema-now-title { font-size: 0.82rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cinema-now-meta { font-size: 0.68rem; color: var(--text3); margin-top: 0.1rem; }
.cinema-playlist {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.cinema-playlist-item {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 0.75rem;
  background: var(--card-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition);
}
.cinema-playlist-item:active { border-color: var(--accent); transform: scale(0.98); }
.cinema-playlist-item.active {
  border-color: var(--accent);
  box-shadow: 0 0 16px var(--accent-glow);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent);
}
.cinema-pl-num { font-size: 0.7rem; color: var(--text3); font-weight: 700; min-width: 1.2rem; }
.cinema-playlist-item.active .cinema-pl-num { color: var(--accent); }
.cinema-pl-name { flex: 1; font-size: 0.8rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cinema-pl-dur { font-size: 0.68rem; color: var(--text3); }
.cinema-pl-remove { font-size: 0.8rem; color: var(--text3); padding: 0.3rem; }
.cinema-pl-remove:active { color: var(--danger); }
.cinema-empty { margin-bottom: 1rem; }

/* ============================================================
   END CINEMA
   ============================================================ */

/* ---------- Gallery Toggle ---------- */
.view-toggle {
  display: flex;
  background: rgba(15,16,20,0.7);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xs);
  overflow: hidden;
  margin-left: auto;
}
.view-toggle-btn {
  padding: 0.3rem 0.6rem;
  font-size: 0.82rem;
  color: var(--text3);
  transition: all 0.2s ease;
  border-right: 1px solid var(--glass-border);
}
.view-toggle-btn:last-child { border-right: none; }
.view-toggle-btn.active {
  background: var(--accent-soft);
  color: var(--accent);
}

/* ---------- Gallery Grid ---------- */
.doc-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}
.gallery-item {
  position: relative;
  aspect-ratio: 3/4;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--glass-border);
  background: var(--bg4);
  cursor: pointer;
  transition: all 0.2s ease;
}
.gallery-item:active {
  transform: scale(0.97);
  border-color: var(--accent);
}
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gallery-item-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  background: linear-gradient(135deg, var(--bg3), var(--bg5));
}
.gallery-item-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0.5rem;
  background: linear-gradient(transparent, rgba(0,0,0,0.85));
}
.gallery-item-title {
  font-size: 0.62rem;
  font-weight: 700;
  color: white;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gallery-item-meta {
  font-size: 0.52rem;
  color: rgba(255,255,255,0.6);
  margin-top: 0.1rem;
}
.gallery-item .confidence-badge {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
}
.gallery-item-status {
  position: absolute;
  top: 0.35rem;
  left: 0.35rem;
  font-size: 0.6rem;
}

/* ---------- Enhanced Folder Cards ---------- */
.folder-card {
  position: relative;
  overflow: hidden;
}
.folder-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.folder-card:active::before { opacity: 1; }
.folder-card-stats {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.35rem;
}
.folder-card-stat {
  font-size: 0.6rem;
  color: var(--text3);
  display: flex;
  align-items: center;
  gap: 0.2rem;
}

/* ============================================================
   FULLSCREEN GALLERY VIEWER
   ============================================================ */
.gallery-viewer {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(0,0,0,0.97);
  display: flex;
  flex-direction: column;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
}
.gallery-viewer-bg {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  filter: blur(60px) brightness(0.3) saturate(1.5);
  opacity: 0.4;
  pointer-events: none;
  transform: scale(1.3);
}
.gallery-viewer-topbar {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: max(env(safe-area-inset-top, 12px), 12px) 16px 8px;
  background: linear-gradient(180deg, rgba(0,0,0,0.7) 0%, transparent 100%);
}
.gallery-viewer-close {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  color: white;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.gallery-viewer-close:active { background: rgba(255,255,255,0.2); }
.gallery-viewer-counter {
  font-size: 0.78rem;
  font-weight: 700;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.5px;
}
.gallery-viewer-download {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  color: white;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.gallery-viewer-download:active { background: var(--accent-soft); color: var(--accent); }
.gallery-viewer-stage {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
  overflow: hidden;
  padding: 0 8px;
}
.gallery-viewer-img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  transition: opacity 0.2s ease;
  pointer-events: none;
}
.gallery-viewer-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: 44px;
  height: 64px;
  border-radius: 14px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: white;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
}
.gallery-viewer-nav:active {
  background: rgba(255,255,255,0.15);
  transform: translateY(-50%) scale(0.93);
}
.gallery-nav-prev { left: 8px; }
.gallery-nav-next { right: 8px; }
.gallery-viewer-nav.hidden { opacity: 0; pointer-events: none; }
.gallery-viewer-info {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: 8px 16px max(env(safe-area-inset-bottom, 16px), 16px);
  background: linear-gradient(0deg, rgba(0,0,0,0.7) 0%, transparent 100%);
}
.gallery-viewer-info .gv-title {
  font-size: 0.82rem;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gallery-viewer-info .gv-meta {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.45);
  margin-top: 0.15rem;
}

/* ---------- Onboarding Welcome ---------- */
.welcome-card {
  background: linear-gradient(180deg, rgba(15,16,20,0.92), rgba(8,8,12,0.98));
  border: 1px solid transparent;
  border-radius: var(--radius);
  padding: 2rem 1.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-bottom: 1rem;
  background-clip: padding-box;
}
.welcome-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: var(--radius);
  padding: 1px;
  background: linear-gradient(135deg, var(--accent), rgba(168,85,247,0.5), var(--accent));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: welcomeBorderShift 4s ease-in-out infinite alternate;
  opacity: 0.6;
}
.welcome-card::after {
  content: '';
  position: absolute;
  top: -60px; left: 50%; transform: translateX(-50%);
  width: 240px; height: 240px;
  background: radial-gradient(circle, var(--accent-glow) 0%, rgba(168,85,247,0.08) 40%, transparent 70%);
  filter: blur(40px);
  opacity: 0.6;
  pointer-events: none;
}
@keyframes welcomeBorderShift {
  0% { opacity: 0.4; }
  100% { opacity: 0.8; }
}
.welcome-emoji {
  font-size: 3rem;
  margin-bottom: 0.75rem;
  position: relative;
}
.welcome-title {
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 0.4rem;
  position: relative;
}
.welcome-sub {
  font-size: 0.82rem;
  color: var(--text2);
  line-height: 1.5;
  position: relative;
  max-width: 280px;
  margin: 0 auto;
}
.welcome-steps {
  margin-top: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  position: relative;
}
.welcome-step {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.9rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  text-align: left;
  transition: all 0.2s ease;
  position: relative;
  overflow: hidden;
}
.welcome-step::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent);
  border-radius: 0 4px 4px 0;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.welcome-step:active {
  border-color: var(--accent);
  background: var(--accent-soft);
  transform: scale(0.98);
}
.welcome-step:active::before {
  opacity: 1;
}
.welcome-step-ico { font-size: 1.3rem; flex-shrink: 0; }
.welcome-step-text {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text);
}
/* ============================================================
   PIN LOCK SCREEN
   ============================================================ */
.pin-lock-screen {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: radial-gradient(ellipse at 50% 20%, rgba(15,16,20,0.97), rgba(3,3,5,0.99));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
}
.pin-lock-screen::before {
  content: '';
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, var(--accent-glow) 0%, rgba(59,130,246,0.05) 50%, transparent 70%);
  filter: blur(60px);
  pointer-events: none;
  opacity: 0.5;
  animation: pinGlow 5s ease-in-out infinite alternate;
}
@keyframes pinGlow {
  0% { opacity: 0.3; transform: translateX(-50%) scale(0.9); }
  100% { opacity: 0.6; transform: translateX(-50%) scale(1.1); }
}
.pin-lock-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem;
  width: 100%;
  max-width: 320px;
}
.pin-lock-logo {
  font-size: 3rem;
  margin-bottom: 1rem;
  position: relative;
}
@keyframes pinLogoFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
.pin-lock-title {
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 0.3rem;
  letter-spacing: -0.3px;
}
.pin-lock-subtitle {
  font-size: 0.78rem;
  color: var(--text3);
  margin-bottom: 1.5rem;
}
.pin-dots {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}
.pin-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.2);
  background: transparent;
  transition: all 0.2s ease;
}
.pin-dot.filled {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 40%, transparent);
  transform: scale(1.1);
}
.pin-dot.error {
  background: var(--danger);
  border-color: var(--danger);
  box-shadow: 0 0 12px rgba(239,68,68,0.4);
  animation: pinShake 0.4s ease;
}
@keyframes pinShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-8px); }
  40% { transform: translateX(8px); }
  60% { transform: translateX(-6px); }
  80% { transform: translateX(6px); }
}
.pin-error {
  font-size: 0.78rem;
  color: var(--danger);
  font-weight: 700;
  margin-bottom: 0.5rem;
  min-height: 1.2rem;
}
.pin-keypad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.7rem;
  width: 100%;
  max-width: 270px;
  margin-top: 0.5rem;
}
.pin-key {
  width: 100%;
  aspect-ratio: 1.3;
  border-radius: 18px;
  font-size: 1.5rem;
  font-weight: 800;
  color: white;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.06);
  -webkit-tap-highlight-color: transparent;
  cursor: pointer;
}
.pin-key:active {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 30%, transparent), color-mix(in srgb, var(--accent) 12%, transparent));
  border-color: color-mix(in srgb, var(--accent) 50%, transparent);
  transform: scale(0.93);
  box-shadow: 0 0 20px color-mix(in srgb, var(--accent) 25%, transparent), 0 2px 8px rgba(0,0,0,0.3);
}
.pin-key-empty {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  pointer-events: none;
}
.pin-key-delete {
  font-size: 1.3rem;
  color: var(--text2);
}
.pin-key-delete:active {
  color: var(--danger);
  background: rgba(239,68,68,0.12);
  border-color: rgba(239,68,68,0.3);
}

.welcome-step-hint {
  font-size: 0.65rem;
  color: var(--text3);
  margin-top: 0.1rem;
}

/* ============================================================
   PREMIUM DEADLINE FORM
   ============================================================ */
.dl-type-chips {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.dl-type-chip {
  padding: 0.4rem 0.7rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--text2);
  transition: all 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.dl-type-chip:active,
.dl-type-chip.selected {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
}
.dl-field {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  margin-bottom: 0.85rem;
  padding: 0.75rem 0.85rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 16px;
}
.dl-field-icon {
  font-size: 1.15rem;
  flex-shrink: 0;
  margin-top: 0.15rem;
}
.dl-field-body {
  flex: 1;
  min-width: 0;
}
.dl-field-label {
  display: block;
  font-size: 0.62rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-weight: 700;
  margin-bottom: 0.3rem;
}
.dl-field-input {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 600;
  font-family: var(--font);
  outline: none;
  padding: 0;
}
.dl-field-input::placeholder { color: var(--text3); font-weight: 500; }
.dl-field-textarea {
  min-height: 60px;
  resize: vertical;
  line-height: 1.4;
}
.dl-field-input:focus { color: var(--accent); }
select.dl-field-input {
  background: transparent;
  color-scheme: dark;
  min-height: 44px;
}
.dl-field-half { flex: 1; }
.dl-datetime-row {
  display: flex;
  gap: 0.65rem;
  margin-bottom: 0.85rem;
}
.dl-datetime-row .dl-field { margin-bottom: 0; flex: 1; }
.dl-color-section {
  margin-bottom: 0.85rem;
  padding: 0.75rem 0.85rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 16px;
}
.dl-color-label {
  display: block;
  font-size: 0.62rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-weight: 700;
  margin-bottom: 0.55rem;
}
.dl-color-row {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}
.dl-color-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--dc);
  border: 2.5px solid transparent;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  position: relative;
}
.dl-color-dot:active { transform: scale(0.9); }
.dl-color-dot.active {
  border-color: #fff;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--dc) 30%, transparent), 0 4px 16px rgba(0,0,0,0.25);
  transform: scale(1.12);
}
.dl-reminder-card {
  margin-bottom: 0.85rem;
  padding: 0.75rem 0.85rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 16px;
}
.dl-reminder-header {
  margin-bottom: 0.6rem;
}
.dl-reminder-toggle {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.dl-reminder-toggle input { display: none; }
.dl-toggle-track {
  width: 44px;
  height: 26px;
  border-radius: 999px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.08);
  position: relative;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.dl-toggle-thumb {
  position: absolute;
  left: 3px;
  top: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--text3);
  transition: all 0.2s ease;
}
.dl-reminder-toggle input:checked ~ .dl-toggle-track {
  background: var(--accent-soft);
  border-color: var(--accent);
}
.dl-reminder-toggle input:checked ~ .dl-toggle-track .dl-toggle-thumb {
  left: 21px;
  background: var(--accent);
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent) 40%, transparent);
}
.dl-reminder-text {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text);
}
.dl-reminder-options {
  padding-top: 0.5rem;
}
.dl-reminder-opt-row {
  display: flex;
  gap: 0.55rem;
}
.dl-reminder-opt-row .dl-field { margin-bottom: 0.5rem; flex: 1; padding: 0.55rem 0.7rem; }
.dl-reminder-hint {
  font-size: 0.68rem;
  color: var(--text3);
  line-height: 1.35;
}
.dl-notif-btn {
  width: 100%;
  padding: 0.5rem 0.7rem;
  border-radius: 12px;
  background: var(--accent-soft);
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 700;
  font-family: var(--font);
  transition: all 0.15s ease;
}
.dl-notif-btn:active { background: var(--accent); color: white; }
.dl-actions {
  gap: 0.65rem;
}
#deadlineSheet .dl-field-input[type="date"],
#deadlineSheet .dl-field-input[type="time"] {
  min-height: 44px;
  color-scheme: dark;
  cursor: pointer;
}

/* ============================================================
   LONG-PRESS ACTION SHEET (delete / rename / preview)
   ============================================================ */
.long-press-active {
  transform: scale(0.95);
  opacity: 0.7;
  transition: transform 0.15s ease, opacity 0.15s ease;
}

.doc-action-sheet {
  position: fixed; inset: 0; z-index: 9995;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
}
.doc-action-sheet.visible { opacity: 1; pointer-events: auto; }

.doc-action-sheet .action-sheet-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.doc-action-sheet .action-sheet-content {
  position: absolute; left: 12px; right: 12px;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
  background: rgba(28, 28, 30, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 14px;
  padding: 8px;
  display: flex; flex-direction: column; gap: 4px;
  transform: translateY(20px);
  transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1);
}
.doc-action-sheet.visible .action-sheet-content { transform: translateY(0); }

.doc-action-sheet .action-sheet-title {
  font-size: 13px; color: rgba(255,255,255,0.6);
  padding: 12px 16px 6px;
  text-align: center;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.doc-action-sheet .action-sheet-btn {
  background: rgba(255,255,255,0.06);
  border: none;
  color: #fff;
  padding: 14px 16px;
  border-radius: 10px;
  font-size: 16px;
  text-align: left;
  cursor: pointer;
  min-height: 48px;
}
.doc-action-sheet .action-sheet-btn:active { background: rgba(255,255,255,0.12); }
.doc-action-sheet .action-sheet-danger { color: #ff453a; }
.doc-action-sheet .action-sheet-cancel {
  margin-top: 4px;
  background: rgba(255,255,255,0.1);
  text-align: center;
  font-weight: 600;
}

/* ═══ CINEMA-1.B — Source Switcher Bar ═══ */
.cinema-source-bar {
  position: absolute; top: 0; left: 0; right: 0;
  z-index: 12;
  background: linear-gradient(180deg, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.5) 70%, transparent 100%);
  padding: 14px 16px;
  padding-top: max(14px, env(safe-area-inset-top));
  display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.cinema-source-bar > * { pointer-events: auto; }

.cinema-source-info {
  display: flex; flex-direction: column; gap: 2px;
}
.cinema-source-title {
  color: #fff; font-size: 15px; font-weight: 600;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cinema-source-provider {
  color: rgba(255,255,255,0.7); font-size: 12px;
}

.cinema-source-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.cinema-source-btn {
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  padding: 9px 13px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: transform 0.1s ease, background 0.15s ease;
}
.cinema-source-btn:active {
  background: rgba(255,255,255,0.28);
  transform: scale(0.96);
}
.cinema-source-btn.pulse {
  animation: cinemaPulseSrc 1.4s ease-in-out infinite;
  background: rgba(99, 102, 241, 0.45);
  border-color: rgba(99, 102, 241, 0.6);
}
@keyframes cinemaPulseSrc {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(99,102,241,0.4); }
  50% { transform: scale(1.04); box-shadow: 0 0 0 8px rgba(99,102,241,0); }
}
.cinema-source-close {
  margin-left: auto;
  padding: 9px 12px;
}

/* ═══ CINEMA-1.C — Rich Fallback Overlay ═══ */
.cinema-fallback-overlay {
  position: fixed; inset: 0; z-index: 9998;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
}
.cinema-fallback-overlay.visible { opacity: 1; pointer-events: auto; }

.fb-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.fb-content {
  position: absolute;
  left: 16px; right: 16px;
  bottom: calc(env(safe-area-inset-bottom) + 16px);
  background: rgba(28, 28, 30, 0.96);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border-radius: 18px;
  padding: 20px 16px 16px;
  display: flex; flex-direction: column; gap: 8px;
  max-height: 80vh; overflow-y: auto;
  transform: translateY(20px);
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
}
.cinema-fallback-overlay.visible .fb-content { transform: translateY(0); }

.fb-icon { font-size: 32px; text-align: center; margin-bottom: 4px; }
.fb-title { color: #fff; font-size: 18px; font-weight: 600; text-align: center; }
.fb-subtitle { color: rgba(255,255,255,0.6); font-size: 13px; text-align: center; margin-bottom: 12px; }

.fb-movie-card {
  background: rgba(255,255,255,0.06);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 12px;
}
.fb-movie-title { color: #fff; font-size: 15px; font-weight: 500; }
.fb-movie-meta { color: rgba(255,255,255,0.5); font-size: 12px; margin-top: 4px; }

.fb-section-label {
  color: rgba(255,255,255,0.5);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 8px;
  margin-bottom: 4px;
  padding: 0 4px;
}

.fb-btn {
  background: rgba(255,255,255,0.08);
  border: none;
  color: #fff;
  padding: 14px 16px;
  border-radius: 10px;
  font-size: 15px;
  text-align: left;
  cursor: pointer;
  display: block; width: 100%;
  transition: background 0.15s ease;
}
.fb-btn:active { background: rgba(255,255,255,0.16); }
.fb-btn-primary { background: rgba(99, 102, 241, 0.25); }
.fb-btn-primary:active { background: rgba(99, 102, 241, 0.4); }
.fb-btn-secondary { background: rgba(255,255,255,0.06); }
.fb-btn-cancel {
  background: rgba(255,255,255,0.12);
  text-align: center;
  font-weight: 600;
  margin-top: 8px;
}

/* ════════════════════════════════════════════════════════════════
   HACKER STACK — terminal-style widgets (visible in all themes,
   fully expressive in [data-theme="matrix"]).
   ════════════════════════════════════════════════════════════════ */

.hacker-stack {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1rem;
}
.hacker-block {
  position: relative;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px 12px 14px;
  box-shadow: var(--card-shadow);
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  font-size: 12px;
}
.hk-header {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  letter-spacing: 0.2px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--border);
  flex-wrap: wrap;
}
.hk-prompt { color: var(--accent); font-weight: 700; }
.hk-colon  { color: var(--text2); }
.hk-path   { color: var(--text2); }
.hk-dollar { color: var(--accent); margin: 0 6px 0 2px; font-weight: 700; }
.hk-cmd    { color: var(--text); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hk-led {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--text3);
  box-shadow: 0 0 0 0 var(--text3);
  flex-shrink: 0;
}
.hk-led.ok {
  background: #22c55e;
  box-shadow: 0 0 8px rgba(34,197,94,0.55);
  animation: hk-pulse 2.4s ease-in-out infinite;
}
.hk-led.warn { background: #f59e0b; box-shadow: 0 0 8px rgba(245,158,11,0.55); }
.hk-led.err  { background: #ef4444; box-shadow: 0 0 8px rgba(239,68,68,0.55); }
@keyframes hk-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(0.85); }
}

.hk-grid {
  display: grid;
  gap: 6px;
}
.hk-grid-4 { grid-template-columns: repeat(4, 1fr); }
.hk-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 8px 6px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 6px;
  min-width: 0;
  overflow: hidden;
}
.hk-k {
  font-size: 9px;
  letter-spacing: 0.8px;
  color: var(--text3);
  text-transform: uppercase;
  font-weight: 600;
}
.hk-v {
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hk-v.hk-big {
  font-size: 18px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.5px;
}
.hk-v.hk-trunc { font-size: 11px; color: var(--text2); }

.hk-progress {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hk-bar {
  height: 6px;
  background: rgba(255,255,255,0.05);
  border-radius: 3px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.hk-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 60%, white) 100%);
  box-shadow: 0 0 8px var(--accent-glow);
  transition: width 0.6s cubic-bezier(.22,.9,.25,1);
}
.hk-meta {
  font-size: 10px;
  color: var(--text2);
  display: flex;
  align-items: center;
  gap: 6px;
}
.hk-sep { color: var(--text3); }

.hk-rows {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hk-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 5px 8px;
  background: rgba(255,255,255,0.015);
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 11px;
  min-height: 26px;
}
.hk-row .hk-k { font-size: 9px; flex-shrink: 0; }
.hk-row .hk-v { font-size: 11px; text-align: right; max-width: 60%; }

.hk-modules-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}
.hk-mod {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px 10px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 11px;
  min-height: 56px;
  cursor: pointer;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}
.hk-mod:active { transform: scale(0.97); background: rgba(255,255,255,0.04); }
.hk-mod-id { font-size: 9px; color: var(--text3); letter-spacing: 1px; }
.hk-mod-name { font-size: 12px; color: var(--text); font-weight: 700; letter-spacing: 0.3px; }
.hk-mod-status { font-size: 9px; letter-spacing: 0.6px; text-transform: uppercase; font-weight: 700; }
.hk-mod[data-state="online"]   { border-color: color-mix(in srgb, var(--accent) 35%, transparent); }
.hk-mod[data-state="online"]   .hk-mod-status { color: var(--accent); }
.hk-mod[data-state="online"]::before {
  content: ''; position: absolute; top: 8px; right: 8px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent-glow);
}
.hk-mod[data-state="offline"]  .hk-mod-status { color: #f59e0b; }
.hk-mod[data-state="reserved"] { opacity: 0.55; border-style: dashed; }
.hk-mod[data-state="reserved"] .hk-mod-status { color: var(--text3); }

/* ════════════════════════════════════════════════════════════════
   MATRIX THEME — green-on-black brutalist terminal aesthetic.
   Activated via [data-theme="matrix"]. Overrides global font, palette,
   borders. Keeps all functionality intact.
   ════════════════════════════════════════════════════════════════ */

[data-theme="matrix"] {
  --accent: #00ff41;
  --accent-glow: rgba(0,255,65,0.32);
  --accent-soft: rgba(0,255,65,0.10);
  --border-accent: rgba(0,255,65,0.55);
  --bg: #000000;
  --bg2: #030503;
  --bg3: #050a06;
  --bg4: #07120a;
  --bg5: #0a1a0e;
  --border: rgba(0,255,65,0.18);
  --text: #d3ffda;
  --text2: #6ad07c;
  --text3: #2f7340;
  --glass: rgba(3,8,4,0.86);
  --glass-border: rgba(0,255,65,0.22);
  --card-bg: linear-gradient(145deg, rgba(2,8,4,0.95) 0%, rgba(5,15,8,0.7) 100%);
  --card-shadow:
    0 2px 12px rgba(0,255,65,0.06),
    0 0 0 1px rgba(0,255,65,0.15) inset;
  --font: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  --radius: 6px;
  --radius-sm: 4px;
  --radius-xs: 2px;
}

/* Subtle scanline + grid overlay across the whole shell. Fixed to body so
   it doesn't repaint on content updates. */
[data-theme="matrix"] body::before {
  background:
    repeating-linear-gradient(
      0deg,
      rgba(0,255,65,0.025) 0px,
      rgba(0,255,65,0.025) 1px,
      transparent 1px,
      transparent 3px
    ),
    radial-gradient(ellipse at 50% 0%, rgba(0,255,65,0.06) 0%, transparent 60%),
    radial-gradient(ellipse at 50% 100%, rgba(0,255,65,0.04) 0%, transparent 70%),
    #000000;
}

[data-theme="matrix"] body {
  font-family: var(--font);
  letter-spacing: 0.2px;
}

[data-theme="matrix"] .topbar {
  background: rgba(0,0,0,0.92);
  border-bottom: 1px solid var(--border-accent);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
[data-theme="matrix"] .app-logo {
  font-family: var(--font);
  font-weight: 800;
  text-transform: uppercase;
  text-shadow: 0 0 8px var(--accent-glow), 0 0 16px var(--accent-glow);
  letter-spacing: 1px;
}
[data-theme="matrix"] .app-logo::before { content: '> '; color: var(--accent); }
[data-theme="matrix"] .app-version {
  background: transparent;
  border: 1px solid var(--accent);
  border-radius: 0;
  padding: 2px 6px;
  font-family: var(--font);
  letter-spacing: 0.6px;
}
[data-theme="matrix"] .icon-btn {
  background: rgba(0,255,65,0.04);
  border: 1px solid var(--border);
  border-radius: 0;
}
[data-theme="matrix"] .icon-btn:active {
  background: rgba(0,255,65,0.14);
  border-color: var(--accent);
}

/* Hero card → terminal window */
[data-theme="matrix"] .dash-hero {
  background: var(--card-bg);
  border: 1px solid var(--border-accent);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
[data-theme="matrix"] .dash-hero::before {
  content: '┌─[ DOCOS://CORE ]──────────────────────────────────┐';
  display: block;
  font-family: var(--font);
  font-size: 9px;
  color: var(--accent);
  letter-spacing: 0.5px;
  padding: 6px 10px 0;
  white-space: nowrap;
  overflow: hidden;
  opacity: 0.85;
}
[data-theme="matrix"] .dash-hero-greeting {
  font-family: var(--font);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  text-shadow: 0 0 8px var(--accent-glow);
}
[data-theme="matrix"] .dash-hero-greeting::before { content: '> '; }
[data-theme="matrix"] .dash-hero-time {
  font-family: var(--font);
  font-weight: 800;
  color: var(--accent);
  text-shadow: 0 0 14px var(--accent-glow), 0 0 28px var(--accent-glow);
  letter-spacing: -1px;
  position: relative;
}
[data-theme="matrix"] .dash-hero-time::after {
  content: '_';
  display: inline-block;
  margin-left: 4px;
  color: var(--accent);
  animation: hk-blink 1s steps(2, end) infinite;
}
@keyframes hk-blink { 50% { opacity: 0; } }
[data-theme="matrix"] .dash-hero-date {
  font-family: var(--font);
  color: var(--text2);
  letter-spacing: 0.5px;
}
[data-theme="matrix"] .dash-hero-storage-pill {
  background: transparent;
  border: 1px solid var(--accent);
  border-radius: 0;
  font-family: var(--font);
  letter-spacing: 0.5px;
  color: var(--accent);
}
[data-theme="matrix"] .dash-hero-storage-dot {
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent-glow);
}

/* Stats → 4 hard-edge data blocks */
[data-theme="matrix"] .dash-stat-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  position: relative;
}
[data-theme="matrix"] .dash-stat-card::before {
  content: '[ ]';
  position: absolute;
  top: 4px; left: 6px;
  font-size: 8px;
  color: var(--text3);
  letter-spacing: 1px;
}
[data-theme="matrix"] .dash-stat-num {
  color: var(--accent);
  font-family: var(--font);
  font-weight: 800;
  text-shadow: 0 0 10px var(--accent-glow);
}
[data-theme="matrix"] .dash-stat-label {
  font-family: var(--font);
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text2);
}

/* Storage widget → terminal data block */
[data-theme="matrix"] .dash-storage-widget,
[data-theme="matrix"] .dash-calendar-wrap,
[data-theme="matrix"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
}
[data-theme="matrix"] .dash-storage-label,
[data-theme="matrix"] .section-title {
  font-family: var(--font);
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
}
[data-theme="matrix"] .section-title::before { content: '// '; opacity: 0.7; }
[data-theme="matrix"] .dash-storage-bar { background: rgba(0,255,65,0.06); }
[data-theme="matrix"] .dash-storage-bar-fill {
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 50%, white));
  box-shadow: 0 0 8px var(--accent-glow);
}
[data-theme="matrix"] .dash-storage-health {
  font-family: var(--font);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* Quick actions → terminal-style buttons */
[data-theme="matrix"] .dash-action-btn {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
}
[data-theme="matrix"] .dash-action-btn:active {
  background: rgba(0,255,65,0.08);
  border-color: var(--accent);
}
[data-theme="matrix"] .dash-action-text {
  font-family: var(--font);
  font-size: 10px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text);
}

/* Calendar → hard grid */
[data-theme="matrix"] .calendar-mini { font-family: var(--font); }
[data-theme="matrix"] .calendar-mini-day,
[data-theme="matrix"] .cal-day {
  border-radius: 0 !important;
  font-family: var(--font);
}
[data-theme="matrix"] .calendar-mini-day.today,
[data-theme="matrix"] .cal-day.today {
  background: var(--accent) !important;
  color: #000 !important;
  font-weight: 800;
  box-shadow: 0 0 12px var(--accent-glow);
}

/* Hacker stack — full neon glow in matrix */
[data-theme="matrix"] .hacker-block {
  background: rgba(0,3,1,0.9);
  border: 1px solid var(--border-accent);
  box-shadow:
    0 0 0 1px rgba(0,255,65,0.06) inset,
    0 0 18px rgba(0,255,65,0.04);
  border-radius: var(--radius-sm);
}
[data-theme="matrix"] .hacker-block::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px; right: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);
  opacity: 0.5;
}
[data-theme="matrix"] .hk-cell {
  background: rgba(0,255,65,0.025);
  border: 1px solid var(--border);
  border-radius: 0;
}
[data-theme="matrix"] .hk-row {
  background: rgba(0,255,65,0.02);
  border: 1px solid var(--border);
  border-radius: 0;
}
[data-theme="matrix"] .hk-mod {
  background: rgba(0,255,65,0.02);
  border: 1px solid var(--border);
  border-radius: 0;
}
[data-theme="matrix"] .hk-mod[data-state="online"] {
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(0,255,65,0.15) inset;
}
[data-theme="matrix"] .hk-bar { border-radius: 0; }

/* Folders/recent docs → boxes */
[data-theme="matrix"] .dash-folder-rail .folder-rail-item,
[data-theme="matrix"] .recent-docs-list .doc-item,
[data-theme="matrix"] .doc-list .doc-item,
[data-theme="matrix"] .folder-grid .folder-item {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
}

/* Bottom dock → terminal taskbar */
[data-theme="matrix"] .bottom-dock {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.95) 0%, rgba(0,0,0,1) 100%);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-top: 1px solid var(--accent);
  box-shadow: 0 -4px 24px rgba(0,255,65,0.08);
}
[data-theme="matrix"] .bottom-dock::after { display: none; }
[data-theme="matrix"] .dock-btn {
  border-radius: 0;
  font-family: var(--font);
}
[data-theme="matrix"] .dock-label,
[data-theme="matrix"] .dock-btn-label {
  font-family: var(--font);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
[data-theme="matrix"] .dock-btn.active {
  background: rgba(0,255,65,0.10);
  border-color: var(--accent);
  box-shadow: 0 0 12px rgba(0,255,65,0.18) inset;
}

/* Buttons & inputs */
[data-theme="matrix"] button,
[data-theme="matrix"] input,
[data-theme="matrix"] select,
[data-theme="matrix"] textarea {
  font-family: var(--font);
}
[data-theme="matrix"] .filter-chip,
[data-theme="matrix"] .link-btn {
  border-radius: 0;
  font-family: var(--font);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-size: 10px;
}
[data-theme="matrix"] .filter-chip.active {
  background: var(--accent);
  color: #000;
  border-color: var(--accent);
  box-shadow: 0 0 10px var(--accent-glow);
}
[data-theme="matrix"] .search-input {
  background: rgba(0,255,65,0.03);
  border: 1px solid var(--border-accent);
  border-radius: 0;
  font-family: var(--font);
  color: var(--text);
}
[data-theme="matrix"] .search-input::placeholder { color: var(--text3); }

/* Toasts in matrix */
[data-theme="matrix"] .cloud-toast {
  background: rgba(0,0,0,0.96);
  border: 1px solid var(--accent);
  border-radius: 0;
  font-family: var(--font);
  color: var(--accent);
  text-shadow: 0 0 6px var(--accent-glow);
  letter-spacing: 0.5px;
}

/* Theme swatches list — make matrix one stand out */
.theme-swatch[data-theme="matrix"] {
  background: linear-gradient(135deg, #000 0%, #003a0e 100%) !important;
  border: 1px solid #00ff41 !important;
  box-shadow: 0 0 10px rgba(0,255,65,0.35) !important;
}


/* ════════════════════════════════════════════════════════════════
   v5.0.1 — Compact terminal dashboard.
   Hide old hero/stats/storage widgets (now folded into hacker stack).
   Bulgarian-first terminal hero with huge clock.
   ════════════════════════════════════════════════════════════════ */

#screen-dashboard .dash-hero,
#screen-dashboard .dash-stats,
#screen-dashboard .dash-storage-widget,
#screen-dashboard .dash-actions {
  display: none !important;
}

/* SYSTEM_STATUS — huge clock block inside hacker block */
.hk-clock-block {
  text-align: center;
  padding: 14px 8px 12px;
  margin-bottom: 10px;
  border-bottom: 1px dashed var(--border);
  position: relative;
}
.hk-greeting {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 10px;
  letter-spacing: 2.5px;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 4px;
  opacity: 0.85;
}
.hk-greeting::before { content: '> '; }
.hk-clock {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-weight: 800;
  font-size: 56px;
  line-height: 1;
  color: var(--accent);
  letter-spacing: -2px;
  text-shadow: 0 0 14px var(--accent-glow), 0 0 28px var(--accent-glow);
  margin: 4px 0 6px;
}
.hk-blink {
  display: inline-block;
  margin-left: 4px;
  color: var(--accent);
  animation: hk-blink 1s steps(2, end) infinite;
}
.hk-clock-sub {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 11px;
  letter-spacing: 1.5px;
  color: var(--text2);
  text-transform: uppercase;
}

/* Two-bar progress: local + cloud */
.hk-progress {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.hk-bar-row {
  display: grid;
  grid-template-columns: 64px 1fr 88px;
  gap: 8px;
  align-items: center;
}
.hk-bar-label {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 9px;
  letter-spacing: 1.2px;
  color: var(--text2);
  font-weight: 700;
  text-transform: uppercase;
}
.hk-bar-meta {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 10px;
  color: var(--text2);
  text-align: right;
  white-space: nowrap;
}
.hk-fill-cloud {
  background: linear-gradient(90deg, #38bdf8 0%, #818cf8 100%) !important;
  box-shadow: 0 0 8px rgba(56,189,248,0.45) !important;
}

/* Inline secure button */
.hk-btn-inline {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.8px;
  font-weight: 700;
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: 4px;
  padding: 3px 10px;
  cursor: pointer;
  transition: all 0.18s ease;
}
.hk-btn-inline:active { background: var(--accent); color: #000; transform: scale(0.96); }
.hk-row-sec.secured .hk-btn-inline { background: transparent; opacity: 0.7; }

/* Quick actions hacker block */
.hk-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.hk-quick-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 6px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  cursor: pointer;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
  min-height: 70px;
  justify-content: center;
}
.hk-quick-btn:active {
  background: rgba(255,255,255,0.05);
  border-color: var(--accent);
  transform: scale(0.96);
}
.hk-q-key {
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--text3);
  font-weight: 700;
}
.hk-q-ico { font-size: 22px; line-height: 1; }
.hk-q-text {
  font-size: 10px;
  letter-spacing: 1.2px;
  color: var(--text);
  font-weight: 700;
  text-transform: uppercase;
}

/* Compact calendar in dashboard */
#screen-dashboard .dash-calendar-wrap {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  padding: 10px 12px 12px;
}
#screen-dashboard .calendar-mini {
  gap: 2px !important;
}
#screen-dashboard .cal-day {
  min-height: 28px !important;
  font-size: 11px !important;
  padding: 2px !important;
}
#screen-dashboard .cal-header-cell {
  font-size: 9px !important;
  font-family: 'JetBrains Mono', 'SF Mono', monospace !important;
  letter-spacing: 1px !important;
  color: var(--text2) !important;
}

/* Section titles → terminal style on dashboard */
#screen-dashboard .section-header .section-title {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
}
#screen-dashboard .section-header .section-title::before {
  content: '// ';
  opacity: 0.6;
}
#screen-dashboard .link-btn {
  font-family: 'JetBrains Mono', 'SF Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

/* Matrix theme tweaks for new compact layout */
[data-theme="matrix"] .hk-clock { color: var(--accent); text-shadow: 0 0 16px var(--accent-glow), 0 0 32px var(--accent-glow); }
[data-theme="matrix"] .hk-quick-btn { border-radius: 0; }
[data-theme="matrix"] .hk-fill-cloud {
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 50%, white)) !important;
  box-shadow: 0 0 8px var(--accent-glow) !important;
}
[data-theme="matrix"] .hk-btn-inline { border-radius: 0; }


/* ════════════════════════════════════════════
   Calendar — terminal nav + month picker overlay
   ════════════════════════════════════════════ */
.hk-cal { padding-bottom: 10px; }
.hk-cal-nav {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}
.hk-cal-btn {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  color: var(--accent);
  width: 30px; height: 30px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.hk-cal-btn:hover { background: rgba(34,197,94,0.10); border-color: var(--accent); }
.hk-cal-btn:active { transform: scale(0.94); }

.hk-cal-month-btn {
  background: rgba(34,197,94,0.06);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: inherit;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 6px;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 8px;
  min-width: 0;
  transition: background .15s ease, border-color .15s ease;
}
.hk-cal-month-btn:hover { background: rgba(34,197,94,0.12); border-color: var(--accent); }
.hk-cal-month {
  font-weight: 700;
  letter-spacing: 0.4px;
  color: var(--text);
  text-transform: uppercase;
  font-size: 12px;
  white-space: nowrap;
}
.hk-cal-year {
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
}

.hk-cal-today {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 30%, transparent), transparent);
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: 0 10px;
  height: 30px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  cursor: pointer;
  transition: background .15s ease, transform .1s ease;
}
.hk-cal-today:hover { background: color-mix(in srgb, var(--accent) 20%, transparent); }
.hk-cal-today:active { transform: scale(0.94); }

.hk-cal-foot {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--border);
}
.hk-cal-hint {
  font-size: 10px;
  color: var(--text2);
  letter-spacing: 0.2px;
}

/* Month picker overlay */
.hk-month-picker {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 9990;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.hk-month-picker-card {
  background: var(--card-bg);
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 14px;
  width: min(320px, 100%);
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 24px color-mix(in srgb, var(--accent) 25%, transparent);
}
.hk-mp-header {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border);
}
.hk-mp-year {
  text-align: center;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--accent);
  font-size: 14px;
}
.hk-mp-close {
  background: rgba(239,68,68,0.10);
  border: 1px solid rgba(239,68,68,0.45);
  color: #ef4444;
  width: 30px; height: 30px;
  border-radius: 6px;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s ease;
}
.hk-mp-close:hover { background: rgba(239,68,68,0.22); }
.hk-mp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.hk-mp-cell {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 10px 4px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.hk-mp-cell:hover { background: rgba(34,197,94,0.12); border-color: var(--accent); }
.hk-mp-cell:active { transform: scale(0.95); }
.hk-mp-cell.sel {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: var(--accent);
  color: var(--accent);
}
.hk-mp-cell.now::after {
  content: '•';
  margin-left: 4px;
  color: var(--accent);
}

/* Matrix theme — sharper edges */
[data-theme="matrix"] .hk-cal-btn,
[data-theme="matrix"] .hk-cal-month-btn,
[data-theme="matrix"] .hk-cal-today,
[data-theme="matrix"] .hk-mp-cell,
[data-theme="matrix"] .hk-mp-close,
[data-theme="matrix"] .hk-month-picker-card { border-radius: 0; }

/* ════════════════════════════════════════════
   Folders — terminal preview block (dashboard)
   ════════════════════════════════════════════ */
.hk-folders { padding-bottom: 12px; }
.hk-folders-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 10px;
}
.hk-fstat {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 6px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hk-fstat-k {
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text2);
}
.hk-fstat-v {
  font-size: 16px;
  font-weight: 700;
  color: var(--accent);
  font-family: inherit;
}
.hk-fstat-v.warn { color: #f59e0b; }

.hk-folders-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 10px;
}
.hk-folders-empty {
  padding: 14px 8px;
  text-align: center;
  color: var(--text2);
  font-size: 11px;
  border: 1px dashed var(--border);
  border-radius: 6px;
}
.hk-folders-empty b { color: var(--accent); }

.hk-frow {
  display: grid;
  grid-template-columns: auto auto 1fr auto auto;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-left: 2px solid color-mix(in srgb, var(--accent) 60%, transparent);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 12px;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.hk-frow:hover {
  background: rgba(34,197,94,0.08);
  border-left-color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}
.hk-frow:active { transform: scale(0.99); }
.hk-frow-perms {
  color: var(--text3);
  font-size: 10px;
  letter-spacing: 0.4px;
}
.hk-frow-icon { font-size: 14px; line-height: 1; }
.hk-frow-name {
  font-weight: 600;
  letter-spacing: 0.2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.hk-frow-size {
  color: var(--accent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.4px;
}
.hk-frow-flag {
  background: rgba(245,158,11,0.18);
  color: #f59e0b;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid rgba(245,158,11,0.35);
}
.hk-folders-more {
  font-size: 10px;
  color: var(--text2);
  text-align: center;
  padding: 6px 0 2px;
  letter-spacing: 0.3px;
}
.hk-folders-more::before { content: '└─ '; color: var(--accent); }

.hk-folders-open {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--accent) 8%, transparent));
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: 12px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: lowercase;
  cursor: pointer;
  transition: background .15s ease, transform .1s ease, box-shadow .2s ease;
  position: relative;
  overflow: hidden;
}
.hk-folders-open::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 35%, transparent), transparent);
  transform: translateX(-100%);
  transition: transform .55s ease;
}
.hk-folders-open:hover {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 32%, transparent), color-mix(in srgb, var(--accent) 14%, transparent));
  box-shadow: 0 0 18px color-mix(in srgb, var(--accent) 25%, transparent);
}
.hk-folders-open:hover::before { transform: translateX(100%); }
.hk-folders-open:active { transform: scale(0.98); }
.hk-fopen-arrow { color: var(--accent); }
.hk-fopen-label { flex: 1; text-align: left; padding-left: 8px; }
.hk-fopen-tail { font-size: 14px; }

[data-theme="matrix"] .hk-fstat,
[data-theme="matrix"] .hk-frow,
[data-theme="matrix"] .hk-folders-empty,
[data-theme="matrix"] .hk-folders-open { border-radius: 0; }

/* ════════════════════════════════════════════
   Inline ✕ delete button — queue/doc/gallery
   ════════════════════════════════════════════ */
.item-delete-btn {
  background: rgba(239,68,68,0.10);
  border: 1px solid rgba(239,68,68,0.35);
  color: #ef4444;
  width: 32px; height: 32px;
  min-width: 32px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
  flex-shrink: 0;
}
.item-delete-btn:hover {
  background: rgba(239,68,68,0.22);
  border-color: rgba(239,68,68,0.6);
}
.item-delete-btn:active { transform: scale(0.92); }

.item-delete-btn--abs {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 3;
  width: 28px; height: 28px;
  min-width: 28px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-color: rgba(239,68,68,0.45);
}
.item-delete-btn--abs:hover { background: rgba(239,68,68,0.55); color: #fff; }

.gallery-item { position: relative; }
.doc-item { position: relative; align-items: center; }

.queue-snapshot-btns {
  display: flex;
  align-items: center;
  gap: 6px;
}

[data-theme="matrix"] .item-delete-btn { border-radius: 0; }

/* ════════════════════════════════════════════
   MEMORY CORE — action row (backup/restore/sync)
   ════════════════════════════════════════════ */
.hk-mem-actions {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
}
.hk-mem-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 9px 6px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.hk-mem-btn:hover {
  background: rgba(34,197,94,0.10);
  border-color: var(--accent);
  color: var(--accent);
}
.hk-mem-btn:active { transform: scale(0.96); }
.hk-mem-btn.primary {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--accent) 8%, transparent));
  border-color: var(--accent);
  color: var(--accent);
}
.hk-mem-btn.primary:hover {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 32%, transparent), color-mix(in srgb, var(--accent) 14%, transparent));
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 25%, transparent);
}
.hk-mem-arrow { color: var(--accent); font-size: 9px; }
.hk-mem-tail { color: var(--text2); font-size: 9px; font-weight: 500; }

.hk-key-copy {
  cursor: pointer;
  text-decoration: underline dotted color-mix(in srgb, var(--accent) 40%, transparent);
  text-underline-offset: 3px;
  transition: color .15s ease;
}
.hk-key-copy:hover { color: var(--accent); }
.hk-key-copy::after {
  content: ' ⧉';
  opacity: 0.6;
  font-size: 0.85em;
}

[data-theme="matrix"] .hk-mem-btn { border-radius: 0; }

/* ════════════════════════════════════════════
   Hacker-block section variant + header action chip
   ════════════════════════════════════════════ */
.hk-section { padding: 12px 12px 10px; }
.hk-section > .hk-header { margin-bottom: 8px; padding-bottom: 8px; }

.hk-header-btn {
  margin-left: auto;
  background: rgba(34,197,94,0.08);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--border));
  color: var(--accent);
  padding: 3px 8px;
  border-radius: 4px;
  font-family: inherit;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1px;
  cursor: pointer;
  transition: background .15s ease, transform .1s ease;
  white-space: nowrap;
}
.hk-header-btn:hover {
  background: rgba(34,197,94,0.18);
  border-color: var(--accent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 30%, transparent);
}
.hk-header-btn:active { transform: scale(0.94); }
[data-theme="matrix"] .hk-header-btn { border-radius: 0; }

/* ════════════════════════════════════════════
   BOTTOM DOCK — Matrix terminal taskbar
   Sharp corners, mono font, [01]-[05] tab keys, green active glow
   ════════════════════════════════════════════ */
[data-theme="matrix"] .bottom-dock {
  background: linear-gradient(180deg, rgba(8,12,16,0.96), rgba(3,5,8,0.99)) !important;
  border-top: 1px solid var(--accent) !important;
  box-shadow:
    0 -1px 0 color-mix(in srgb, var(--accent) 22%, transparent) inset,
    0 -20px 60px rgba(0,0,0,0.7) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
[data-theme="matrix"] .bottom-dock::before {
  background: linear-gradient(90deg, transparent, var(--accent), transparent) !important;
  opacity: 1 !important;
  height: 1px !important;
  filter: drop-shadow(0 0 4px var(--accent));
}
[data-theme="matrix"] .bottom-dock::after { display: none !important; }

[data-theme="matrix"] .dock-btn {
  border-radius: 0 !important;
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace !important;
  background: transparent !important;
  border: 0 !important;
  border-top: 2px solid transparent !important;
  padding: 14px 6px 6px !important;
  min-width: 56px !important;
  position: relative;
  box-shadow: none !important;
}
[data-theme="matrix"] .dock-btn::before,
[data-theme="matrix"] .dock-btn::after {
  display: none !important;
}

/* Tab key indicator [01]-[05] above icon */
[data-theme="matrix"] .dock-btn .dock-icon::after {
  position: absolute;
  top: 2px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px;
  color: var(--text3);
  letter-spacing: 1px;
  font-weight: 700;
  opacity: 0.7;
}
[data-theme="matrix"] .dock-btn[data-tab="dashboard"] .dock-icon::after { content: '[01]'; }
[data-theme="matrix"] .dock-btn[data-tab="documents"] .dock-icon::after { content: '[02]'; }
[data-theme="matrix"] .dock-btn[data-tab="scan"] .dock-icon::after      { content: '[+ ]'; color: var(--accent) !important; opacity: 1 !important; }
[data-theme="matrix"] .dock-btn[data-tab="cinema"] .dock-icon::after    { content: '[04]'; }
[data-theme="matrix"] .dock-btn[data-tab="more"] .dock-icon::after      { content: '[05]'; }
[data-theme="matrix"] .dock-btn.active .dock-icon::after { color: var(--accent) !important; opacity: 1 !important; }

[data-theme="matrix"] .dock-btn .dock-icon {
  border-radius: 0 !important;
  background: transparent !important;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border)) !important;
  width: 38px !important;
  height: 30px !important;
  font-size: 1.05rem !important;
  transform: none !important;
  box-shadow: none !important;
  filter: grayscale(0.4) opacity(0.75);
  transition: all .18s ease;
}
[data-theme="matrix"] .dock-btn .dock-label {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  color: var(--text3) !important;
  margin-top: 4px !important;
  text-shadow: none !important;
  transform: none !important;
}

[data-theme="matrix"] .dock-btn.active {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 8%, transparent) 0%, transparent 100%) !important;
  border-top: 2px solid var(--accent) !important;
  box-shadow:
    0 -8px 22px color-mix(in srgb, var(--accent) 18%, transparent) inset,
    0 -1px 0 var(--accent) !important;
}
[data-theme="matrix"] .dock-btn.active .dock-icon {
  background: color-mix(in srgb, var(--accent) 8%, transparent) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent) 35%, transparent), inset 0 0 8px color-mix(in srgb, var(--accent) 14%, transparent) !important;
  color: var(--accent) !important;
  filter: grayscale(0) opacity(1);
}
[data-theme="matrix"] .dock-btn.active .dock-label {
  color: var(--accent) !important;
  text-shadow: 0 0 6px color-mix(in srgb, var(--accent) 50%, transparent) !important;
}

/* CENTER button — primary scan action */
[data-theme="matrix"] .dock-btn.dock-center .dock-icon {
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 50%, white)) !important;
  border: 1px solid var(--accent) !important;
  color: #000 !important;
  font-weight: 900 !important;
  font-size: 1.3rem !important;
  width: 48px !important;
  height: 32px !important;
  box-shadow:
    0 0 14px color-mix(in srgb, var(--accent) 65%, transparent),
    0 0 28px color-mix(in srgb, var(--accent) 35%, transparent) !important;
  filter: none;
}
[data-theme="matrix"] .dock-btn.dock-center .dock-icon::after {
  color: #000 !important;
  opacity: 0.7 !important;
}
[data-theme="matrix"] .dock-btn.dock-center.active {
  background: transparent !important;
  border-top-color: transparent !important;
  box-shadow: none !important;
}

/* Press feedback */
[data-theme="matrix"] .dock-btn.dock-pressed .dock-icon,
[data-theme="matrix"] .dock-btn:active .dock-icon { transform: scale(0.93) !important; }


/* ════════════════════════════════════════════════════════════════
   v5.1.0 — RICH THEME ENGINE
   13 теми с пълни визуални трансформации, не само accent color.
   Цветовите теми (Синя/Жълта/Червена/Зелена/Оранж) сега получават
   background pattern, custom card glow, акцент-tint навсякъде.
   Нови: Cyberpunk, Synthwave, Amber CRT, German, Bloodmoon, Nordic.
   ════════════════════════════════════════════════════════════════ */

/* ---------- Theme switch flash ---------- */
html.theme-switching body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--accent);
  opacity: 0;
  pointer-events: none;
  z-index: 9999;
  animation: themeFlash 0.42s ease-out;
}
@keyframes themeFlash {
  0%   { opacity: 0; }
  25%  { opacity: 0.10; }
  100% { opacity: 0; }
}

/* ---------- Universal accent tint for color themes ---------- */
[data-theme="black-blue"] body::before,
[data-theme="black-yellow"] body::before,
[data-theme="black-red"] body::before,
[data-theme="black-green"] body::before,
[data-theme="black-orange"] body::before {
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, var(--accent-glow) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 110%, var(--accent-soft) 0%, transparent 70%),
    var(--bg);
}

[data-theme="black-blue"] .hk-clock,
[data-theme="black-yellow"] .hk-clock,
[data-theme="black-red"] .hk-clock,
[data-theme="black-green"] .hk-clock,
[data-theme="black-orange"] .hk-clock {
  color: var(--accent);
  text-shadow: 0 0 14px var(--accent-glow), 0 0 28px var(--accent-glow);
}

[data-theme="black-blue"] .dash-stat-num,
[data-theme="black-yellow"] .dash-stat-num,
[data-theme="black-red"] .dash-stat-num,
[data-theme="black-green"] .dash-stat-num,
[data-theme="black-orange"] .dash-stat-num,
[data-theme="black-blue"] .hk-greeting,
[data-theme="black-yellow"] .hk-greeting,
[data-theme="black-red"] .hk-greeting,
[data-theme="black-green"] .hk-greeting,
[data-theme="black-orange"] .hk-greeting,
[data-theme="black-blue"] .section-title,
[data-theme="black-yellow"] .section-title,
[data-theme="black-red"] .section-title,
[data-theme="black-green"] .section-title,
[data-theme="black-orange"] .section-title {
  color: var(--accent);
}

[data-theme="black-blue"] .hacker-block,
[data-theme="black-yellow"] .hacker-block,
[data-theme="black-red"] .hacker-block,
[data-theme="black-green"] .hacker-block,
[data-theme="black-orange"] .hacker-block {
  border-color: var(--border-accent);
  box-shadow:
    0 0 0 1px var(--accent-soft) inset,
    0 8px 32px rgba(0,0,0,0.4),
    0 0 24px var(--accent-soft);
}

[data-theme="black-blue"] .bottom-dock,
[data-theme="black-yellow"] .bottom-dock,
[data-theme="black-red"] .bottom-dock,
[data-theme="black-green"] .bottom-dock,
[data-theme="black-orange"] .bottom-dock {
  border-top: 1px solid var(--border-accent);
}

[data-theme="black-blue"] .dock-btn.active,
[data-theme="black-yellow"] .dock-btn.active,
[data-theme="black-red"] .dock-btn.active,
[data-theme="black-green"] .dock-btn.active,
[data-theme="black-orange"] .dock-btn.active {
  background: var(--accent-soft);
  box-shadow: 0 0 20px var(--accent-glow) inset;
}


/* ════════════════════════════════════════════════════════════════
   CYBERPUNK — neon pink/cyan, sharp corners, glitch
   ════════════════════════════════════════════════════════════════ */
[data-theme="cyberpunk"] {
  --accent: #ff0080;
  --accent-glow: rgba(255,0,128,0.45);
  --accent-soft: rgba(255,0,128,0.14);
  --accent-2: #00fff0;
  --accent-2-glow: rgba(0,255,240,0.45);
  --border-accent: rgba(255,0,128,0.55);
  --bg: #06010a;
  --bg2: #0a0410;
  --bg3: #0f0518;
  --bg4: #150a22;
  --bg5: #1d0e2f;
  --border: rgba(255,0,128,0.18);
  --text: #fdf2ff;
  --text2: #c89adb;
  --text3: #6b4a85;
  --glass: rgba(10,4,16,0.86);
  --glass-border: rgba(255,0,128,0.28);
  --card-bg: linear-gradient(135deg, rgba(15,5,24,0.92) 0%, rgba(29,14,47,0.7) 100%);
  --card-shadow:
    0 0 0 1px rgba(255,0,128,0.18) inset,
    0 8px 24px rgba(255,0,128,0.10);
  --font: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  --radius: 4px;
  --radius-sm: 3px;
  --radius-xs: 2px;
}
[data-theme="cyberpunk"] body::before {
  background:
    repeating-linear-gradient(0deg, rgba(255,0,128,0.025) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(90deg, rgba(0,255,240,0.02) 0 1px, transparent 1px 4px),
    radial-gradient(ellipse at 0% 0%, rgba(255,0,128,0.10) 0%, transparent 50%),
    radial-gradient(ellipse at 100% 100%, rgba(0,255,240,0.10) 0%, transparent 50%),
    #06010a;
}
[data-theme="cyberpunk"] body { font-family: var(--font); letter-spacing: 0.3px; }
[data-theme="cyberpunk"] .topbar {
  background: rgba(6,1,10,0.96);
  border-bottom: 1px solid var(--accent);
  box-shadow: 0 0 20px rgba(255,0,128,0.15);
}
[data-theme="cyberpunk"] .app-logo {
  font-family: var(--font);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--accent);
  text-shadow: 2px 0 var(--accent-2), -1px 0 var(--accent), 0 0 12px var(--accent-glow);
}
[data-theme="cyberpunk"] .app-version {
  background: var(--accent);
  color: #000;
  border: none;
  border-radius: 0;
  padding: 2px 8px;
  font-weight: 800;
  letter-spacing: 1px;
}
[data-theme="cyberpunk"] .hacker-block,
[data-theme="cyberpunk"] .dash-storage-widget,
[data-theme="cyberpunk"] .dash-calendar-wrap,
[data-theme="cyberpunk"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border-accent);
  border-radius: var(--radius-sm);
  position: relative;
}
[data-theme="cyberpunk"] .hacker-block::before {
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%) !important;
  opacity: 0.7 !important;
  height: 2px !important;
}
[data-theme="cyberpunk"] .hk-clock {
  color: var(--accent);
  text-shadow:
    2px 0 var(--accent-2),
    -2px 0 var(--accent),
    0 0 18px var(--accent-glow),
    0 0 36px var(--accent-glow);
  animation: cyberpunk-glitch 4s infinite;
}
@keyframes cyberpunk-glitch {
  0%, 95%, 100% { text-shadow: 2px 0 var(--accent-2), -2px 0 var(--accent), 0 0 18px var(--accent-glow), 0 0 36px var(--accent-glow); }
  96% { text-shadow: -3px 0 var(--accent-2), 3px 0 var(--accent), 0 0 18px var(--accent-glow); transform: translateX(1px); }
  97% { text-shadow: 4px 0 var(--accent-2), -4px 0 var(--accent), 0 0 18px var(--accent-glow); transform: translateX(-1px); }
  98% { text-shadow: 2px 0 var(--accent-2), -2px 0 var(--accent), 0 0 18px var(--accent-glow); }
}
[data-theme="cyberpunk"] .hk-greeting,
[data-theme="cyberpunk"] .section-title { color: var(--accent-2); text-shadow: 0 0 8px var(--accent-2-glow); }
[data-theme="cyberpunk"] .hk-quick-btn,
[data-theme="cyberpunk"] .dash-action-btn {
  background: rgba(255,0,128,0.04);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
[data-theme="cyberpunk"] .hk-quick-btn:active,
[data-theme="cyberpunk"] .dash-action-btn:active {
  background: var(--accent);
  color: #000;
  border-color: var(--accent-2);
  box-shadow: 0 0 16px var(--accent-glow), 0 0 32px var(--accent-2-glow);
}
[data-theme="cyberpunk"] .bottom-dock {
  background: linear-gradient(180deg, rgba(6,1,10,0.96) 0%, rgba(29,14,47,1) 100%);
  border-top: 1px solid var(--accent);
  box-shadow: 0 -2px 24px rgba(255,0,128,0.20);
}
[data-theme="cyberpunk"] .dock-btn.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #000 !important;
  border-radius: 0;
}


/* ════════════════════════════════════════════════════════════════
   SYNTHWAVE — 80s sunset, purple/pink/orange
   ════════════════════════════════════════════════════════════════ */
[data-theme="synthwave"] {
  --accent: #ff6ec7;
  --accent-glow: rgba(255,110,199,0.40);
  --accent-soft: rgba(255,110,199,0.14);
  --border-accent: rgba(255,110,199,0.55);
  --bg: #0d0524;
  --bg2: #150834;
  --bg3: #1c0d44;
  --bg4: #251352;
  --bg5: #2e1962;
  --border: rgba(255,110,199,0.18);
  --text: #fce4ff;
  --text2: #c98edf;
  --text3: #75598f;
  --glass: rgba(13,5,36,0.86);
  --glass-border: rgba(255,110,199,0.30);
  --card-bg: linear-gradient(180deg, rgba(28,13,68,0.95) 0%, rgba(46,25,98,0.65) 100%);
  --card-shadow:
    0 0 0 1px rgba(255,110,199,0.20) inset,
    0 8px 32px rgba(255,110,199,0.12);
  --font: 'Plus Jakarta Sans', -apple-system, sans-serif;
  --radius: 14px;
  --radius-sm: 10px;
  --radius-xs: 6px;
}
[data-theme="synthwave"] body::before {
  background:
    linear-gradient(180deg, transparent 0%, transparent 55%, rgba(255,110,199,0.06) 60%, rgba(255,110,199,0.18) 75%, rgba(255,180,80,0.20) 100%),
    repeating-linear-gradient(180deg, transparent 0 40px, rgba(255,110,199,0.04) 40px 41px),
    radial-gradient(ellipse 60% 40% at 50% 90%, rgba(255,180,80,0.25) 0%, transparent 60%),
    linear-gradient(180deg, #0d0524 0%, #1c0d44 60%, #2e1962 100%);
}
[data-theme="synthwave"] .topbar {
  background: rgba(13,5,36,0.94);
  border-bottom: 1px solid rgba(255,110,199,0.25);
}
[data-theme="synthwave"] .app-logo {
  background: linear-gradient(90deg, #ff6ec7 0%, #ffb380 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
  letter-spacing: 1px;
  filter: drop-shadow(0 0 12px rgba(255,110,199,0.5));
}
[data-theme="synthwave"] .hk-clock {
  background: linear-gradient(180deg, #ffd0ff 0%, #ff6ec7 50%, #ffb380 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 22px rgba(255,110,199,0.55));
}
[data-theme="synthwave"] .hk-greeting,
[data-theme="synthwave"] .section-title { color: #ffb380; text-shadow: 0 0 10px rgba(255,180,128,0.5); }
[data-theme="synthwave"] .hacker-block,
[data-theme="synthwave"] .dash-storage-widget,
[data-theme="synthwave"] .dash-calendar-wrap,
[data-theme="synthwave"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border-accent);
  box-shadow: var(--card-shadow);
}
[data-theme="synthwave"] .dash-stat-num {
  background: linear-gradient(180deg, #ff6ec7, #ffb380);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
[data-theme="synthwave"] .hk-quick-btn:active,
[data-theme="synthwave"] .dash-action-btn:active {
  background: linear-gradient(135deg, var(--accent), #ffb380);
  color: #0d0524;
  border-color: transparent;
  box-shadow: 0 0 18px var(--accent-glow);
}
[data-theme="synthwave"] .bottom-dock {
  background: linear-gradient(180deg, rgba(13,5,36,0.94) 0%, rgba(46,25,98,1) 100%);
  border-top: 1px solid rgba(255,110,199,0.30);
}
[data-theme="synthwave"] .dock-btn.active {
  background: linear-gradient(135deg, #ff6ec7, #ffb380);
  color: #0d0524 !important;
}


/* ════════════════════════════════════════════════════════════════
   AMBER CRT — old-school orange terminal
   ════════════════════════════════════════════════════════════════ */
[data-theme="amber"] {
  --accent: #ffb000;
  --accent-glow: rgba(255,176,0,0.45);
  --accent-soft: rgba(255,176,0,0.10);
  --border-accent: rgba(255,176,0,0.55);
  --bg: #0a0500;
  --bg2: #120800;
  --bg3: #190b00;
  --bg4: #221000;
  --bg5: #2d1700;
  --border: rgba(255,176,0,0.18);
  --text: #ffe7b3;
  --text2: #c79155;
  --text3: #6b4d28;
  --glass: rgba(10,5,0,0.88);
  --glass-border: rgba(255,176,0,0.22);
  --card-bg: linear-gradient(145deg, rgba(18,8,0,0.95) 0%, rgba(34,16,0,0.7) 100%);
  --card-shadow:
    0 0 0 1px rgba(255,176,0,0.12) inset,
    0 0 14px rgba(255,176,0,0.04);
  --font: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  --radius: 4px;
  --radius-sm: 3px;
  --radius-xs: 2px;
}
[data-theme="amber"] body::before {
  background:
    repeating-linear-gradient(0deg, rgba(255,176,0,0.04) 0 1px, transparent 1px 3px),
    radial-gradient(ellipse 100% 80% at 50% 50%, rgba(255,176,0,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(255,120,0,0.10) 0%, transparent 70%),
    #0a0500;
}
[data-theme="amber"] body { font-family: var(--font); letter-spacing: 0.2px; }
[data-theme="amber"] .topbar {
  background: rgba(10,5,0,0.94);
  border-bottom: 1px solid var(--accent);
}
[data-theme="amber"] .app-logo {
  font-family: var(--font);
  text-transform: uppercase;
  font-weight: 800;
  color: var(--accent);
  text-shadow: 0 0 8px var(--accent-glow), 0 0 16px var(--accent-glow);
  letter-spacing: 1px;
}
[data-theme="amber"] .app-logo::before { content: '> '; }
[data-theme="amber"] .app-version {
  background: transparent;
  border: 1px solid var(--accent);
  border-radius: 0;
  color: var(--accent);
  padding: 2px 6px;
  font-family: var(--font);
}
[data-theme="amber"] .hk-clock {
  color: var(--accent);
  text-shadow: 0 0 16px var(--accent-glow), 0 0 36px var(--accent-glow);
}
[data-theme="amber"] .hk-greeting,
[data-theme="amber"] .section-title { color: var(--accent); }
[data-theme="amber"] .section-title::before { content: '// '; opacity: 0.7; }
[data-theme="amber"] .hacker-block,
[data-theme="amber"] .dash-storage-widget,
[data-theme="amber"] .dash-calendar-wrap,
[data-theme="amber"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
}
[data-theme="amber"] .hk-quick-btn,
[data-theme="amber"] .dash-action-btn {
  background: rgba(255,176,0,0.03);
  border: 1px solid var(--border);
  border-radius: 0;
  font-family: var(--font);
}
[data-theme="amber"] .hk-quick-btn:active {
  background: var(--accent);
  color: #0a0500;
  border-color: var(--accent);
  box-shadow: 0 0 14px var(--accent-glow);
}
[data-theme="amber"] .bottom-dock {
  background: rgba(10,5,0,0.97);
  border-top: 1px solid var(--accent);
}
[data-theme="amber"] .dock-btn.active {
  background: rgba(255,176,0,0.12);
  border-color: var(--accent);
  border-radius: 0;
}
[data-theme="amber"] .dock-btn { border-radius: 0; }


/* ════════════════════════════════════════════════════════════════
   GERMAN — Bauhaus dark + brushed gold, premium minimal
   ════════════════════════════════════════════════════════════════ */
[data-theme="german"] {
  --accent: #d4a843;
  --accent-glow: rgba(212,168,67,0.30);
  --accent-soft: rgba(212,168,67,0.10);
  --accent-2: #c8941e;
  --border-accent: rgba(212,168,67,0.45);
  --bg: #0a0e1a;
  --bg2: #0e1320;
  --bg3: #131826;
  --bg4: #1a1f2d;
  --bg5: #232838;
  --border: rgba(212,168,67,0.12);
  --text: #f5f1e8;
  --text2: #a89a78;
  --text3: #5e553f;
  --glass: rgba(14,19,32,0.88);
  --glass-border: rgba(212,168,67,0.18);
  --card-bg: linear-gradient(145deg, rgba(19,24,38,0.95) 0%, rgba(26,31,45,0.7) 100%);
  --card-shadow:
    0 0 0 1px rgba(212,168,67,0.10) inset,
    0 12px 32px rgba(0,0,0,0.5),
    0 0 0 1px rgba(0,0,0,0.4);
  --font: 'Plus Jakarta Sans', -apple-system, sans-serif;
  --radius: 8px;
  --radius-sm: 6px;
  --radius-xs: 4px;
}
[data-theme="german"] body::before {
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(212,168,67,0.07) 0%, transparent 60%),
    linear-gradient(180deg, #0a0e1a 0%, #131826 50%, #0a0e1a 100%);
}
[data-theme="german"] .topbar {
  background: rgba(10,14,26,0.96);
  border-bottom: 1px solid var(--border);
}
[data-theme="german"] .app-logo {
  background: linear-gradient(135deg, #f0d28a 0%, #d4a843 50%, #c8941e 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
  letter-spacing: 0.5px;
}
[data-theme="german"] .app-version {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0a0e1a;
  border: none;
  font-weight: 700;
}
[data-theme="german"] .hk-clock {
  background: linear-gradient(180deg, #f0d28a 0%, #d4a843 50%, #a87d1c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 12px rgba(212,168,67,0.25));
  letter-spacing: -2px;
}
[data-theme="german"] .hk-greeting,
[data-theme="german"] .section-title {
  color: var(--accent);
  font-weight: 700;
}
[data-theme="german"] .hacker-block,
[data-theme="german"] .dash-storage-widget,
[data-theme="german"] .dash-calendar-wrap,
[data-theme="german"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--card-shadow);
}
[data-theme="german"] .hacker-block::before {
  background: linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%) !important;
  height: 1px !important;
  opacity: 0.6 !important;
}
[data-theme="german"] .hk-quick-btn,
[data-theme="german"] .dash-action-btn {
  background: rgba(212,168,67,0.03);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
[data-theme="german"] .hk-quick-btn:active,
[data-theme="german"] .dash-action-btn:active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0a0e1a;
  border-color: transparent;
}
[data-theme="german"] .bottom-dock {
  background: linear-gradient(180deg, rgba(10,14,26,0.96) 0%, rgba(14,19,32,1) 100%);
  border-top: 1px solid var(--border);
}
[data-theme="german"] .dock-btn.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0a0e1a !important;
}
[data-theme="german"] .dash-stat-num {
  background: linear-gradient(180deg, #f0d28a, #d4a843);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 900;
}


/* ════════════════════════════════════════════════════════════════
   BLOODMOON — gothic dark red, dramatic
   ════════════════════════════════════════════════════════════════ */
[data-theme="bloodmoon"] {
  --accent: #dc2626;
  --accent-glow: rgba(220,38,38,0.45);
  --accent-soft: rgba(220,38,38,0.12);
  --border-accent: rgba(220,38,38,0.55);
  --bg: #0a0303;
  --bg2: #110505;
  --bg3: #170707;
  --bg4: #1f0a0a;
  --bg5: #2a0e0e;
  --border: rgba(220,38,38,0.16);
  --text: #f5dada;
  --text2: #b08585;
  --text3: #5c3a3a;
  --glass: rgba(10,3,3,0.90);
  --glass-border: rgba(220,38,38,0.22);
  --card-bg: linear-gradient(145deg, rgba(17,5,5,0.95) 0%, rgba(31,10,10,0.7) 100%);
  --card-shadow:
    0 0 0 1px rgba(220,38,38,0.12) inset,
    0 8px 32px rgba(0,0,0,0.6),
    0 0 24px rgba(220,38,38,0.05);
  --font: 'Plus Jakarta Sans', -apple-system, sans-serif;
  --radius: 6px;
  --radius-sm: 4px;
  --radius-xs: 3px;
}
[data-theme="bloodmoon"] body::before {
  background:
    radial-gradient(ellipse 60% 50% at 50% 100%, rgba(220,38,38,0.18) 0%, transparent 65%),
    radial-gradient(circle 200px at 80% 20%, rgba(220,38,38,0.15) 0%, transparent 70%),
    linear-gradient(180deg, #0a0303 0%, #170707 100%);
}
[data-theme="bloodmoon"] .topbar {
  background: rgba(10,3,3,0.96);
  border-bottom: 1px solid var(--border-accent);
  box-shadow: 0 0 20px rgba(220,38,38,0.10);
}
[data-theme="bloodmoon"] .app-logo {
  color: var(--accent);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-shadow: 0 0 12px var(--accent-glow), 0 0 24px var(--accent-glow);
}
[data-theme="bloodmoon"] .app-version {
  background: var(--accent);
  color: #0a0303;
  border: none;
  font-weight: 800;
  box-shadow: 0 0 12px var(--accent-glow);
}
[data-theme="bloodmoon"] .hk-clock {
  color: var(--accent);
  text-shadow: 0 0 18px var(--accent-glow), 0 0 36px var(--accent-glow), 0 0 60px rgba(220,38,38,0.3);
  letter-spacing: -2px;
}
[data-theme="bloodmoon"] .hk-greeting,
[data-theme="bloodmoon"] .section-title { color: var(--accent); text-shadow: 0 0 8px var(--accent-glow); }
[data-theme="bloodmoon"] .hacker-block,
[data-theme="bloodmoon"] .dash-storage-widget,
[data-theme="bloodmoon"] .dash-calendar-wrap,
[data-theme="bloodmoon"] .card-premium {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--card-shadow);
}
[data-theme="bloodmoon"] .hk-quick-btn:active,
[data-theme="bloodmoon"] .dash-action-btn:active {
  background: var(--accent);
  color: #0a0303;
  border-color: transparent;
  box-shadow: 0 0 24px var(--accent-glow);
}
[data-theme="bloodmoon"] .bottom-dock {
  background: linear-gradient(180deg, rgba(10,3,3,0.96) 0%, rgba(23,7,7,1) 100%);
  border-top: 1px solid var(--border-accent);
}
[data-theme="bloodmoon"] .dock-btn.active {
  background: var(--accent);
  color: #0a0303 !important;
  box-shadow: 0 0 16px var(--accent-glow);
}
[data-theme="bloodmoon"] .dash-stat-num { color: var(--accent); text-shadow: 0 0 10px var(--accent-glow); }


/* ════════════════════════════════════════════════════════════════
   NORDIC — light minimal, soft blue (контрапункт на тъмните)
   ════════════════════════════════════════════════════════════════ */
[data-theme="nordic"] {
  --accent: #5e81ac;
  --accent-glow: rgba(94,129,172,0.30);
  --accent-soft: rgba(94,129,172,0.10);
  --border-accent: rgba(94,129,172,0.40);
  --bg: #eceff4;
  --bg2: #e5e9f0;
  --bg3: #d8dee9;
  --bg4: #cbd2dc;
  --bg5: #b4bac4;
  --border: rgba(76,86,106,0.18);
  --text: #2e3440;
  --text2: #4c566a;
  --text3: #7b8694;
  --danger: #bf616a;
  --success: #a3be8c;
  --warning: #ebcb8b;
  --glass: rgba(255,255,255,0.78);
  --glass-border: rgba(76,86,106,0.14);
  --card-bg: linear-gradient(180deg, #ffffff 0%, #f4f6fa 100%);
  --card-shadow:
    0 1px 0 rgba(255,255,255,0.8) inset,
    0 4px 16px rgba(76,86,106,0.08),
    0 0 0 1px rgba(76,86,106,0.06);
  --font: 'Plus Jakarta Sans', -apple-system, sans-serif;
  --radius: 14px;
  --radius-sm: 10px;
  --radius-xs: 6px;
}
[data-theme="nordic"] body::before {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(94,129,172,0.10) 0%, transparent 60%),
    linear-gradient(180deg, #eceff4 0%, #e5e9f0 100%);
}
[data-theme="nordic"] .topbar {
  background: rgba(236,239,244,0.92);
  border-bottom: 1px solid rgba(76,86,106,0.10);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
[data-theme="nordic"] .app-logo { color: var(--accent); font-weight: 800; }
[data-theme="nordic"] .app-version {
  background: var(--accent);
  color: #ffffff;
  border: none;
  font-weight: 700;
}
[data-theme="nordic"] .icon-btn {
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(76,86,106,0.10);
  color: var(--text);
}
[data-theme="nordic"] .hk-clock { color: var(--accent); text-shadow: none; font-weight: 800; }
[data-theme="nordic"] .hk-greeting,
[data-theme="nordic"] .section-title { color: var(--text2); }
[data-theme="nordic"] .hacker-block,
[data-theme="nordic"] .dash-storage-widget,
[data-theme="nordic"] .dash-calendar-wrap,
[data-theme="nordic"] .card-premium {
  background: var(--card-bg);
  border: 1px solid rgba(76,86,106,0.10);
  border-radius: var(--radius);
  box-shadow: var(--card-shadow);
}
[data-theme="nordic"] .hk-quick-btn,
[data-theme="nordic"] .dash-action-btn {
  background: #ffffff;
  border: 1px solid rgba(76,86,106,0.10);
  border-radius: var(--radius-sm);
  color: var(--text);
}
[data-theme="nordic"] .hk-quick-btn:active,
[data-theme="nordic"] .dash-action-btn:active {
  background: var(--accent);
  color: #ffffff;
}
[data-theme="nordic"] .hk-q-text,
[data-theme="nordic"] .dash-action-text { color: var(--text); }
[data-theme="nordic"] .hk-q-key { color: var(--text3); }
[data-theme="nordic"] .bottom-dock {
  background: rgba(236,239,244,0.94);
  border-top: 1px solid rgba(76,86,106,0.10);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
[data-theme="nordic"] .dock-btn { color: var(--text2); }
[data-theme="nordic"] .dock-btn.active {
  background: var(--accent);
  color: #ffffff !important;
}
[data-theme="nordic"] .dash-stat-num { color: var(--accent); }
[data-theme="nordic"] .dash-stat-label { color: var(--text3); }


/* ════════════════════════════════════════════════════════════════
   THEME PREVIEW SWATCHES — rich mini cards, no naked dot
   ════════════════════════════════════════════════════════════════ */
.theme-grid { gap: 0.55rem; }
.theme-swatch {
  position: relative;
  padding: 0.5rem;
  background: var(--bg3);
  border: 2px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  min-height: 78px;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.theme-swatch:active { transform: scale(0.95); }
.theme-swatch.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent) inset, 0 0 18px var(--accent-glow);
}
.theme-preview {
  position: relative;
  height: 38px;
  border-radius: 8px;
  margin-bottom: 0.4rem;
  overflow: hidden;
  background: #050507;
  border: 1px solid rgba(255,255,255,0.06);
}
.theme-preview-bar {
  position: absolute; top: 0; left: 0; right: 0; height: 6px;
  background: var(--swatch);
  opacity: 0.85;
}
.theme-preview-grid {
  position: absolute; top: 10px; left: 4px; right: 4px;
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2px;
}
.theme-preview-cell {
  height: 12px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
}
.theme-preview-dot {
  position: absolute;
  bottom: 3px; right: 4px;
  width: 12px; height: 12px;
  border-radius: 50%;
  box-shadow: 0 0 10px var(--swatch);
}
.theme-swatch-label {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--text2);
  text-align: center;
  display: block;
}
.theme-swatch.active .theme-swatch-label { color: var(--text); }

/* Per-preview style overrides */
.theme-preview[data-preview="matrix"] {
  background: #000;
  background-image:
    repeating-linear-gradient(0deg, rgba(0,255,65,0.10) 0 1px, transparent 1px 3px);
}
.theme-preview[data-preview="matrix"] .theme-preview-cell { background: rgba(0,255,65,0.18); border: 1px solid rgba(0,255,65,0.35); border-radius: 0; }
.theme-preview[data-preview="matrix"] .theme-preview-bar { height: 8px; opacity: 1; }

.theme-preview[data-preview="cyberpunk"] {
  background: linear-gradient(135deg, #06010a 0%, #1d0e2f 100%);
}
.theme-preview[data-preview="cyberpunk"] .theme-preview-bar {
  background: linear-gradient(90deg, #ff0080 0%, #00fff0 100%);
}
.theme-preview[data-preview="cyberpunk"] .theme-preview-cell {
  background: rgba(255,0,128,0.20);
  border-radius: 0;
}

.theme-preview[data-preview="synthwave"] {
  background: linear-gradient(180deg, #0d0524 0%, #2e1962 60%, #ff6ec7 100%);
}
.theme-preview[data-preview="synthwave"] .theme-preview-bar {
  background: linear-gradient(90deg, #ff6ec7 0%, #ffb380 100%);
}
.theme-preview[data-preview="synthwave"] .theme-preview-cell {
  background: rgba(255,110,199,0.22);
}

.theme-preview[data-preview="amber"] {
  background: #0a0500;
  background-image: repeating-linear-gradient(0deg, rgba(255,176,0,0.14) 0 1px, transparent 1px 3px);
}
.theme-preview[data-preview="amber"] .theme-preview-cell {
  background: rgba(255,176,0,0.22); border-radius: 0;
}

.theme-preview[data-preview="german"] {
  background: linear-gradient(145deg, #131826 0%, #0a0e1a 100%);
}
.theme-preview[data-preview="german"] .theme-preview-bar {
  background: linear-gradient(90deg, #f0d28a 0%, #d4a843 50%, #c8941e 100%);
}
.theme-preview[data-preview="german"] .theme-preview-cell { background: rgba(212,168,67,0.18); }

.theme-preview[data-preview="bloodmoon"] {
  background: radial-gradient(ellipse at 50% 100%, #2a0e0e 0%, #0a0303 100%);
}
.theme-preview[data-preview="bloodmoon"] .theme-preview-cell { background: rgba(220,38,38,0.22); }

.theme-preview[data-preview="nordic"] {
  background: linear-gradient(180deg, #ffffff 0%, #e5e9f0 100%);
}
.theme-preview[data-preview="nordic"] .theme-preview-bar { background: #5e81ac; opacity: 1; }
.theme-preview[data-preview="nordic"] .theme-preview-cell { background: rgba(76,86,106,0.10); }
.theme-preview[data-preview="nordic"] .theme-preview-dot { box-shadow: 0 0 6px rgba(94,129,172,0.4); }

.theme-preview[data-preview="glow"] {
  background: linear-gradient(180deg, #050507 0%, #0F1014 100%);
}
.theme-preview[data-preview="glow"] .theme-preview-bar {
  background: var(--swatch);
  box-shadow: 0 0 12px var(--swatch);
}

.theme-preview[data-preview="rainbow"] {
  background: linear-gradient(135deg, #6366F1 0%, #0EA5E9 50%, #14B8A6 100%);
}
.theme-preview[data-preview="rainbow"] .theme-preview-bar {
  background: linear-gradient(90deg, #6366F1, #0EA5E9, #14B8A6);
  height: 8px;
}
.theme-preview[data-preview="rainbow"] .theme-preview-dot {
  background: linear-gradient(135deg, #A855F7, #0EA5E9) !important;
}

/* ============================================================
   v5.3 — UNIVERSAL GLASS + PERF BOOST
   Глобален glass на всеки card, GPU layers, content-visibility,
   по-леки shadows, network-aware. Поставено в края за да override-не.
   ============================================================ */

:root {
  --glass-bg-soft: rgba(20, 22, 30, 0.42);
  --glass-bg-card: rgba(20, 22, 30, 0.55);
  --glass-bg-strong: rgba(15, 16, 22, 0.72);
  --glass-blur: 18px;
  --glass-blur-strong: 24px;
  --glass-saturate: 1.4;
  --glass-edge: 1px solid rgba(255, 255, 255, 0.09);
  --glass-edge-warm: 1px solid rgba(255, 255, 255, 0.06);
  --glass-shadow-soft: 0 4px 24px rgba(0, 0, 0, 0.28),
                       inset 0 1px 0 rgba(255, 255, 255, 0.04);
  /* Override the heavier original card-bg with glass-friendly tint */
  --card-bg: linear-gradient(155deg,
    rgba(255, 255, 255, 0.06) 0%,
    rgba(255, 255, 255, 0.025) 48%,
    rgba(255, 255, 255, 0.01) 100%);
  --card-shadow: var(--glass-shadow-soft);
}

/* Universal glass on common card surfaces. Uses GPU layer (translateZ)
   so blur compositing stays cheap. */
.card-premium,
.dash-storage-widget,
.dash-stat-card,
.empty-state,
.intake-queue-item,
.doc-card,
.folder-card,
.folder-tile,
.cinema-playlist-item,
.cinema-url-history-item,
.agent-header-card,
.agent-doc-panel,
.agent-actions-panel,
.agent-result-panel,
.theme-card,
.template-card,
.hk-block,
.hk-cal,
.hk-folders,
.hk-stack,
.hk-cinema,
.hk-storage,
.modal-content,
.bottom-sheet,
.toast {
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border: var(--glass-edge);
  background: var(--card-bg);
  box-shadow: var(--glass-shadow-soft);
  transform: translateZ(0);
  will-change: backdrop-filter;
}

/* Strong-glass for sticky/floating overlays (top bar, dock, modals) */
.topbar,
.dock,
.cinema-controls,
.cinema-overlay,
.cinema-bar,
.modal-backdrop {
  backdrop-filter: blur(var(--glass-blur-strong)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur-strong)) saturate(var(--glass-saturate));
  background: var(--glass-bg-strong);
  border-color: rgba(255, 255, 255, 0.08);
  transform: translateZ(0);
}

/* Hover lift — feels Apple-y, cheap effect */
.card-premium:hover,
.dash-stat-card:hover,
.doc-card:hover,
.folder-card:hover,
.cinema-playlist-item:hover,
.theme-card:hover,
.template-card:hover {
  border-color: rgba(255, 255, 255, 0.16);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.36),
              inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
  transform: translateY(-1px) translateZ(0);
}

/* Reduce blur cost on weak devices / battery save */
@media (prefers-reduced-motion: reduce) {
  * {
    will-change: auto !important;
  }
  .card-premium, .dash-storage-widget, .topbar, .dock {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
}

/* ---------- Render perf: skip painting off-screen lists ---------- */
.doc-list,
.intake-queue,
.cinema-playlist,
.theme-grid,
.template-grid,
.folders-grid {
  content-visibility: auto;
  contain-intrinsic-size: 0 600px;
}

/* Image quality boost — keeps thumbnails sharp on HiDPI */
img,
.doc-thumb,
.gallery-thumb,
.cinema-poster {
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}
.doc-thumb img,
.gallery-thumb img {
  image-rendering: auto; /* photos look better with default sampling */
}

/* ---------- Cinema viewport — Netflix-style edge fade ---------- */
.cinema-viewport,
#cinemaViewport {
  contain: layout paint;
  transform: translateZ(0);
}
#cinemaVideo {
  background: #000;
  will-change: transform;
}
/* Soft loading veil while metadata resolves */
.cinema-loading-veil {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center,
    rgba(20, 22, 30, 0.0) 0%, rgba(0, 0, 0, 0.55) 100%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s ease;
  z-index: 5;
}
.cinema-loading-veil.on { opacity: 1; }
.cinema-loading-veil::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 38px; height: 38px;
  margin: -19px 0 0 -19px;
  border: 2px solid rgba(255, 255, 255, 0.18);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: cinemaSpin 0.8s linear infinite;
}
@keyframes cinemaSpin { to { transform: rotate(360deg); } }

/* Slow-net hint chip (shown when navigator.connection is 2g/3g) */
.cinema-net-chip {
  position: absolute;
  top: 10px; right: 10px;
  z-index: 6;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.4px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--text);
  display: none;
}
.cinema-net-chip.on { display: inline-flex; align-items: center; gap: 5px; }
.cinema-net-chip[data-net="slow"] { color: #FCA5A5; border-color: rgba(252, 165, 165, 0.3); }
.cinema-net-chip[data-net="medium"] { color: #FCD34D; border-color: rgba(252, 211, 77, 0.3); }
.cinema-net-chip[data-net="fast"] { color: #86EFAC; border-color: rgba(134, 239, 172, 0.3); }

/* ═══════════════════════════════════════════════════════════════════
   v5.4 — BRUTAL MUSIC + ALARM OVERLAY
   ═══════════════════════════════════════════════════════════════════ */

/* 6-button dock — tighten gaps, smaller labels, keeps thumb-friendly tap */
.bottom-dock--6 { padding-left: 4px !important; padding-right: 4px !important; gap: 0 !important; }
.bottom-dock--6 .dock-btn { padding: 6px 4px !important; min-width: 0 !important; flex: 1 1 0; }
.bottom-dock--6 .dock-btn .dock-icon { font-size: 1.18rem !important; line-height: 1; }
.bottom-dock--6 .dock-btn .dock-label { font-size: .56rem !important; letter-spacing: .04em; margin-top: 2px; }
.bottom-dock--6 .dock-btn.dock-center .dock-icon { font-size: 1.5rem !important; }
@media (max-width: 360px) {
  .bottom-dock--6 .dock-btn .dock-label { font-size: .52rem !important; }
}

/* === MUSIC SCREEN — brutal terminal cockpit === */
#screen-music .screen-scroll { padding-bottom: 7rem; }
.hk-music-head { margin-bottom: .9rem; }
.mp-stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: .35rem; margin-top: .7rem; padding: .65rem .55rem; background: rgba(0,0,0,.35); border: 1px solid rgba(212,168,67,.18); border-radius: 10px; }
.mp-stat { display: flex; flex-direction: column; align-items: center; font-family: 'JetBrains Mono', monospace; }
.mp-stat-k { font-size: .58rem; letter-spacing: .12em; color: rgba(255,255,255,.45); text-transform: uppercase; }
.mp-stat-v { font-size: .92rem; font-weight: 800; color: #d4a843; margin-top: 2px; }
.mp-stat-v.warn { color: #fcd34d; }
.mp-stat-v.ok { color: #86efac; }

/* Now playing cockpit */
.mp-now { display: grid; grid-template-columns: 88px 1fr; gap: 1rem; padding: 1rem; margin-bottom: 1rem; background: linear-gradient(135deg, rgba(212,168,67,.08), rgba(10,14,39,.5)); border: 1px solid rgba(212,168,67,.25); border-radius: 14px; box-shadow: 0 0 24px rgba(212,168,67,.06) inset, 0 8px 28px rgba(0,0,0,.4); position: relative; overflow: hidden; }
.mp-now::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(212,168,67,.03) 3px, rgba(212,168,67,.03) 4px); pointer-events: none; }
.mp-now-art { width: 88px; height: 88px; display: flex; align-items: center; justify-content: center; }
.mp-now-vinyl { width: 88px; height: 88px; border-radius: 50%; background: radial-gradient(circle at 50% 50%, #1a1a1a 0, #050505 70%); border: 2px solid rgba(212,168,67,.35); display: flex; align-items: center; justify-content: center; box-shadow: 0 0 30px rgba(212,168,67,.15), inset 0 0 20px rgba(0,0,0,.7); position: relative; }
.mp-now-vinyl::after { content: ""; position: absolute; inset: 12px; border-radius: 50%; border: 1px dashed rgba(212,168,67,.18); }
.mp-now-vinyl-core { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, #d4a843, #c8941e); color: #050505; font-size: .9rem; font-weight: 900; display: flex; align-items: center; justify-content: center; box-shadow: 0 0 14px rgba(212,168,67,.6); }
.mp-now.playing .mp-now-vinyl { animation: mpVinylSpin 4s linear infinite; }
@keyframes mpVinylSpin { from { transform: rotate(0); } to { transform: rotate(360deg); } }
.mp-now-meta { min-width: 0; }
.mp-now-title { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: 1rem; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-now-sub { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: rgba(255,255,255,.5); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-vis { width: 100%; height: 64px; margin: .55rem 0 .35rem; border-radius: 8px; background: rgba(0,0,0,.55); border: 1px solid rgba(212,168,67,.18); display: block; }

.mp-progress-wrap { margin-top: .35rem; }
.mp-progress-bar { position: relative; height: 8px; background: rgba(0,0,0,.55); border-radius: 4px; cursor: pointer; overflow: hidden; border: 1px solid rgba(212,168,67,.2); }
.mp-progress-fill { position: absolute; left: 0; top: 0; height: 100%; width: 0%; background: linear-gradient(90deg, #d4a843, #c8941e); border-radius: 4px; transition: width .12s linear; box-shadow: 0 0 12px rgba(212,168,67,.5); }
.mp-progress-thumb { position: absolute; top: 50%; transform: translate(-50%, -50%); width: 14px; height: 14px; border-radius: 50%; background: #fff; box-shadow: 0 0 8px rgba(212,168,67,.7); pointer-events: none; opacity: 0; transition: opacity .15s; }
.mp-progress-bar:hover .mp-progress-thumb { opacity: 1; }
.mp-time-row { display: flex; justify-content: space-between; margin-top: .25rem; }
.mp-time { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: rgba(255,255,255,.6); letter-spacing: .04em; }

.mp-controls-row { display: flex; align-items: center; justify-content: center; gap: .4rem; margin-top: .55rem; }
.mp-controls-row--sec { gap: .55rem; padding-top: .35rem; border-top: 1px dashed rgba(212,168,67,.15); margin-top: .65rem; }
.mp-ctrl { width: 44px; height: 44px; border-radius: 10px; background: rgba(0,0,0,.6); border: 1px solid rgba(212,168,67,.22); color: #d4a843; font-size: 1.05rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s; touch-action: manipulation; flex-shrink: 0; }
.mp-ctrl:hover, .mp-ctrl:active { background: rgba(212,168,67,.14); border-color: #d4a843; transform: translateY(-1px); }
.mp-ctrl.is-active { background: linear-gradient(135deg, rgba(212,168,67,.22), rgba(200,148,30,.14)); border-color: #d4a843; color: #fff; box-shadow: 0 0 14px rgba(212,168,67,.35); }
.mp-ctrl-main { width: 60px; height: 60px; font-size: 1.55rem; background: linear-gradient(135deg, #d4a843, #c8941e); color: #050505; border-color: #d4a843; box-shadow: 0 0 24px rgba(212,168,67,.45); font-weight: 900; }
.mp-ctrl-main:hover, .mp-ctrl-main:active { background: linear-gradient(135deg, #e2b756, #d4a843); transform: scale(1.05); }
.mp-ctrl-pill { width: auto; min-width: 56px; padding: 0 12px; font-family: 'JetBrains Mono', monospace; font-size: .72rem; font-weight: 800; letter-spacing: .06em; }
.mp-vol-ico { font-size: .9rem; color: rgba(255,255,255,.7); }
.mp-volume { flex: 1; height: 4px; -webkit-appearance: none; appearance: none; background: rgba(255,255,255,.15); border-radius: 2px; outline: none; cursor: pointer; }
.mp-volume::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 16px; height: 16px; border-radius: 50%; background: #d4a843; cursor: pointer; box-shadow: 0 0 8px rgba(212,168,67,.6); }
.mp-volume::-moz-range-thumb { width: 16px; height: 16px; border-radius: 50%; background: #d4a843; cursor: pointer; border: none; }

.mp-eq { padding: .85rem; margin-top: .6rem; background: rgba(0,0,0,.5); border-radius: 10px; border: 1px solid rgba(212,168,67,.18); }
.mp-eq-row { display: grid; grid-template-columns: 50px 1fr 56px; align-items: center; gap: .6rem; margin-bottom: .5rem; font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: rgba(255,255,255,.7); }
.mp-eq-row input[type="range"] { width: 100%; height: 4px; -webkit-appearance: none; appearance: none; background: rgba(255,255,255,.1); border-radius: 2px; }
.mp-eq-row input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 14px; height: 14px; border-radius: 50%; background: #d4a843; cursor: pointer; }
.mp-eq-row span:last-child { text-align: right; color: #d4a843; font-weight: 700; }
.mp-eq-presets { display: flex; gap: .35rem; flex-wrap: wrap; padding-top: .6rem; border-top: 1px dashed rgba(212,168,67,.15); }
.mp-eq-preset { padding: 6px 10px; font-family: 'JetBrains Mono', monospace; font-size: .66rem; font-weight: 800; letter-spacing: .08em; background: rgba(0,0,0,.5); color: #d4a843; border: 1px solid rgba(212,168,67,.25); border-radius: 6px; cursor: pointer; transition: all .15s; }
.mp-eq-preset:hover { background: rgba(212,168,67,.18); border-color: #d4a843; }
.mp-eq-preset[data-eq="brutal"] { color: #ff5555; border-color: rgba(255,85,85,.4); }

/* Acquire (upload + URL) */
.mp-acquire { padding: 1rem; margin-bottom: 1rem; }
.mp-acq-row { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; margin-top: .7rem; }
.mp-big-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: .9rem .6rem; background: linear-gradient(135deg, rgba(212,168,67,.16), rgba(200,148,30,.06)); border: 1px solid rgba(212,168,67,.32); border-radius: 12px; color: #fff; cursor: pointer; transition: all .2s; touch-action: manipulation; min-height: 86px; }
.mp-big-btn:hover, .mp-big-btn:active { transform: translateY(-2px); border-color: #d4a843; box-shadow: 0 8px 24px rgba(212,168,67,.18); background: linear-gradient(135deg, rgba(212,168,67,.24), rgba(200,148,30,.1)); }
.mp-big-ico { font-size: 1.6rem; }
.mp-big-lbl { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: .88rem; letter-spacing: .04em; }
.mp-big-sub { font-family: 'JetBrains Mono', monospace; font-size: .62rem; color: rgba(255,255,255,.55); }

.mp-url-row { display: flex; gap: .4rem; margin-top: .8rem; }
.mp-url-input { flex: 1; min-width: 0; padding: 12px 14px; background: rgba(0,0,0,.55); border: 1px solid rgba(212,168,67,.25); border-radius: 10px; color: #fff; font-family: 'JetBrains Mono', monospace; font-size: .78rem; outline: none; transition: border-color .15s; }
.mp-url-input:focus { border-color: #d4a843; box-shadow: 0 0 14px rgba(212,168,67,.18); }
.mp-url-btn { padding: 0 1.1rem; background: linear-gradient(135deg, #d4a843, #c8941e); color: #050505; border: none; border-radius: 10px; font-family: 'JetBrains Mono', monospace; font-weight: 900; font-size: .78rem; letter-spacing: .08em; cursor: pointer; touch-action: manipulation; box-shadow: 0 4px 14px rgba(212,168,67,.3); }
.mp-url-btn:hover, .mp-url-btn:active { transform: translateY(-1px); }
.mp-url-hint { margin-top: .55rem; font-family: 'JetBrains Mono', monospace; font-size: .65rem; color: rgba(255,255,255,.5); line-height: 1.5; }
.mp-url-hint a { color: #d4a843; text-decoration: none; }
.mp-url-hint code { color: #86efac; background: rgba(0,0,0,.4); padding: 1px 4px; border-radius: 3px; font-family: inherit; }

/* Library list */
.mp-lib { padding: 1rem; margin-bottom: 1rem; }
.mp-lib-search-row { display: flex; gap: .4rem; margin-top: .7rem; }
.mp-lib-search { flex: 1; padding: 9px 12px; background: rgba(0,0,0,.55); border: 1px solid rgba(212,168,67,.2); border-radius: 8px; color: #fff; font-size: .8rem; outline: none; }
.mp-lib-search:focus { border-color: #d4a843; }
.mp-lib-sort { padding: 9px 12px; background: rgba(0,0,0,.55); border: 1px solid rgba(212,168,67,.2); border-radius: 8px; color: #fff; font-family: 'JetBrains Mono', monospace; font-size: .72rem; outline: none; }
.mp-lib-list { margin-top: .8rem; display: flex; flex-direction: column; gap: .45rem; }
.mp-lib-row { display: grid; grid-template-columns: 36px 1fr auto; gap: .55rem; align-items: center; padding: .55rem .65rem; background: rgba(0,0,0,.45); border: 1px solid rgba(255,255,255,.06); border-radius: 9px; cursor: pointer; transition: all .15s; min-height: 56px; }
.mp-lib-row:hover { background: rgba(212,168,67,.08); border-color: rgba(212,168,67,.3); }
.mp-lib-row.is-current { background: linear-gradient(90deg, rgba(212,168,67,.18), rgba(212,168,67,.04)); border-color: #d4a843; box-shadow: 0 0 14px rgba(212,168,67,.18) inset; }
.mp-lib-row.is-alarm { border-left: 3px solid #fcd34d; }
.mp-lib-play { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, #d4a843, #c8941e); color: #050505; border: none; font-size: .9rem; cursor: pointer; display: flex; align-items: center; justify-content: center; font-weight: 900; flex-shrink: 0; touch-action: manipulation; box-shadow: 0 0 10px rgba(212,168,67,.35); }
.mp-lib-play:hover { transform: scale(1.08); }
.mp-lib-meta { min-width: 0; }
.mp-lib-title { font-family: 'JetBrains Mono', monospace; font-size: .82rem; font-weight: 700; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-lib-sub { font-family: 'JetBrains Mono', monospace; font-size: .62rem; color: rgba(255,255,255,.45); margin-top: 1px; }
.mp-lib-actions { display: flex; gap: .25rem; flex-shrink: 0; }
.mp-lib-act { width: 32px; height: 32px; border-radius: 7px; background: rgba(0,0,0,.6); border: 1px solid rgba(255,255,255,.08); color: rgba(255,255,255,.7); font-size: .85rem; cursor: pointer; display: flex; align-items: center; justify-content: center; touch-action: manipulation; }
.mp-lib-act:hover { color: #d4a843; border-color: rgba(212,168,67,.35); background: rgba(212,168,67,.08); }
.mp-lib-act.danger:hover { color: #ff6b6b; border-color: rgba(255,107,107,.35); background: rgba(255,107,107,.08); }
.mp-lib-act.alarm-on { color: #fcd34d; border-color: rgba(252,211,77,.45); background: rgba(252,211,77,.08); }
.mp-lib-empty { padding: 1.2rem; text-align: center; color: rgba(255,255,255,.5); }

/* Default alarm config */
.mp-alarm-cfg { padding: 1rem; }
.mp-alarm-row { display: grid; grid-template-columns: 1fr 1fr auto; gap: .4rem; align-items: end; margin-top: .7rem; }
.mp-alarm-lbl { grid-column: 1 / -1; font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: rgba(255,255,255,.6); letter-spacing: .04em; }
.mp-alarm-select { padding: 10px 12px; background: rgba(0,0,0,.55); border: 1px solid rgba(212,168,67,.25); border-radius: 8px; color: #fff; font-family: 'JetBrains Mono', monospace; font-size: .76rem; outline: none; grid-column: 1 / 3; }
.mp-alarm-test { padding: 10px 12px; background: rgba(212,168,67,.12); color: #d4a843; border: 1px solid rgba(212,168,67,.35); border-radius: 8px; font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: .72rem; cursor: pointer; }
.mp-alarm-test:hover { background: rgba(212,168,67,.22); }
.mp-alarm-hint { margin-top: .6rem; font-family: 'JetBrains Mono', monospace; font-size: .62rem; color: rgba(255,255,255,.45); }

/* Deadline alarm row (inside deadline sheet) */
#deadlineAlarmRow { margin-top: .55rem; align-items: end; }
#deadlineAlarmPreviewBtn { align-self: flex-end; height: 40px; }

/* === FULL-SCREEN ALARM OVERLAY === */
.alarm-overlay { position: fixed; inset: 0; z-index: 99999; display: flex; align-items: center; justify-content: center; padding: 2rem 1rem; }
.alarm-bg { position: absolute; inset: 0; background: radial-gradient(circle at 50% 30%, rgba(255,85,85,.28), rgba(5,7,11,.96) 70%); animation: alarmPulse 1.2s ease-in-out infinite alternate; }
@keyframes alarmPulse { from { background: radial-gradient(circle at 50% 30%, rgba(255,85,85,.18), rgba(5,7,11,.96) 70%); } to { background: radial-gradient(circle at 50% 30%, rgba(252,211,77,.32), rgba(5,7,11,.96) 70%); } }
.alarm-card { position: relative; max-width: 420px; width: 100%; padding: 2rem 1.4rem 1.6rem; background: linear-gradient(180deg, rgba(20,15,10,.85), rgba(5,7,11,.92)); border: 2px solid rgba(252,211,77,.4); border-radius: 22px; text-align: center; box-shadow: 0 30px 80px rgba(0,0,0,.7), 0 0 60px rgba(252,211,77,.18); animation: alarmCardIn .35s cubic-bezier(.34,1.56,.64,1); }
@keyframes alarmCardIn { from { transform: scale(.7); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.alarm-pulse { position: absolute; inset: -20px; border: 2px solid rgba(252,211,77,.45); border-radius: 26px; animation: alarmRing 1.5s ease-out infinite; pointer-events: none; }
@keyframes alarmRing { from { transform: scale(.95); opacity: 1; } to { transform: scale(1.15); opacity: 0; } }
.alarm-clock { font-family: 'JetBrains Mono', monospace; font-size: 2.4rem; font-weight: 900; color: #fcd34d; letter-spacing: .12em; text-shadow: 0 0 24px rgba(252,211,77,.5); margin-bottom: .35rem; }
.alarm-icon { font-size: 3.4rem; margin-bottom: .4rem; animation: alarmShake .55s ease-in-out infinite; display: inline-block; }
@keyframes alarmShake { 0%, 100% { transform: rotate(-12deg); } 50% { transform: rotate(12deg); } }
.alarm-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.5rem; font-weight: 800; color: #fff; margin-bottom: .35rem; padding: 0 .5rem; word-break: break-word; }
.alarm-sub { font-family: 'JetBrains Mono', monospace; font-size: .82rem; color: rgba(255,255,255,.7); margin-bottom: .8rem; padding: 0 .5rem; }
.alarm-track { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: rgba(252,211,77,.7); letter-spacing: .06em; margin-bottom: 1.2rem; padding: 6px 12px; background: rgba(0,0,0,.4); border-radius: 6px; display: inline-block; border: 1px dashed rgba(252,211,77,.3); }
.alarm-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .55rem; }
.alarm-btn { padding: 14px 12px; border-radius: 12px; font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: .9rem; cursor: pointer; border: none; touch-action: manipulation; transition: transform .15s; }
.alarm-btn:active { transform: scale(.96); }
.alarm-btn-snooze { background: rgba(255,255,255,.08); color: #fff; border: 1px solid rgba(255,255,255,.18); }
.alarm-btn-stop { background: linear-gradient(135deg, #ff5555, #cc3333); color: #fff; box-shadow: 0 6px 24px rgba(255,85,85,.4); animation: alarmStopGlow 1s ease-in-out infinite alternate; }
@keyframes alarmStopGlow { from { box-shadow: 0 6px 24px rgba(255,85,85,.4); } to { box-shadow: 0 6px 30px rgba(255,85,85,.7); } }

/* Calendar — make termini days POP harder */
.calendar-mini .cal-day { position: relative; }
.calendar-mini .cal-day.has-deadline { background: rgba(212,168,67,.1) !important; border: 1px solid rgba(212,168,67,.4) !important; }
.calendar-mini .cal-day.has-deadline .cal-day-num { color: #fcd34d !important; font-weight: 800 !important; text-shadow: 0 0 8px rgba(252,211,77,.4); }
.calendar-mini .cal-day.has-deadline.today { background: linear-gradient(135deg, rgba(252,211,77,.28), rgba(212,168,67,.1)) !important; border: 2px solid #fcd34d !important; box-shadow: 0 0 18px rgba(252,211,77,.35); }
.calendar-mini .cal-day-bell { position: absolute; top: 2px; right: 3px; font-size: .58rem; opacity: .95; filter: drop-shadow(0 0 4px rgba(252,211,77,.7)); }

/* Today's termini hero card on dashboard */
.today-termini-card { padding: 1rem; margin-bottom: 1rem; background: linear-gradient(135deg, rgba(252,211,77,.08), rgba(212,168,67,.04)); border: 1px solid rgba(252,211,77,.25); border-radius: 14px; }
.today-termini-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .65rem; }
.today-termini-title { font-family: 'JetBrains Mono', monospace; font-size: .82rem; font-weight: 800; color: #fcd34d; letter-spacing: .06em; }
.today-termini-count { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: rgba(255,255,255,.6); padding: 3px 9px; background: rgba(0,0,0,.4); border-radius: 6px; border: 1px solid rgba(252,211,77,.3); }
.today-termini-list { display: flex; flex-direction: column; gap: .4rem; }
.today-termin-row { display: grid; grid-template-columns: 4px auto 1fr auto; gap: .55rem; align-items: center; padding: .55rem .65rem; background: rgba(0,0,0,.45); border: 1px solid rgba(255,255,255,.06); border-radius: 8px; cursor: pointer; transition: all .15s; }
.today-termin-row:hover { background: rgba(252,211,77,.08); border-color: rgba(252,211,77,.3); }
.today-termin-bar { width: 4px; height: 32px; border-radius: 2px; background: #d4a843; }
.today-termin-time { font-family: 'JetBrains Mono', monospace; font-size: .82rem; font-weight: 800; color: #fff; min-width: 44px; }
.today-termin-title { font-family: 'JetBrains Mono', monospace; font-size: .76rem; color: rgba(255,255,255,.85); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.today-termin-bell { font-size: .85rem; opacity: .8; }
.today-termini-empty { padding: .7rem .5rem; text-align: center; font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: rgba(255,255,255,.45); }

/* ═══════════════════════════════════════════════════════════════════════
   LIQUID LUXE — премиум „скъп от бъдещето" тема
   Тъмно-топла палитра + gold accent + liquid glass + kinetic gold text.
   ═══════════════════════════════════════════════════════════════════════ */
[data-theme="liquid-luxe"] {
  --bg: #0A0908;
  --bg2: #15120F;
  --bg3: #1C1917;
  --bg4: #252220;
  --bg5: #2F2A26;
  --accent: #C9A765;
  --accent-glow: rgba(201, 167, 101, 0.30);
  --accent-soft: rgba(201, 167, 101, 0.12);
  --border: rgba(201, 167, 101, 0.10);
  --border-accent: rgba(201, 167, 101, 0.45);
  --text: #F5F0E6;
  --text2: #B5AB97;
  --text3: #6B6359;
  --danger: #C0392B;
  --success: #8FB369;
  --font: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
}

[data-theme="liquid-luxe"] body {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, #1C1917 0%, #15120F 40%, #0A0908 80%);
  font-feature-settings: 'cv11', 'ss01';
  -webkit-font-smoothing: antialiased;
}

/* ─── Buttons — премиум gold + liquid glass ─────────────────────────── */
[data-theme="liquid-luxe"] .btn-primary {
  background: linear-gradient(135deg, #E0C588 0%, #C9A765 48%, #A88247 100%);
  color: #1A1410;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 14px;
  font-weight: 700;
  letter-spacing: 0.005em;
  padding: 12px 22px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    inset 0 -1px 0 rgba(0, 0, 0, 0.18),
    0 8px 24px rgba(201, 167, 101, 0.32),
    0 0 0 1px rgba(201, 167, 101, 0.22);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.18);
  transition:
    transform 220ms cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 260ms ease;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
[data-theme="liquid-luxe"] .btn-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 32%, rgba(255, 255, 255, 0.5) 50%, transparent 68%);
  transform: translateX(-120%);
  transition: transform 900ms cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}
[data-theme="liquid-luxe"] .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    inset 0 -1px 0 rgba(0, 0, 0, 0.20),
    0 14px 36px rgba(201, 167, 101, 0.50),
    0 0 0 1px rgba(201, 167, 101, 0.45);
}
[data-theme="liquid-luxe"] .btn-primary:hover::before { transform: translateX(120%); }
[data-theme="liquid-luxe"] .btn-primary:active {
  transform: translateY(0) scale(0.97);
  opacity: 1;
}

[data-theme="liquid-luxe"] .btn-secondary {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(201, 167, 101, 0.24);
  color: #F5F0E6;
  border-radius: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
  padding: 11px 20px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 6px 20px rgba(0, 0, 0, 0.45);
  transition: all 280ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
[data-theme="liquid-luxe"] .btn-secondary:hover {
  border-color: rgba(201, 167, 101, 0.55);
  background: linear-gradient(135deg, rgba(201, 167, 101, 0.14), rgba(201, 167, 101, 0.04));
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 10px 28px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(201, 167, 101, 0.32);
}

/* ─── Cards — liquid glass с топъл подтон ───────────────────────────── */
[data-theme="liquid-luxe"] .hacker-block,
[data-theme="liquid-luxe"] .card-premium {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012));
  backdrop-filter: blur(28px) saturate(150%);
  -webkit-backdrop-filter: blur(28px) saturate(150%);
  border: 1px solid rgba(201, 167, 101, 0.12);
  border-radius: 22px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 14px 44px rgba(0, 0, 0, 0.55);
}

[data-theme="liquid-luxe"] .stat-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.012));
  border: 1px solid rgba(201, 167, 101, 0.10);
  border-radius: 16px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme="liquid-luxe"] .stat-num {
  background: linear-gradient(135deg, #F5E6C8 0%, #C9A765 55%, #8B6F3F 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 800;
  letter-spacing: -0.03em;
  filter: drop-shadow(0 0 18px rgba(201, 167, 101, 0.20));
}

/* ─── Terminal LED — златен пулс ─────────────────────────────────────── */
[data-theme="liquid-luxe"] .hk-led {
  background: radial-gradient(circle, #FFD89B 0%, #C9A765 55%, transparent 100%);
  box-shadow: 0 0 14px rgba(201, 167, 101, 0.65);
}

/* ─── Sheet — премиум glass ──────────────────────────────────────────── */
[data-theme="liquid-luxe"] .sheet {
  background: linear-gradient(180deg, rgba(28, 25, 23, 0.96), rgba(10, 9, 8, 0.99));
  backdrop-filter: blur(40px) saturate(160%);
  -webkit-backdrop-filter: blur(40px) saturate(160%);
  border-top: 1px solid rgba(201, 167, 101, 0.18);
  box-shadow: 0 -20px 60px rgba(0, 0, 0, 0.6);
}

@media (prefers-reduced-motion: reduce) {
  [data-theme="liquid-luxe"] .btn-primary::before { transition: none; transform: translateX(-120%); }
  [data-theme="liquid-luxe"] .btn-primary,
  [data-theme="liquid-luxe"] .btn-secondary { transition: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   LIQUID LUXE — bottom dock + FAB plus премиум
   ═══════════════════════════════════════════════════════════════════════ */
[data-theme="liquid-luxe"] .bottom-dock {
  background:
    radial-gradient(140px 70px at 50% 8%, rgba(201, 167, 101, 0.22) 0%, transparent 72%),
    linear-gradient(180deg, rgba(22, 19, 16, 0.90) 0%, rgba(8, 7, 6, 0.99) 100%);
  border-top: 1px solid rgba(201, 167, 101, 0.22);
  box-shadow:
    0 -1px 0 rgba(201, 167, 101, 0.10) inset,
    0 -34px 90px rgba(0, 0, 0, 0.6);
}
[data-theme="liquid-luxe"] .bottom-dock::before {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(201, 167, 101, 0.30) 18%,
    rgba(245, 230, 200, 0.14) 50%,
    rgba(201, 167, 101, 0.30) 82%,
    transparent 100%);
  opacity: 1;
}
[data-theme="liquid-luxe"] .bottom-dock::after {
  background: radial-gradient(circle,
    rgba(201, 167, 101, 0.22) 0%,
    rgba(201, 167, 101, 0.06) 32%,
    transparent 70%);
  opacity: 0.85;
}

/* FAB + централен бутон — премиум gold кръг с halo + breathing */
[data-theme="liquid-luxe"] .dock-btn.dock-center .dock-icon {
  position: relative;
  width: 60px !important;
  height: 60px !important;
  margin-top: -16px;
  border-radius: 50%;
  background: linear-gradient(135deg, #EBCD83 0%, #C9A765 48%, #8B6F3F 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.9rem !important;
  font-weight: 700;
  color: #1A1410;
  border: 1.5px solid rgba(255, 255, 255, 0.32);
  box-shadow:
    inset 0 1.5px 0 rgba(255, 255, 255, 0.55),
    inset 0 -2px 0 rgba(0, 0, 0, 0.20),
    0 10px 28px rgba(201, 167, 101, 0.55),
    0 0 0 4px rgba(201, 167, 101, 0.14),
    0 0 0 10px rgba(201, 167, 101, 0.05);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.30);
  animation: ll-fab-breath 3.2s ease-in-out infinite;
  transition: transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
[data-theme="liquid-luxe"] .dock-btn.dock-center:active .dock-icon {
  transform: scale(0.92);
}
[data-theme="liquid-luxe"] .dock-btn.dock-center .dock-label {
  display: none;
}
@keyframes ll-fab-breath {
  0%, 100% {
    box-shadow:
      inset 0 1.5px 0 rgba(255, 255, 255, 0.55),
      inset 0 -2px 0 rgba(0, 0, 0, 0.20),
      0 10px 28px rgba(201, 167, 101, 0.55),
      0 0 0 4px rgba(201, 167, 101, 0.14),
      0 0 0 10px rgba(201, 167, 101, 0.05);
  }
  50% {
    box-shadow:
      inset 0 1.5px 0 rgba(255, 255, 255, 0.65),
      inset 0 -2px 0 rgba(0, 0, 0, 0.20),
      0 14px 34px rgba(201, 167, 101, 0.70),
      0 0 0 7px rgba(201, 167, 101, 0.20),
      0 0 0 16px rgba(201, 167, 101, 0.07);
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-theme="liquid-luxe"] .dock-btn.dock-center .dock-icon { animation: none; }
}

/* Други dock бутони — gold active състояние */
[data-theme="liquid-luxe"] .dock-btn:not(.dock-center) .dock-icon {
  filter: grayscale(0.55) brightness(0.95);
  transition: filter 250ms ease;
}
[data-theme="liquid-luxe"] .dock-btn.active:not(.dock-center) .dock-icon {
  filter: grayscale(0) brightness(1.05);
  color: #C9A765 !important;
}
[data-theme="liquid-luxe"] .dock-btn.active:not(.dock-center) .dock-label {
  color: #C9A765 !important;
  font-weight: 700;
}
[data-theme="liquid-luxe"] .dock-btn.active:not(.dock-center)::before {
  background: rgba(201, 167, 101, 0.34) !important;
}
[data-theme="liquid-luxe"] .dock-btn.active:not(.dock-center)::after {
  background: radial-gradient(circle, rgba(201, 167, 101, 0.32), transparent 70%) !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   LIQUID LUXE — Round 2 polish: sheet, sections, settings, hk-header
   ═══════════════════════════════════════════════════════════════════════ */

/* Section title — gold gradient text */
[data-theme="liquid-luxe"] .section-title,
[data-theme="liquid-luxe"] .settings-group-title {
  background: linear-gradient(135deg, #F5E6C8 0%, #C9A765 60%, #8B6F3F 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 700;
  letter-spacing: 0.12em;
  filter: drop-shadow(0 0 12px rgba(201, 167, 101, 0.15));
}

/* hk-header (terminal prompt strip) — gold accents */
[data-theme="liquid-luxe"] .hk-header {
  border-bottom: 1px solid rgba(201, 167, 101, 0.14);
}
[data-theme="liquid-luxe"] .hk-prompt,
[data-theme="liquid-luxe"] .hk-cmd {
  color: #C9A765;
}
[data-theme="liquid-luxe"] .hk-dollar,
[data-theme="liquid-luxe"] .hk-colon {
  color: #B5AB97;
}
[data-theme="liquid-luxe"] .hk-path {
  color: #F5E6C8;
}
[data-theme="liquid-luxe"] .hk-k {
  color: #B5AB97;
  letter-spacing: 0.04em;
}
[data-theme="liquid-luxe"] .hk-v {
  color: #F5F0E6;
  font-weight: 600;
}
[data-theme="liquid-luxe"] .hk-v.hk-big {
  background: linear-gradient(135deg, #F5E6C8 0%, #C9A765 55%, #8B6F3F 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 0 18px rgba(201, 167, 101, 0.22));
}
[data-theme="liquid-luxe"] .hk-header-btn {
  background: linear-gradient(135deg, rgba(201, 167, 101, 0.18), rgba(201, 167, 101, 0.06));
  border: 1px solid rgba(201, 167, 101, 0.30);
  color: #F5E6C8;
  border-radius: 10px;
  padding: 4px 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: all 220ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
[data-theme="liquid-luxe"] .hk-header-btn:hover {
  background: linear-gradient(135deg, rgba(201, 167, 101, 0.28), rgba(201, 167, 101, 0.10));
  border-color: rgba(201, 167, 101, 0.50);
  transform: translateY(-1px);
}

/* hk-clock — gold gradient + soft glow (sets up kinetic feel) */
[data-theme="liquid-luxe"] .hk-clock {
  background: linear-gradient(135deg, #F5E6C8 0%, #C9A765 50%, #8B6F3F 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: none;
  filter: drop-shadow(0 0 22px rgba(201, 167, 101, 0.30));
  letter-spacing: -0.04em;
}
[data-theme="liquid-luxe"] .hk-blink {
  color: #C9A765;
}
[data-theme="liquid-luxe"] .hk-greeting {
  color: #C9A765;
  letter-spacing: 0.04em;
}

/* link-btn — gold link */
[data-theme="liquid-luxe"] .link-btn {
  color: #C9A765;
  transition: color 200ms ease;
}
[data-theme="liquid-luxe"] .link-btn:hover { color: #E8C97A; }

/* Bottom sheet — premium glass */
[data-theme="liquid-luxe"] .sheet {
  background: linear-gradient(180deg, rgba(28, 25, 23, 0.96), rgba(10, 9, 8, 0.99));
  backdrop-filter: blur(40px) saturate(160%);
  -webkit-backdrop-filter: blur(40px) saturate(160%);
  border-top: 1px solid rgba(201, 167, 101, 0.22);
  box-shadow: 0 -24px 70px rgba(0, 0, 0, 0.7);
  border-radius: 24px 24px 0 0;
}
[data-theme="liquid-luxe"] .sheet-handle {
  background: linear-gradient(90deg, transparent, rgba(201, 167, 101, 0.55), transparent);
  height: 4px;
  border-radius: 4px;
}
[data-theme="liquid-luxe"] .sheet-title {
  background: linear-gradient(135deg, #F5E6C8, #C9A765);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 700;
  letter-spacing: -0.01em;
}
[data-theme="liquid-luxe"] .sheet-backdrop {
  background: radial-gradient(ellipse at center, rgba(10, 9, 8, 0.78), rgba(0, 0, 0, 0.92));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Settings items — premium row */
[data-theme="liquid-luxe"] .settings-item {
  border-bottom: 1px solid rgba(201, 167, 101, 0.10);
  padding: 0.8rem 0;
  transition: background 200ms ease;
}
[data-theme="liquid-luxe"] .settings-item:hover {
  background: linear-gradient(90deg, rgba(201, 167, 101, 0.06), transparent);
}
[data-theme="liquid-luxe"] .settings-value {
  color: #C9A765;
  font-weight: 600;
}
[data-theme="liquid-luxe"] .settings-note {
  color: #8B7F6A;
  font-style: italic;
}

/* Danger button — refined */
[data-theme="liquid-luxe"] .danger-btn {
  background: linear-gradient(135deg, rgba(192, 57, 43, 0.16), rgba(192, 57, 43, 0.06));
  border: 1px solid rgba(192, 57, 43, 0.32);
  color: #E8867A;
  border-radius: 14px;
  transition: all 220ms ease;
}
[data-theme="liquid-luxe"] .danger-btn:hover {
  background: linear-gradient(135deg, rgba(192, 57, 43, 0.28), rgba(192, 57, 43, 0.12));
  border-color: rgba(192, 57, 43, 0.55);
}

/* hk-cell + hk-cal-nav — fine accents */
[data-theme="liquid-luxe"] .hk-cell {
  border: 1px solid rgba(201, 167, 101, 0.08);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0.008));
  border-radius: 12px;
}

/* ═══════════════════════════════════════════════════════════════════════
   LIQUID LUXE — FAB plus absolutely centered + lifted (notch стил)
   ═══════════════════════════════════════════════════════════════════════ */
[data-theme="liquid-luxe"] .bottom-dock {
  overflow: visible;
}

/* FAB plus излиза от flex flow → останалите 5 бутона flex-ват равно
   → + плава absolute точно в геометричния center на dock-а */
[data-theme="liquid-luxe"] .bottom-dock--6 .dock-btn.dock-center,
[data-theme="liquid-luxe"] .dock-btn.dock-center {
  position: absolute !important;
  left: 50% !important;
  top: -18px !important;
  transform: translateX(-50%) !important;
  width: 72px !important;
  min-width: 72px !important;
  height: auto !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
  z-index: 12;
  pointer-events: auto;
}

/* iконата вече не нуждае от negative margin-top — целият бутон е повдигнат */
[data-theme="liquid-luxe"] .dock-btn.dock-center .dock-icon {
  margin-top: 0 !important;
  width: 64px !important;
  height: 64px !important;
  font-size: 2rem !important;
}

/* Скриваме label под плюса (плюсът е достатъчно изразителен) */
[data-theme="liquid-luxe"] .dock-btn.dock-center .dock-label {
  display: none !important;
}

/* dock-а получава suptle "notch" — лек gradient зад FAB-а за визуална връзка */
[data-theme="liquid-luxe"] .bottom-dock::after {
  background: radial-gradient(circle at center,
    rgba(201, 167, 101, 0.28) 0%,
    rgba(201, 167, 101, 0.08) 30%,
    transparent 65%);
  filter: blur(14px);
  width: 120px;
  height: 60px;
  inset: -16px auto auto 50%;
  transform: translateX(-50%);
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════════════════════
   FAB plus — УНИВЕРСАЛЕН ЦЕНТЪР (всички теми)
   С 6 бутона flexbox-ът поставя плюса на pos 3 = 42% (наляво от center).
   Изваждаме го от flow → absolute точно в 50% + повдигнат над dock-а.
   Останалите 5 бутона flex-ват равно → красива симетрия.
   ═══════════════════════════════════════════════════════════════════════ */
.bottom-dock { overflow: visible; }

.dock-btn.dock-center {
  position: absolute !important;
  left: 50% !important;
  top: -14px !important;
  transform: translateX(-50%) !important;
  width: 72px !important;
  min-width: 72px !important;
  height: auto !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
  z-index: 12 !important;
  pointer-events: auto;
}
.dock-btn.dock-center:active {
  transform: translateX(-50%) scale(0.94) !important;
}
.dock-btn.dock-center .dock-icon {
  margin-top: 0 !important;
}
.dock-btn.dock-center .dock-label {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   REVERT — iPhone-style flat tab bar (6 равни ботона, без notch)
   Šefe: 'плюса къде отиде — направи айфонски стил на ботоните.'
   Връщам всички dock-center exceptions → плюсът е равен с другите.
   ═══════════════════════════════════════════════════════════════════════ */
.dock-btn.dock-center {
  position: static !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  flex: 1 1 0 !important;
  z-index: auto !important;
  padding: 6px 4px !important;
}
.dock-btn.dock-center:active {
  transform: translateY(1px) scale(0.95) !important;
}
.dock-btn.dock-center .dock-icon {
  position: static !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1.5rem !important;
  font-weight: 500 !important;
  color: var(--accent) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  animation: none !important;
  text-shadow: none !important;
}
.dock-btn.dock-center .dock-label {
  display: block !important;
  font-size: 0.56rem !important;
  letter-spacing: 0.04em;
  margin-top: 2px;
  color: var(--text2);
}

/* Liquid Luxe — subtle gold tint за иконата + (но БЕЗ кръг, БЕЗ notch) */
[data-theme="liquid-luxe"] .dock-btn.dock-center .dock-icon {
  color: #C9A765 !important;
  text-shadow: 0 0 8px rgba(201, 167, 101, 0.45);
}
[data-theme="liquid-luxe"] .dock-btn.dock-center.active .dock-icon,
[data-theme="liquid-luxe"] .dock-btn.dock-center:hover .dock-icon {
  color: #E8C97A !important;
  text-shadow: 0 0 12px rgba(232, 201, 122, 0.65);
}

/* премахвам и notch-glow от bottom-dock::after (вече не нужен) */
[data-theme="liquid-luxe"] .bottom-dock::after {
  background: radial-gradient(circle,
    rgba(201, 167, 101, 0.18) 0%,
    rgba(201, 167, 101, 0.05) 30%,
    transparent 70%);
  filter: blur(18px);
  width: auto;
  height: 54px;
  inset: auto 10% 16px;
  transform: none;
  opacity: 0.85;
}

/* ═══════════════════════════════════════════════════════════════════════
   FAB plus → плаващ bottom-right (iPhone/Telegram стил)
   Šefe: 'истри този плюс и сложи нов на айфонски стил'
   Изваждаме dock-center от dock-а → 5 равни ботона в dock-а.
   Плюсът става плаващ кръгъл FAB над dock-а, дясно. Theme-aware accent.
   ═══════════════════════════════════════════════════════════════════════ */
.dock-btn.dock-center {
  position: fixed !important;
  bottom: calc(76px + env(safe-area-inset-bottom, 0px) + 14px) !important;
  right: 16px !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  flex: 0 0 auto !important;
  padding: 0 !important;
  z-index: 200 !important;
  pointer-events: auto !important;
  border-radius: 50% !important;
  background: none !important;
}

.dock-btn.dock-center::before,
.dock-btn.dock-center::after {
  display: none !important;
}

.dock-btn.dock-center .dock-icon {
  width: 58px !important;
  height: 58px !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle at 32% 28%, rgba(255,255,255,0.45) 0%, transparent 55%),
    linear-gradient(135deg,
      color-mix(in srgb, var(--accent) 75%, white) 0%,
      var(--accent) 50%,
      color-mix(in srgb, var(--accent) 60%, black) 100%) !important;
  color: color-mix(in srgb, var(--bg) 80%, black) !important;
  border: 1.5px solid rgba(255,255,255,0.30) !important;
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,0.55),
    inset 0 -2px 0 rgba(0,0,0,0.20),
    0 8px 24px var(--accent-glow, rgba(0,0,0,0.5)),
    0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent) !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.25);
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.95rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
  padding: 0 !important;
  animation: fab-float-breath 3.4s ease-in-out infinite;
  transition: transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.dock-btn.dock-center:active .dock-icon {
  transform: scale(0.92);
}
.dock-btn.dock-center:hover .dock-icon {
  transform: translateY(-2px);
}

.dock-btn.dock-center .dock-label {
  display: none !important;
}

@keyframes fab-float-breath {
  0%, 100% {
    box-shadow:
      inset 0 1.5px 0 rgba(255,255,255,0.55),
      inset 0 -2px 0 rgba(0,0,0,0.20),
      0 8px 24px var(--accent-glow, rgba(0,0,0,0.5)),
      0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
  }
  50% {
    box-shadow:
      inset 0 1.5px 0 rgba(255,255,255,0.65),
      inset 0 -2px 0 rgba(0,0,0,0.20),
      0 14px 34px var(--accent-glow, rgba(0,0,0,0.7)),
      0 0 0 8px color-mix(in srgb, var(--accent) 22%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .dock-btn.dock-center .dock-icon { animation: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   FIX за плаващ FAB — .bottom-dock има transform + contain → става
   containing block за fixed-positioned child-ове. Премахваме (минимална
   perf цена), за да може dock-center FAB-ът да plava относно viewport-а.
   ═══════════════════════════════════════════════════════════════════════ */
.bottom-dock {
  transform: none !important;
  -webkit-transform: none !important;
  contain: none !important;
  will-change: auto !important;
  backface-visibility: visible !important;
  -webkit-backface-visibility: visible !important;
}


/* ═══════════════════════════════════════════════════════════════════════
   FINAL FAB — clean gold премиум, видим, bottom-right
   (Override на debug pink + слабия предишен styling)
   ═══════════════════════════════════════════════════════════════════════ */
.dock-btn.dock-center {
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  outline: none !important;
  width: 60px !important;
  height: 60px !important;
  min-width: 60px !important;
  position: fixed !important;
  bottom: calc(78px + env(safe-area-inset-bottom, 0px) + 16px) !important;
  right: 18px !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  flex: 0 0 auto !important;
  z-index: 250 !important;
  padding: 0 !important;
  border-radius: 50% !important;
}
.dock-btn.dock-center .dock-icon {
  background: linear-gradient(135deg, #EBCD83 0%, #C9A765 50%, #8B6F3F 100%) !important;
  border: 1.5px solid rgba(255,255,255,0.32) !important;
  color: #1A1410 !important;
  font-size: 1.95rem !important;
  font-weight: 700 !important;
  width: 60px !important;
  height: 60px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,0.55),
    inset 0 -2px 0 rgba(0,0,0,0.20),
    0 10px 28px rgba(201,167,101,0.55),
    0 0 0 5px rgba(201,167,101,0.14) !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.25) !important;
  margin: 0 !important;
  padding: 0 !important;
  outline: none !important;
  animation: fab-float-breath 3.4s ease-in-out infinite;
}
.dock-btn.dock-center:active .dock-icon {
  transform: scale(0.92);
}
.dock-btn.dock-center .dock-label {
  display: none !important;
}

/* FAB позициониран по-вляво (cloud sync icon е bottom-right) + max z-index */
.dock-btn.dock-center {
  right: 88px !important;
  z-index: 999 !important;
}

/* FINAL FINAL — FAB на МАКС z-index, BR, доминира над cloud sync icon */
.dock-btn.dock-center {
  right: 18px !important;
  bottom: calc(78px + env(safe-area-inset-bottom, 0px) + 18px) !important;
  z-index: 2147483647 !important;
  width: 64px !important;
  height: 64px !important;
  min-width: 64px !important;
}
.dock-btn.dock-center .dock-icon {
  width: 64px !important;
  height: 64px !important;
  z-index: 2147483647 !important;
}

/* FAB долу-ВЛЯВО — cloud sync icon заема BR, изместваме FAB-а */
.dock-btn.dock-center {
  right: auto !important;
  left: 18px !important;
  bottom: calc(78px + env(safe-area-inset-bottom, 0px) + 18px) !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   FAB plus → top-right в header (до palette + bell).
   Малък gold icon, в реда, не плава, не пречи никъде.
   ═══════════════════════════════════════════════════════════════════════ */
.dock-btn.dock-center {
  position: fixed !important;
  top: max(12px, env(safe-area-inset-top, 12px)) !important;
  right: 96px !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  z-index: 2147483647 !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: none !important;
}
.dock-btn.dock-center .dock-icon {
  width: 36px !important;
  height: 36px !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #EBCD83 0%, #C9A765 50%, #8B6F3F 100%) !important;
  color: #1A1410 !important;
  border: 1.5px solid rgba(255,255,255,0.28) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.50),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 4px 14px rgba(201,167,101,0.45),
    0 0 0 3px rgba(201,167,101,0.10) !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.20) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
  animation: none !important;
  transition: transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
.dock-btn.dock-center:active .dock-icon {
  transform: scale(0.90) !important;
}
.dock-btn.dock-center:hover .dock-icon {
  transform: translateY(-1px) !important;
}

/* Премахвам containing-block creator-ите от ancestors → fixed работи спрямо viewport */
#app {
  transform: none !important;
  -webkit-transform: none !important;
  contain: none !important;
  will-change: auto !important;
}
.bottom-dock {
  backdrop-filter: blur(28px) saturate(1.16) !important; /* пазим glass效ekt */
}

/* FINAL — премахвам backdrop-filter от .bottom-dock (тя също създаваше containing block)
   Dock-ът остава с radial gradients + border = достатъчно стилен без blur. */
.bottom-dock {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
