/* DESIGN SYSTEM */
:root {
  --font-sans: 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-serif: 'Syne', sans-serif;
  --font-body: 'Inter', sans-serif;
  --color-bg: #070707;
  --color-bg-rgb: 7, 7, 7;
  --color-fg: #ffffff;
  --color-fg-muted: rgba(255, 255, 255, 0.35);
  --color-fg-subtle: rgba(255, 255, 255, 0.15);
  --color-accent: #ffffff;
  --color-accent-dim: rgba(255, 255, 255, 0.6);
  --sidebar-width: 480px;
  --ease-custom: cubic-bezier(0.16, 1, 0.3, 1);
  --transition-slow: 0.8s var(--ease-custom);
  --transition-medium: 0.5s var(--ease-custom);
  --transition-fast: 0.25s var(--ease-custom);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { background-color: var(--color-bg); color: var(--color-fg); font-family: var(--font-body); font-size: 16px; line-height: 1.5; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow: hidden; height: 100%; }
body { height: 100%; overflow: hidden; user-select: none; -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }
button { background: none; border: none; color: inherit; font: inherit; cursor: pointer; outline: none; }

/* BACKGROUND VIDEOS */
.background-videos-container { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: -2; overflow: hidden; background-color: #000; }
.bg-video { position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; object-fit: cover; transform: translate(-50%, -50%) scale(1.03); opacity: 0; transition: opacity 0.7s var(--ease-custom), transform 1s var(--ease-custom); pointer-events: none; }
.bg-video.active { opacity: 1; transform: translate(-50%, -50%) scale(1); }
.ambient-gradient-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; background: radial-gradient(circle at 70% 30%, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.15) 100%); }

/* LAYOUT */
.layout-shell { position: relative; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: space-between; padding: 4vw; z-index: 2; }

/* HEADER */
.app-header { position: relative; width: 100%; z-index: 10; }
.header-inner { display: flex; justify-content: space-between; align-items: center; }
.logo { display: inline-flex; align-items: center; cursor: pointer; }
.logo-text { font-family: var(--font-sans); font-size: 1.8rem; font-weight: 400; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-fg); display: inline-block; line-height: 1; transition: letter-spacing var(--transition-medium); }
.logo:hover .logo-text { letter-spacing: 0.1em; }

.btn-toggle-sidebar, .btn-credits-toggle, .btn-close-sidebar, .btn-close-overlay { display: flex; align-items: center; gap: 1.2rem; font-family: var(--font-sans); font-size: 0.9rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; padding: 0.8rem 0; position: relative; color: var(--color-fg); transition: color var(--transition-fast); }
.btn-arrow { display: flex; align-items: center; justify-content: center; position: relative; width: 41px; overflow: hidden; }
.btn-arrow svg { transform: translateX(0); transition: transform var(--transition-medium); }
.btn-toggle-sidebar:hover .btn-arrow svg, .btn-credits-toggle:hover .btn-arrow svg { transform: translateX(5px); }
.btn-toggle-sidebar:hover .arrow-line, .btn-credits-toggle:hover .arrow-line { transform: scaleX(1.3); transform-origin: left; }
.btn-toggle-sidebar:hover, .btn-credits-toggle:hover { color: rgba(255, 255, 255, 0.7); }
.btn-arrow.reversed { transform: rotate(180deg); }
.btn-close-sidebar:hover .btn-arrow svg, .btn-close-overlay:hover .btn-arrow svg { transform: translateX(5px); }

/* MAIN PROJECTS LIST */
.main-content { flex-grow: 1; display: flex; flex-direction: column; justify-content: center; margin-top: 4vh; margin-bottom: 0; }
.projects-list-wrapper { max-width: 900px; }
.projects-list { list-style: none; display: flex; flex-direction: column; align-items: flex-start; gap: 0.35rem; }
.project-item { position: relative; transform: translate3d(0, 0, 0); transition: transform var(--transition-medium); }
.project-link { display: inline-block; padding: 0.2rem 0; }
.project-title { font-family: var(--font-sans); font-size: clamp(1.8rem, 2.6vw, 2.5rem); font-weight: 300; line-height: 1.15; letter-spacing: -0.01em; color: rgba(255, 255, 255, 0.75); display: inline-block; transition: color 0.25s var(--ease-custom), transform 0.25s var(--ease-custom); transform-origin: left center; text-shadow: 0 2px 18px rgba(0, 0, 0, 0.45); will-change: transform; }
.projects-list:hover .project-title { color: rgba(255, 255, 255, 0.5); }
.project-item:hover .project-title { color: var(--color-fg); transform: translate3d(4px, 0, 0); font-weight: 400; }

/* FOOTER */
.app-footer { width: 100%; display: flex; justify-content: center; align-items: baseline; font-family: var(--font-sans); font-size: 0.85rem; letter-spacing: 0.05em; color: rgba(255, 255, 255, 0.8); line-height: 1; z-index: 10; position: relative; text-shadow: 0 1px 12px rgba(0, 0, 0, 0.5); }
.footer-contact { display: inline-flex; align-items: baseline; gap: 0.7rem; flex-wrap: nowrap; white-space: nowrap; line-height: 1; }
.footer-sep { opacity: 0.4; }
.footer-link { position: relative; padding-bottom: 2px; color: rgba(255, 255, 255, 0.85); transition: color var(--transition-fast); }
.footer-link::after { content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; background-color: var(--color-fg-subtle); transform: scaleX(0); transform-origin: right; transition: transform var(--transition-medium); }
.footer-link:hover { color: var(--color-fg); }
.footer-link:hover::after { transform: scaleX(1); transform-origin: left; }
.footer-address { position: absolute; left: 0; bottom: 0; text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.15em; opacity: 0.85; line-height: 1; }
@media (max-width: 768px) {
  .app-footer { flex-direction: column; align-items: center; gap: 0.8rem; text-align: center; }
  .footer-contact { flex-wrap: wrap; white-space: normal; justify-content: center; }
  .footer-address { position: static; }
}

/* SIDEBAR */
.sidebar { position: fixed; top: 0; right: 0; width: 100%; height: 100%; z-index: 100; pointer-events: none; visibility: hidden; }
.sidebar.active { pointer-events: auto; visibility: visible; }
.sidebar-backdrop { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.4); opacity: 0; transition: opacity var(--transition-slow); }
.sidebar.active .sidebar-backdrop { opacity: 1; }
.sidebar-drawer { position: absolute; top: 0; right: 0; width: 100%; max-width: var(--sidebar-width); height: 100%; background-color: var(--color-bg); padding: 4vw; overflow-y: auto; transform: translate3d(100%, 0, 0); transition: transform var(--transition-slow); display: flex; flex-direction: column; gap: 3rem; }
.sidebar.active .sidebar-drawer { transform: translate3d(0, 0, 0); }
.sidebar-header { display: flex; justify-content: flex-end; }
.sidebar-body { display: flex; flex-direction: column; gap: 3rem; }
.about-description { display: flex; flex-direction: column; gap: 1.2rem; font-family: var(--font-body); font-size: 0.95rem; line-height: 1.6; color: rgba(255, 255, 255, 0.7); }
.about-description a { color: var(--color-fg); border-bottom: 1px solid rgba(255, 255, 255, 0.3); transition: border-color var(--transition-fast); }
.about-description a:hover { border-color: var(--color-fg); }
.crew-section { display: flex; flex-direction: column; gap: 1.8rem; }
.crew-title { font-family: var(--font-sans); font-size: 0.85rem; letter-spacing: 0.2em; color: var(--color-fg-muted); font-weight: 600; text-transform: uppercase; border-bottom: 1px solid rgba(255, 255, 255, 0.08); padding-bottom: 0.8rem; }
.crew-list { list-style: none; display: flex; flex-direction: column; gap: 1.2rem; }
.crew-item { display: flex; flex-direction: column; gap: 0.2rem; transition: transform var(--transition-fast); }
.crew-name { font-family: var(--font-sans); font-size: 1.15rem; font-weight: 400; color: var(--color-fg); transition: color var(--transition-fast), transform var(--transition-fast); }
.crew-role { font-family: var(--font-sans); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-fg-muted); }
.crew-item:hover .crew-name { transform: translate3d(4px, 0, 0); color: rgba(255, 255, 255, 0.8); }

/* ARCHIVE BUTTON in sidebar */
.archive-section { margin-top: 1.4rem; }
.btn-archive-open { display: inline-flex; align-items: center; gap: 1.2rem; font-family: var(--font-sans); font-size: 0.9rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; color: var(--color-fg); padding: 0.8rem 0; transition: color var(--transition-fast); }
.btn-archive-open:hover { color: var(--color-fg-muted); }
.btn-archive-open:hover .btn-arrow svg { transform: translateX(5px); }

/* ARCHIVE OVERLAY (full-screen page) */
.archive-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 150; background-color: var(--color-bg); opacity: 0; visibility: hidden; transform: translate3d(0, 12px, 0); transition: opacity var(--transition-slow), transform var(--transition-slow), visibility var(--transition-slow); overflow-y: auto; }
.archive-overlay.active { opacity: 1; visibility: visible; transform: translate3d(0, 0, 0); }
.archive-overlay-inner { width: 100%; min-height: 100%; padding: 4vw; display: flex; flex-direction: column; gap: 4vh; }
.archive-overlay-nav { display: flex; align-items: center; gap: 3rem; }
.archive-overlay-title { font-family: var(--font-sans); font-size: clamp(1.6rem, 2.4vw, 2.2rem); font-weight: 300; letter-spacing: -0.01em; color: var(--color-fg); }
.btn-close-archive { display: flex; align-items: center; gap: 1.2rem; font-family: var(--font-sans); font-size: 0.9rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; color: var(--color-fg); transition: color var(--transition-fast); }
.btn-close-archive:hover { color: var(--color-fg-muted); }
.btn-close-archive:hover .btn-arrow svg { transform: translateX(5px); }
.archive-overlay-body { max-width: 1100px; width: 100%; }
.archive-page-list { list-style: none; display: flex; flex-direction: column; gap: 0.1rem; }
.archive-page-item { border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.archive-page-item:first-child { border-top: 1px solid rgba(255, 255, 255, 0.08); }
.archive-page-link { display: grid; grid-template-columns: 2fr 2fr auto; align-items: baseline; gap: 2rem; padding: 1.4rem 0.4rem; color: var(--color-fg); transition: color var(--transition-fast), padding-left var(--transition-fast), background-color var(--transition-fast); }
.archive-page-link:hover { padding-left: 1rem; background-color: rgba(255, 255, 255, 0.02); }
.archive-page-title { font-family: var(--font-sans); font-size: clamp(1.2rem, 1.8vw, 1.6rem); font-weight: 300; letter-spacing: -0.01em; color: var(--color-fg); }
.archive-page-meta { font-family: var(--font-sans); font-size: 0.85rem; letter-spacing: 0.04em; color: var(--color-fg-muted); }
.archive-page-view { font-family: var(--font-sans); font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-fg-muted); transition: color var(--transition-fast), transform var(--transition-fast); }
.archive-page-link:hover .archive-page-view { color: var(--color-fg); transform: translate3d(-4px, 0, 0); }
.archive-empty { font-family: var(--font-sans); font-size: 0.95rem; color: var(--color-fg-muted); padding: 3rem 0; letter-spacing: 0.02em; }
@media (max-width: 768px) {
  .archive-page-link { grid-template-columns: 1fr auto; gap: 0.6rem; }
  .archive-page-meta { grid-column: 1 / span 2; font-size: 0.78rem; }
}

/* FULLSCREEN PROJECT OVERLAY */
.project-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 200; background-color: #000; opacity: 0; visibility: hidden; transition: opacity 0.3s var(--ease-custom), visibility 0.3s var(--ease-custom); }
.project-overlay.active { opacity: 1; visibility: visible; transform: scale(1); }
.overlay-nav { position: absolute; top: 0; left: 0; width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 4vw; z-index: 220; pointer-events: none; }
.overlay-nav a, .overlay-nav button { pointer-events: auto; }
.overlay-player-container { width: 100%; height: 100%; position: relative; overflow: hidden; }
.fullscreen-video { width: 100%; height: 100%; object-fit: cover; }
.overlay-project-title { position: absolute; bottom: 10vw; left: 4vw; margin: 0; font-family: var(--font-sans); font-size: clamp(2rem, 5vw, 5.5rem); font-weight: 300; line-height: 1; letter-spacing: -0.02em; color: var(--color-fg); z-index: 230; opacity: 0; transform: translate3d(0, 12px, 0); transition: opacity var(--transition-medium), transform var(--transition-medium); pointer-events: none; text-shadow: 0 2px 30px rgba(0, 0, 0, 0.5); max-width: 80vw; }
.project-overlay.active .overlay-project-title { opacity: 1; transform: translate3d(0, 0, 0); }
.minimal-controls { position: absolute; bottom: 4vw; left: 4vw; display: flex; gap: 1.5rem; z-index: 230; opacity: 0; transform: translate3d(0, 10px, 0); transition: opacity var(--transition-medium), transform var(--transition-medium); }
.project-overlay.active .minimal-controls { opacity: 1; transform: translate3d(0, 0, 0); }
.control-btn { width: 48px; height: 48px; border-radius: 50%; background: rgba(10, 10, 10, 0.45); border: 1px solid rgba(255, 255, 255, 0.15); display: flex; align-items: center; justify-content: center; transition: background-color var(--transition-fast); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.control-btn:hover { background: rgba(255, 255, 255, 0.15); }
.icon-play.hide, .icon-pause.hide, .icon-muted.hide, .icon-unmuted.hide, .icon-fs-enter.hide, .icon-fs-exit.hide { display: none; }
.credits-panel { position: absolute; top: 0; right: 0; width: 100%; max-width: var(--sidebar-width); height: 100%; background-color: rgba(7, 7, 7, 0.95); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); padding: 8vh 4vw 4vh; transform: translate3d(100%, 0, 0); transition: transform var(--transition-slow); z-index: 210; overflow-y: auto; }
.project-overlay.credits-active .credits-panel { transform: translate3d(0, 0, 0); }
.credits-panel-inner { display: flex; flex-direction: column; gap: 3rem; }
.credits-title { font-family: var(--font-sans); font-size: 3rem; font-weight: 300; line-height: 1.1; letter-spacing: -0.02em; color: var(--color-fg); }
.credits-grid { display: flex; flex-direction: column; gap: 1.8rem; }
.credits-group { display: flex; flex-direction: column; gap: 0.4rem; }
.group-label { font-family: var(--font-sans); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-fg-muted); }
.group-value { font-family: var(--font-sans); font-size: 1.05rem; font-weight: 400; color: var(--color-fg); }

/* MOBILE TWEAKS */
@media (max-width: 768px) {
  .project-title { font-size: 1.8rem; }
  .credits-title { font-size: 2.2rem; }
  .minimal-controls { bottom: 6vw; left: 6vw; }
  .overlay-project-title { bottom: 18vw; left: 6vw; font-size: 2.4rem; }
  .overlay-nav { padding: 6vw; }
}
@media (hover: none) {
  .project-item:hover .project-title { transform: none; font-weight: 300; }
}


/* CREW LINKS (clickable names) */
.crew-link { background: none; border: none; padding: 0; margin: 0; text-align: left; cursor: pointer; display: flex; flex-direction: column; gap: 0.2rem; color: inherit; font: inherit; transition: transform var(--transition-fast); }
.crew-link:hover .crew-name { transform: translate3d(4px, 0, 0); color: rgba(255, 255, 255, 0.8); }
.crew-list .crew-item { transition: none; }

/* COLORIST OVERLAY (filtered home-style view) */
.colorist-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 160; background-color: var(--color-bg); opacity: 0; visibility: hidden; transform: translate3d(0, 12px, 0); transition: opacity var(--transition-slow), transform var(--transition-slow), visibility var(--transition-slow); overflow-y: auto; }
.colorist-overlay.active { opacity: 1; visibility: visible; transform: translate3d(0, 0, 0); }
.colorist-overlay-inner { width: 100%; min-height: 100%; padding: 4vw; display: flex; flex-direction: column; }
.colorist-overlay-nav { display: flex; align-items: center; }
.btn-close-colorist { display: flex; align-items: center; gap: 1.2rem; font-family: var(--font-sans); font-size: 0.9rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; color: var(--color-fg); transition: color var(--transition-fast); }
.btn-close-colorist:hover { color: var(--color-fg-muted); }
.btn-close-colorist:hover .btn-arrow svg { transform: translateX(5px); }
.colorist-overlay-body { flex-grow: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.2rem; text-align: center; padding: 6vh 0; }
.colorist-overlay-eyebrow { font-family: var(--font-sans); font-size: 0.75rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--color-fg-muted); }
.colorist-overlay-name { font-family: var(--font-sans); font-size: clamp(2rem, 3.5vw, 3.2rem); font-weight: 300; letter-spacing: -0.02em; color: var(--color-fg); margin-bottom: 2vh; }
.colorist-projects-list { list-style: none; display: flex; flex-direction: column; align-items: center; gap: 0.45rem; }
.colorist-project-item { position: relative; }
.colorist-project-link { display: inline-block; padding: 0.2rem 0; }
.colorist-project-title { font-family: var(--font-sans); font-size: clamp(1.8rem, 2.6vw, 2.5rem); font-weight: 300; line-height: 1.15; letter-spacing: -0.01em; color: var(--color-fg-muted); display: inline-block; transition: color var(--transition-slow), transform var(--transition-slow); }
.colorist-projects-list:hover .colorist-project-title { color: var(--color-fg-subtle); }
.colorist-project-item:hover .colorist-project-title { color: var(--color-fg); font-weight: 400; }
@media (max-width: 768px) {
  .colorist-project-title { font-size: 1.8rem; }
  .colorist-overlay-name { font-size: 2.2rem; }
}


/* Background video inside the colorist overlay (shown on hover) */
.colorist-bg-video { position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; object-fit: cover; transform: translate(-50%, -50%) scale(1.03); opacity: 0; transition: opacity 0.6s var(--ease-custom); pointer-events: none; filter: saturate(0.9) brightness(0.55); z-index: 0; }
.colorist-bg-video.active { opacity: 1; }
.colorist-overlay-inner { position: relative; z-index: 1; }


/* Brand mark next to ELEVATE wordmark */

.logo:hover .logo-mark { transform: rotate(-8deg) scale(1.05); }


/* Big brand logo at the top of the WE ARE sidebar — cinematic dusk grade */
.sidebar-logo-block { position: relative; display: flex; justify-content: center; align-items: center; padding: 1rem 0; isolation: isolate; min-height: 14rem; }
.sidebar-logo-block::before {
  /* Cinematic dusk aura: deep blue -> indigo -> warm rose */
  content: '';
  position: absolute;
  width: 17rem;
  height: 17rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(80, 120, 220, 0.22) 0%, transparent 65%);
  z-index: -1;
  animation: sidebar-logo-grade 14s ease-in-out infinite;
  filter: blur(8px);
}
.sidebar-logo {
  width: 11rem;
  height: 11rem;
  display: block;
  filter: drop-shadow(0 6px 28px rgba(0, 0, 0, 0.55));
  animation: sidebar-logo-breathe 7s var(--ease-custom) infinite, sidebar-logo-hue 14s ease-in-out infinite;
  transition: transform 1.2s var(--ease-custom);
  cursor: pointer;
}
.sidebar-logo:hover { transform: rotate(360deg); }
@keyframes sidebar-logo-breathe {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.025); }
}
@keyframes sidebar-logo-grade {
  /* Cinematic dusk: deep blue -> indigo/purple -> warm rose */
  0%, 100% { background: radial-gradient(circle, rgba(80, 120, 220, 0.22) 0%, transparent 65%); }
  33%      { background: radial-gradient(circle, rgba(150, 110, 220, 0.22) 0%, transparent 65%); }
  66%      { background: radial-gradient(circle, rgba(230, 130, 160, 0.22) 0%, transparent 65%); }
}
@keyframes sidebar-logo-hue {
  0%, 100% { filter: drop-shadow(0 6px 28px rgba(80, 120, 220, 0.3)); }
  33%      { filter: drop-shadow(0 6px 28px rgba(150, 110, 220, 0.3)); }
  66%      { filter: drop-shadow(0 6px 28px rgba(230, 130, 160, 0.3)); }
}


/* When the project overlay is fullscreen, hide all UI chrome so only the video shows.
   Minimal controls reappear when the user moves the mouse. */
.project-overlay.is-fullscreen .overlay-nav,
.project-overlay.is-fullscreen .overlay-project-title,
.project-overlay.is-fullscreen .credits-panel,
.project-overlay.is-fullscreen .minimal-controls {
  opacity: 0 !important;
  pointer-events: none;
  visibility: hidden;
  transition: opacity 0.6s var(--ease-custom), visibility 0.6s var(--ease-custom);
}
.project-overlay.is-fullscreen.show-controls .overlay-nav,
.project-overlay.is-fullscreen.show-controls .overlay-project-title,
.project-overlay.is-fullscreen.show-controls .minimal-controls {
  opacity: 1 !important;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.25s var(--ease-custom), visibility 0.25s var(--ease-custom);
}
.project-overlay.is-fullscreen .minimal-controls {
  opacity: 0;
  transition: opacity 0.4s var(--ease-custom);
}
.project-overlay.is-fullscreen.show-controls .overlay-nav,
.project-overlay.is-fullscreen.show-controls .overlay-project-title,
.project-overlay.is-fullscreen.show-controls .minimal-controls {
  opacity: 1;
  pointer-events: auto;
}


/* Volume slider next to the player controls */
.control-volume {
  -webkit-appearance: none;
  appearance: none;
  width: 90px;
  height: 3px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 999px;
  outline: none;
  cursor: pointer;
  margin-left: 0.5rem;
  align-self: center;
  transition: background-color var(--transition-fast);
  padding: 0;
  vertical-align: middle;
}
.control-volume:hover { background: rgba(255, 255, 255, 0.4); }
.control-volume::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  border: none;
  cursor: pointer;
  transition: transform var(--transition-fast);
}
.control-volume:hover::-webkit-slider-thumb { transform: scale(1.2); }
.control-volume::-moz-range-thumb {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  border: none;
  cursor: pointer;
}

/* On mobile/touch, hide the volume slider (use mute button instead) */
@media (max-width: 768px), (hover: none) {
  .control-volume { display: none; }
  .minimal-controls { gap: 1rem; }
  .control-btn { width: 42px; height: 42px; }
}


/* Touch preview state: subtle highlight + small "tap again" hint */
@media (hover: none), (max-width: 768px) {
  .project-item.is-previewed .project-title {
    color: var(--color-fg);
    font-weight: 400;
    transform: translate3d(4px, 0, 0);
  }
  .project-item.is-previewed .project-title::after {
    content: ' ↳';
    font-size: 0.6em;
    opacity: 0.5;
    margin-left: 0.3em;
  }
}


/* Smooth native fullscreen: lock the video element to fill the screen cleanly */
.fullscreen-video:fullscreen,
.fullscreen-video:-webkit-full-screen {
  width: 100vw !important;
  height: 100vh !important;
  object-fit: contain;
  background: #000;
}
