/* ========================================
   MARK PETERS — PORTFOLIO
======================================== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#060606;
  --surface:#0c0c0c;
  --card:#111;
  --line:#181818;
  --text:#c8c6c0;
  --dim:#8a8a8a;
  --faint:#2a2a2a;
  --white:#f0eeea;
  --glow:rgba(168,152,112,.07);
  --accent:#a89870;
  --heading:'Questrial',sans-serif;
  --sans:'DM Sans',system-ui,sans-serif;
}

html{scroll-behavior:smooth}
html::before,html::after{
  content:'';position:fixed;top:4.2rem;bottom:0;width:1px;pointer-events:none;z-index:97;
  background:linear-gradient(to bottom,transparent 0%,rgba(168,152,112,.13) 8%,rgba(168,152,112,.13) 85%,transparent 100%);
}
html::before{left:1.5rem}
html::after{right:1.5rem}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}
code,pre,kbd,samp{font-family:var(--sans)}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:auto}

body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:998;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.025;
}

::selection{background:rgba(200,180,140,.2);color:var(--white)}


/* ---- NAV ---- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.3rem 2.5rem;
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);
  pointer-events:none;
  border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s;
}
.nav>*{pointer-events:auto}
.nav a{transition:color .25s}
.nav a:hover{color:var(--white)}
.nav-r{display:flex;gap:2rem}
.nav.scrolled{
  background:rgba(6,6,6,.88);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-color:var(--line);
}


/* ---- HERO ---- */
.hero{
  position:relative;
  width:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:6rem 2rem 3rem;
  overflow:hidden;
}

.hero-bg{
  position:absolute;top:0;left:0;right:0;height:50%;
  overflow:hidden;pointer-events:none;z-index:0;
  filter:blur(4px);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 15%, #000 60%, transparent 100%);
  mask-image:linear-gradient(to bottom, transparent 0%, #000 15%, #000 60%, transparent 100%);
}
.hero-bg iframe{
  position:absolute;top:50%;left:50%;border:0;
  transform:translate(-50%,-50%);
  width:300vw;height:300vh;
  min-width:100%;min-height:100%;
  object-fit:cover;
}

.hero-overlay{
  position:absolute;top:0;left:0;right:0;height:50%;
  z-index:1;pointer-events:none;
  background:rgba(6,6,6,.68);
}

.hero h1{
  font-family:var(--heading);font-weight:300;
  font-size:clamp(4rem,11vw,10rem);
  line-height:1;letter-spacing:.06em;
  color:var(--white);
  text-shadow:0 0 60px var(--glow),0 0 120px var(--glow);
  animation:nameGlow 4s ease-in-out infinite alternate;
  position:relative;z-index:3;
}
@keyframes nameGlow{
  0%{text-shadow:0 0 40px rgba(168,152,112,.04),0 0 80px rgba(168,152,112,.02)}
  100%{text-shadow:0 0 60px rgba(168,152,112,.11),0 0 120px rgba(168,152,112,.06),0 0 200px rgba(168,152,112,.03)}
}

.hero-line{width:32px;height:1px;background:var(--dim);margin:.8rem auto;opacity:.5;position:relative;z-index:3}
.hero-sub{font-size:.85rem;letter-spacing:.25em;text-transform:uppercase;color:var(--text);font-weight:300;position:relative;z-index:3}


/* about info inside hero */
.hero-about{
  position:relative;z-index:3;
  display:flex;align-items:center;gap:2rem;
  margin-top:2.5rem;
  max-width:640px;
}
.hero-about .avatar{
  width:150px;height:150px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid var(--line);
  flex-shrink:0;
  opacity:.9;
}
.hero-about-content{text-align:left}
.hero-about-content p{
  color:var(--dim);font-size:.78rem;line-height:1.7;margin-bottom:.8rem;
}

.about-row{
  display:flex;gap:1.5rem;
  font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);
}
.about-row strong{display:block;color:var(--white);font-weight:500;margin-top:.15rem;font-size:.75rem}

/* software logos under bio */
.hero-tools{
  display:flex;align-items:center;
  gap:.6rem;
  margin-top:.8rem;
}
.hero-tools img{
  width:24px;height:24px;
  object-fit:contain;
  opacity:.7;
  transition:opacity .3s;
}
.hero-tools img:hover{opacity:1}

.pulse{
  display:inline-block;width:5px;height:5px;border-radius:50%;
  background:#5c9e78;margin-right:.25rem;vertical-align:middle;
  animation:pulseAnim 2.4s ease-in-out infinite;
}
@keyframes pulseAnim{
  0%,100%{box-shadow:0 0 0 0 rgba(92,158,120,.5)}
  50%{box-shadow:0 0 0 5px rgba(92,158,120,0)}
}


/* ---- DIVIDER ---- */
.div{display:flex;align-items:center;gap:1.2rem;padding:3.5rem 2.5rem 2rem}
.div::before,.div::after{content:'';flex:1;height:1px;background:var(--line)}
.div span{font-size:1.2rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(168,152,112,.55);white-space:nowrap}


/* ---- WORK ---- */
.work{padding:0 4rem 4rem}
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}

.card{
  position:relative;overflow:hidden;cursor:pointer;background:var(--surface);
  border-radius:3px;
  opacity:0;transform:translateY(18px);
  transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1),box-shadow .5s ease;
  will-change:transform,opacity;
  box-shadow:0 0 0px 0px rgba(200,180,140,0);
}
.card.v{opacity:1;transform:translateY(0)}
.card:hover{}

.card::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:3;
  border:1px solid transparent;transition:border-color .35s,box-shadow .35s;border-radius:3px;
}
.card:hover::after{border-color:rgba(168,152,112,.22)}

.card-img{
  width:100%;aspect-ratio:16/9;background:var(--card);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;transition:transform .35s cubic-bezier(.22,1,.36,1);transform:translateZ(0);backface-visibility:hidden;
}
.card:hover .card-img,.card-focused .card-img{transform:scale(1.08) translateZ(0)}
.card-focused .card-ov{opacity:1 !important;transform:translateY(0) !important}
.card-img span{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.card-img img{width:100%;height:100%;object-fit:cover}

.card-img-yt{position:relative;background:#000}
.card-img-yt video{
  position:absolute;top:0;left:0;
  width:100%;height:100%;object-fit:contain;
}

.card-ov{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  padding:1.8rem 1.5rem 1.3rem;
  background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.65) 50%,transparent 100%);
  opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s;
}
.card:hover .card-ov{opacity:1;transform:translateY(0)}
.card-ov h3{font-family:var(--heading);font-size:1.6rem;font-weight:400;color:var(--white);letter-spacing:.02em}
.card-ov p{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-top:.2rem}


/* ---- MODAL ---- */
.ov{
  position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.94);
  display:none;align-items:flex-start;justify-content:center;
  overflow-y:auto;padding:2.5rem 1.2rem;backdrop-filter:blur(6px);
}
.ov.open{display:flex}
.mod{width:100%;max-width:780px;background:var(--bg);border:1px solid var(--line);animation:up .28s ease}
@keyframes up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.mod-x{
  float:right;margin:.9rem;width:28px;height:28px;
  border:1px solid var(--line);background:none;color:var(--dim);
  font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.mod-x:hover{border-color:rgba(168,152,112,.4);color:var(--accent)}
.mod-hero{width:100%;aspect-ratio:16/9;background:var(--card);display:flex;align-items:center;justify-content:center;overflow:hidden}
.mod-hero span{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.mod-bd{padding:2rem}
.mod-bd .cat{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);opacity:.6;margin-bottom:.4rem}
.mod-bd h2{font-family:var(--heading);font-size:1.8rem;font-weight:400;color:var(--white);margin-bottom:.8rem;letter-spacing:.02em}
.mod-bd p{color:var(--text);line-height:1.8;font-size:.92rem;margin-bottom:.8rem}
.specs{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin:1.2rem 0}
.sp{border:1px solid var(--line);padding:.85rem;transition:border-color .2s}
.sp:hover{border-color:rgba(168,152,112,.18)}
.sp-l{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:.25rem}
.sp-v{font-family:var(--heading);font-size:1.05rem;color:var(--white)}
.mod-gal{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:1.2rem}
.mod-gal div{
  aspect-ratio:4/3;background:var(--card);display:flex;align-items:center;justify-content:center;
  font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);
  overflow:hidden;
}
.mod-gal div img{width:100%;height:100%;object-fit:cover}

.tools-row{display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem}
.tool-icon{width:28px;height:28px;object-fit:contain;opacity:.9;transition:opacity .2s}
.tool-icon:hover{opacity:1}


/* ---- CONTACT ---- */
.contact{padding:3.5rem 2.5rem 2rem;text-align:center;border-top:1px solid var(--line)}
.contact h2{font-family:var(--heading);font-weight:300;font-size:clamp(1.8rem,3.5vw,2.4rem);color:var(--white);margin-bottom:1.3rem;letter-spacing:.02em}
.contact-email{
  font-family:var(--heading);font-size:clamp(1rem,1.8vw,1.2rem);
  color:var(--text);border-bottom:1px solid var(--line);padding-bottom:.1rem;transition:all .3s;
}
.contact-email:hover{color:var(--accent);border-color:rgba(168,152,112,.4)}
.contact-links{
  margin-top:1.3rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.7rem;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);
}
.contact-links a{
  border:1px solid var(--line);padding:.55rem 1.1rem;
  display:inline-flex;align-items:center;gap:.45rem;
  transition:color .25s,border-color .25s,background .25s;
}
.contact-links a:hover{
  color:var(--accent);border-color:rgba(168,152,112,.35);background:rgba(168,152,112,.05);
}


/* ---- LANG TOGGLE ---- */
.nav a[href*="cv"] { display: none !important; }
.lang-toggle { display: flex; align-items: center; gap: .3rem; }
.lang-sep { color: var(--line); margin: 0 .3rem; }
.lang-btn { background: none; border: none; outline: none; box-shadow: none; -webkit-appearance: none; appearance: none; color: var(--dim); cursor: pointer; font-family: var(--sans); font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; padding: 0; transition: color .25s; }
.lang-btn:hover { color: var(--text); }
.lang-btn.active { color: var(--white); }


/* ---- REEL ---- */
.reel-section { padding: 0 4rem 3.5rem; }
.reel-inner { width: 100%; }
.reel-label { font-size: 1.2rem; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); opacity: .7; margin-bottom: 1rem; text-align: center; }
@media(max-width:960px) { .reel-section { padding: 0 2rem 3rem; } }
@media(max-width:680px) { .reel-section { padding: 0 2rem 2rem; } }



/* ---- SOUND TOGGLE ---- */

#vol-wrap{
  position:fixed;bottom:2.35rem;right:2.5rem;z-index:200;
  display:flex;align-items:center;gap:.75rem;
  background:rgba(12,12,12,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(168,152,112,.2);
  border-radius:999px;
  padding:0 1.1rem 0 1.4rem;
  height:52px;
  box-shadow:0 4px 24px rgba(0,0,0,.5);
  opacity:1;pointer-events:auto;
  transition:opacity .25s;
}
#vol-wrap.has-sound{ opacity:1; pointer-events:auto; }
#sound-toggle{
  position:relative;bottom:auto;right:auto;
  background:none;border:none;box-shadow:none;
  width:32px;height:32px;
  flex-shrink:0;
  color:var(--accent);
  padding:0;
  display:flex;align-items:center;justify-content:center;
}
#sound-toggle:hover{ color:var(--white); background:none; border:none; box-shadow:none; }
#vol-hint{
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.7);white-space:nowrap;flex-shrink:0;
  border:1px solid rgba(168,152,112,.38);border-radius:4px;padding:.2rem .5rem;
  font-weight:500;
}
#vol-slider{
  -webkit-appearance:none;appearance:none;
  width:90px;height:2px;
  background:rgba(168,152,112,.18);border-radius:999px;
  outline:none;cursor:pointer;
}
#vol-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:14px;height:14px;border-radius:50%;
  background:var(--accent);cursor:pointer;
  box-shadow:0 0 6px rgba(168,152,112,.35);
}
#vol-slider::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;
  background:var(--accent);cursor:pointer;border:none;
}

/* ---- PLYR THEME ---- */
:root {
  --plyr-color-main: #a89870;
  --plyr-video-background: #000;
  --plyr-control-icon-size: 18px;
  --plyr-control-spacing: 10px;
  --plyr-range-fill-background: #a89870;
  --plyr-range-thumb-background: #a89870;
  --plyr-video-controls-background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.75));
  --plyr-badge-background: #000;
  --plyr-tooltip-background: #000;
  --plyr-tooltip-color: #f0eeea;
}
.plyr,.plyr__video-wrapper,.plyr video{
  width:100% !important;
  aspect-ratio:16/9 !important;
  background:#000;
}
.project-hero video:not(.plyr__video-wrapper video){
  visibility:hidden;
}
.plyr--video video{
  visibility:visible;
}

/* ---- GRAY BOX (text group card) ---- */
.gb {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 5px;
  padding: 1.5rem 1.8rem;
  margin-bottom: 1rem;
}

/* Project page description paragraphs */
.project-content > p:not(:empty):not(.credits-line) {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 5px;
  padding: 1.5rem 1.8rem;
  margin-bottom: 1.5rem;
}

/* ---- FOOTER ---- */
footer{padding:1.5rem 2.5rem;text-align:center;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--dim)}


/* ---- REVEAL ---- */
.r{opacity:0;transform:translateY(14px);transition:all .55s cubic-bezier(.22,1,.36,1)}
.r.v{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}

::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line)}


/* ---- RESPONSIVE ---- */

/* Large screens — constrain layout */
@media(min-width:1600px){
  .work{padding:0 6rem 6rem}
  .work-grid{max-width:1400px;margin:0 auto}
  .reel-section{padding:0 6rem 3.5rem}
  .reel-inner{max-width:1400px;margin:0 auto}
  .contact{padding:4rem 6rem 3rem}
  .div{padding:4rem 6rem 2.5rem}
}

/* Tablet */
@media(max-width:960px){
  .work{padding:0 2rem 4rem}
  .work-grid{gap:1rem}
  .hero h1{font-size:clamp(3rem,10vw,7rem)}
  .mod{max-width:95vw}
}

/* ── Image fade-in ── */
img { opacity: 0; transition: opacity .55s ease; }
img.loaded { opacity: 1; }

@media(max-width:680px){
  .nav{padding:1rem 1.2rem;font-size:.65rem}
  .nav-r{gap:1.1rem}
  .hero{padding:5rem 1.2rem 2rem}
  .hero h1{font-size:clamp(2.5rem,12vw,4rem)}
  .hero-sub{font-size:.7rem}
  .hero-tools img{width:18px;height:18px}
  .hero-about{flex-direction:column;gap:1rem;text-align:center}
  .hero-about .avatar{width:120px;height:120px}
  .hero-about-content{text-align:center}
  .hero-tools{justify-content:center}
  .about-row{flex-wrap:wrap;justify-content:center;gap:.8rem}
  .div span{font-size:.65rem}
  .work{padding:0 2rem 3rem}
  .work-grid{grid-template-columns:1fr;gap:1rem}
  .reel-section{padding:0 2rem 2rem}
  .contact,.div{padding-left:1.2rem;padding-right:1.2rem}
  .specs{grid-template-columns:1fr}
  .mod-gal{grid-template-columns:1fr}
  .mod-bd{padding:1.2rem}
  .tool-icon{width:22px;height:22px}
  html::before,html::after{display:none}
  /* hero-simple on mobile */
  .hero-simple{padding:5rem 1.2rem 2rem}
  .hero-simple h1{font-size:clamp(2.8rem,13vw,5rem);letter-spacing:.06em}
  .hero-simple p{letter-spacing:.08em}
  #cubeCanvas{display:none}
}

/* ---- SCROLL HINT ---- */
.scroll-hint {
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  padding:.8rem 0 .4rem;
  color:var(--dim);pointer-events:none;
}
.scroll-hint span{font-size:.55rem;letter-spacing:.22em;text-transform:uppercase}
.scroll-hint svg{animation:scrollBounce 1.8s ease-in-out infinite}
@keyframes scrollBounce{
  0%,100%{transform:translateY(0);opacity:.3}
  50%{transform:translateY(5px);opacity:.7}
}

/* ---- NAV ACTIVE ---- */
.nav-active{color:var(--white) !important}

/* ---- CARD ENHANCEMENTS ---- */
.card-num{
  position:absolute;top:.85rem;left:.95rem;
  font-size:.58rem;letter-spacing:.16em;
  color:rgba(200,180,140,.3);
  z-index:4;pointer-events:none;
}
.card-view{
  display:inline-block;margin-top:.65rem;
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--dim);text-decoration:none;
  opacity:0;transform:translateX(-5px);
  transition:opacity .3s .05s,transform .3s .05s;
}
.card:hover .card-view,.card-focused .card-view{opacity:1;transform:translateX(0)}

/* ---- REEL SUB ---- */
.reel-sub{
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--dim);text-align:center;
  margin-top:-.3rem;margin-bottom:1.2rem;opacity:.55;
}

.content-panel .project-header h1 { white-space: nowrap; font-size: clamp(0.8rem, 2.4vw, 4rem); }
.content-panel .project-header { padding-bottom: 0.75rem; }
.content-panel .project-hero { margin-top: 0.75rem; }

.specs-bar { display: flex; align-items: center; gap: 1.5rem; margin: 1.5rem 0; }
.specs-bar .specs { flex: 1; margin: 0; }
.specs-bar .tools-row { margin: 0; flex-shrink: 0; }

.content-panel .section-title { margin-top: 3.5rem; }

@media(max-width: 680px) {
  .specs-bar { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
  .specs-bar .specs { width: 100%; }
  .content-panel .section-title { margin-top: 2rem; }
  .content-panel .project-header h1 { font-size: clamp(1.5rem, 7vw, 4rem); }
  .sf-track { min-height: unset; }
  .sf-section { display: none; }
  .sf-section + .div, .div:has(+ .sf-section) { display: none; }
  .sf-above { padding-left: 1rem !important; padding-right: 1rem !important; max-width: 100vw; }
  .sf-name-row { padding-left: 1rem !important; padding-right: 1rem !important; max-width: 100vw; }
  .sf-info { padding-left: 1rem !important; padding-right: 1rem !important; max-width: 100vw; }
  .footer-links { flex-wrap: wrap; gap: .5rem; justify-content: center; padding: 0 1rem; }
}

/* ---- FOOTER ---- */
footer{padding:2rem 2.5rem;text-align:center}

/* ---- CONTENT PANEL (light card on dark bg) ---- */
.content-panel {
  background: #0d0d0d;
  border-radius: 8px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.8), 0 4px 16px rgba(0,0,0,0.5), 0 0 0 1px rgba(168,152,112,0.14);
}
.project-content.content-panel { margin: 5.5rem auto 2rem; padding: 2.5rem 3rem 3rem; }
.project-content.content-panel .project-header { padding-top: 0; }
.impr-section.content-panel { padding: 2.5rem 2.5rem 3rem; margin-top: 5.5rem; margin-bottom: 2rem; min-height: auto; }
.about-section.content-panel { padding: 2.5rem 2.5rem 3rem !important; margin-top: 5.5rem; margin-bottom: 2rem; }
.page-section.content-panel { padding: 2.5rem 2.5rem 3rem; margin-top: 5.5rem; margin-bottom: 2rem; }
.contact-page.content-panel { margin: 5.5rem auto 2rem; padding: 2.5rem 2.5rem 3rem; min-height: auto; }
.footer-links{
  display:flex;justify-content:center;gap:2rem;margin-bottom:1.1rem;
}
.footer-social{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--dim);transition:color .25s;
}
.footer-social:hover{color:var(--accent)}
.footer-copy{
  font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--dim);opacity:.55;
}

/* ---- SKETCHFAB CAROUSEL ---- */
.sf-section{padding:0 0 4rem}
.sf-carousel{
  position:relative;display:flex;align-items:center;gap:1rem;
  padding:0 2rem;max-width:1100px;margin:0 auto;
}
.sf-track{
  flex:1;position:relative;
  aspect-ratio:16/9;min-height:300px;
  border-radius:4px;overflow:hidden;
  background:#0d0d0d;
  border:1px solid var(--line);
}
.sf-slide{
  position:absolute;inset:0;
  opacity:0;transition:opacity .4s ease;
  pointer-events:none;
}
.sf-slide.active{opacity:1;pointer-events:auto}
.sf-slide iframe{width:100%;height:100%;border:none;display:block}
.sf-btn{
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line);background:transparent;
  color:var(--dim);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:color .2s,border-color .2s;
}
.sf-btn:hover{color:var(--white);border-color:var(--accent)}
.sf-info{
  display:flex;justify-content:flex-end;
  padding:.7rem 3.5rem 0;max-width:1100px;margin:0 auto;
}
.sf-name-row{
  display:flex;justify-content:center;align-items:center;
  gap:.9rem;padding:.35rem 3.5rem 0;
  max-width:1100px;margin:0 auto;
}
.sf-above{
  display:flex;justify-content:flex-end;
  padding:0 calc(2rem + 34px + 1rem) .4rem;
  max-width:1100px;margin:0 auto;
}
.sf-title{font-size:.84rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(200,180,140,.75);font-family:var(--sans)}
.sf-counter{font-size:.6rem;letter-spacing:.15em;color:var(--faint)}
.sf-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}
.sf-dot{
  width:4px;height:4px;border-radius:50%;
  background:var(--faint);border:1px solid var(--line);
  cursor:pointer;transition:background .3s,transform .3s;padding:0;
}
.sf-dot.active{background:var(--accent);transform:scale(1.5)}

.sf-stats{
  display:flex;align-items:center;gap:.9rem;
}
.sf-stat{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.825rem;letter-spacing:.12em;
  color:var(--dim);
}
.sf-stat svg{opacity:.5;stroke:var(--dim)}
@keyframes sfGlimmer{}
.sf-stat-loading{font-size:.7rem;color:var(--faint);letter-spacing:.1em}