@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');

:root{
  --teal:#1cc6c2;
  --teal-dark:#0c8b88;
  --brand-rgb:28,198,194;
  --brand-btn-start:#7ae9e5;
  --brand-btn-mid:#2ec6c2;
  --brand-btn-end:#16a7a4;
  --brand-btn-shadow:22,167,164;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
  --text:#eef3fb;
  --muted:#a5b2c7;
  --pill:#38e08c;
  --amber:#ffb25a;
  --coral:#ff7a59;
  --sky:#6ec4ff;
  --panel1:#1a2230;
  --panel2:#101720;
  --ink:#081013;
  --frame:#0c1219;
  --bgA:#070d13;
  --bgB:#0d141c;
  --outline:rgba(255,255,255,.08);
  --glass:rgba(16,21,30,.72);
  --star-density:165;
  --star-speed:45s;
  --star-size:1.2;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Space Grotesk", system-ui, -apple-system, sans-serif;
  background:
    radial-gradient(circle at 12% 10%, rgba(92,225,222,.18), transparent 38%),
    radial-gradient(circle at 88% 12%, rgba(255,160,90,.16), transparent 40%),
    linear-gradient(150deg, var(--bgA), var(--bgB));
  color:var(--text);
}

a{color:inherit}

.primary-button,
.ghost-button{
  padding:10px 18px;
  border-radius:10px;
  font-weight:700;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.primary-button{
  background:linear-gradient(135deg, var(--brand-btn-start), var(--brand-btn-mid) 55%, var(--brand-btn-end));
  color:var(--on-brand);
  border:1px solid rgba(2,12,14,.8);
  box-shadow:0 12px 30px rgba(var(--brand-btn-shadow),.28), inset 0 0 0 1px rgba(255,255,255,.18);
  transition:transform .18s ease, box-shadow .18s ease;
}

.primary-button:hover{
  transform:translateY(1px);
  box-shadow:0 16px 36px rgba(var(--brand-btn-shadow),.34), inset 0 0 0 1px rgba(255,255,255,.2);
}

html[data-brand-theme="pulsarr"]{
  --teal:#1cc6c2;
  --teal-dark:#0c8b88;
  --brand-rgb:28,198,194;
  --brand-btn-start:#7ae9e5;
  --brand-btn-mid:#2ec6c2;
  --brand-btn-end:#16a7a4;
  --brand-btn-shadow:22,167,164;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="launcharr"]{
  --teal:#6d7a86;
  --teal-dark:#414c57;
  --brand-rgb:109,122,134;
  --brand-btn-start:#a5b1bb;
  --brand-btn-mid:#6d7a86;
  --brand-btn-end:#4b5864;
  --brand-btn-shadow:75,88,100;
  --on-brand:#ffffff;
  --on-brand-muted:rgba(255,255,255,.78);
  --on-brand-icon-filter:brightness(0) saturate(100%) invert(1);
}

html[data-brand-theme="custom"]{
  --teal:#1cc6c2;
  --teal-dark:#0c8b88;
  --brand-rgb:28,198,194;
  --brand-btn-start:#7ae9e5;
  --brand-btn-mid:#2ec6c2;
  --brand-btn-end:#16a7a4;
  --brand-btn-shadow:22,167,164;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="rocketship"]{
  --teal:#b8c1ca;
  --teal-dark:#7b848d;
  --brand-rgb:184,193,202;
  --brand-btn-start:#e2e7ec;
  --brand-btn-mid:#b8c1ca;
  --brand-btn-end:#959fa9;
  --brand-btn-shadow:128,139,150;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="plex"]{
  --teal:#f9ad2f;
  --teal-dark:#a96f05;
  --brand-rgb:249,173,47;
  --brand-btn-start:#ffd57f;
  --brand-btn-mid:#f9ad2f;
  --brand-btn-end:#d88e09;
  --brand-btn-shadow:216,142,9;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="radarr"]{
  --teal:#f4c542;
  --teal-dark:#a98518;
  --brand-rgb:244,197,66;
  --brand-btn-start:#ffe39b;
  --brand-btn-mid:#f4c542;
  --brand-btn-end:#cc9f23;
  --brand-btn-shadow:204,159,35;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="sonarr"]{
  --teal:#3d7bfd;
  --teal-dark:#1f54bc;
  --brand-rgb:61,123,253;
  --brand-btn-start:#8eb1ff;
  --brand-btn-mid:#3d7bfd;
  --brand-btn-end:#255fd5;
  --brand-btn-shadow:37,95,213;
  --on-brand:#ffffff;
  --on-brand-muted:rgba(255,255,255,.78);
  --on-brand-icon-filter:brightness(0) saturate(100%) invert(1);
}

html[data-brand-theme="lidarr"]{
  --teal:#53b86a;
  --teal-dark:#2f7f41;
  --brand-rgb:83,184,106;
  --brand-btn-start:#99ddaa;
  --brand-btn-mid:#53b86a;
  --brand-btn-end:#3a9250;
  --brand-btn-shadow:58,146,80;
  --on-brand:#081013;
  --on-brand-muted:rgba(8,16,19,.72);
  --on-brand-icon-filter:brightness(0) saturate(100%);
}

html[data-brand-theme="readarr"]{
  --teal:#d84a4a;
  --teal-dark:#912b2b;
  --brand-rgb:216,74,74;
  --brand-btn-start:#f29b9b;
  --brand-btn-mid:#d84a4a;
  --brand-btn-end:#b23636;
  --brand-btn-shadow:178,54,54;
  --on-brand:#ffffff;
  --on-brand-muted:rgba(255,255,255,.78);
  --on-brand-icon-filter:brightness(0) saturate(100%) invert(1);
}

.ghost-button{
  border:1px solid var(--outline);
  background:rgba(5,9,14,.35);
  color:var(--text);
}

/* Home / landing */
.bg-grid{
  position:fixed;
  inset:0;
  background-image:
    radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(120deg, rgba(255,255,255,.05), transparent 40%);
  background-size:120px 120px, 100% 100%;
  opacity:.6;
  pointer-events:none;
  mask-image:radial-gradient(circle at 50% 20%, #000 0%, transparent 70%);
}

.landing-body{
  position:relative;
  isolation:isolate;
}

.landing-body .topbar,
.landing-body .container,
.landing-body .footer{
  position:relative;
  z-index:1;
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:24px clamp(18px, 5vw, 52px);
  position:sticky;
  top:0;
  z-index:5;
  background:linear-gradient(180deg, rgba(7,12,18,.92), rgba(7,12,18,.45));
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.brand{
  display:flex;
  gap:12px;
  align-items:center;
}

.logo{
  width:46px;
  height:46px;
  border-radius:14px;
  background:linear-gradient(140deg, rgba(var(--brand-rgb),.25), rgba(6,10,15,.85));
  border:1px solid rgba(255,255,255,.1);
  display:grid;
  place-items:center;
  box-shadow:0 12px 24px rgba(8,14,20,.4), inset 0 0 0 1px rgba(255,255,255,.08);
}

.logo img{
  width:32px;
  height:32px;
  display:block;
  object-fit:contain;
}

.title{
  font-size:18px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.subtitle{
  font-size:12px;
  color:var(--muted);
}

.auth{
  display:flex;
  align-items:center;
  gap:10px;
}

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 clamp(18px, 5vw, 52px) 64px;
}

.hero{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(0, .8fr);
  gap:28px;
  align-items:center;
  padding:40px 0 28px;
  position:relative;
}

.hero-card{
  background:linear-gradient(150deg, rgba(18,26,36,.92), rgba(9,13,19,.96));
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  padding:28px 28px 30px;
  box-shadow:0 22px 60px rgba(7,12,18,.55);
  animation:panelIn .6s ease both;
}

.hero-card h1{
  margin:0 0 10px;
  font-size:32px;
}

.hero-card p{
  margin:0 0 18px;
  color:var(--muted);
  font-size:15px;
  line-height:1.5;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}

.hint{
  font-size:12px;
  color:rgba(239,243,251,.7);
}

.hero-ambient{
  height:260px;
  border-radius:30px;
  background:
    radial-gradient(circle at 30% 30%, rgba(110,196,255,.28), transparent 55%),
    radial-gradient(circle at 70% 60%, rgba(255,138,90,.28), transparent 50%),
    linear-gradient(160deg, rgba(20,170,167,.24), rgba(7,12,18,.3));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 24px 50px rgba(5,9,14,.5);
  position:relative;
  overflow:hidden;
  animation:floatSlow 10s ease-in-out infinite;
}

.hero-ambient::after{
  content:"";
  position:absolute;
  inset:18%;
  border-radius:24px;
  border:1px dashed rgba(255,255,255,.12);
  opacity:.7;
}

.section{
  margin-top:28px;
}

.section-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}

.section-header h2{
  margin:0;
  font-size:18px;
}

.divider{
  flex:1;
  height:1px;
  background:linear-gradient(90deg, rgba(255,255,255,.18), transparent);
}

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
}

.card{
  background:linear-gradient(160deg, rgba(17,24,34,.92), rgba(10,14,20,.96));
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:16px;
  text-decoration:none;
  color:inherit;
  display:grid;
  gap:10px;
  min-height:140px;
  box-shadow:0 16px 36px rgba(5,9,14,.45);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  animation:panelIn .6s ease both;
}

.card:hover{
  transform:translateY(-3px);
  border-color:rgba(110,196,255,.3);
  box-shadow:0 20px 40px rgba(5,9,14,.55);
}

.card-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}

.card-title{
  font-weight:700;
  font-size:15px;
}

.chip{
  padding:4px 10px;
  border-radius:999px;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.12em;
  background:rgba(108,196,255,.16);
  border:1px solid rgba(108,196,255,.3);
  color:#d7edff;
}

.card p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}

.card-footer{
  display:flex;
  justify-content:flex-end;
}

.link{
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#89e3de;
}

.footer{
  padding:30px clamp(18px, 5vw, 52px) 40px;
  color:var(--muted);
  font-size:12px;
  border-top:1px solid rgba(255,255,255,.06);
}

@keyframes panelIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes floatSlow{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

@media (max-width: 900px){
  .topbar{
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }

  .auth{
    width:100%;
    justify-content:flex-start;
  }

  .hero{
    grid-template-columns:1fr;
  }

  .hero-ambient{
    height:200px;
  }
}

.user-pill{
  display:flex;
  gap:10px;
  align-items:center;
  padding:3px 9px;
  border-radius:999px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.1);
}

.user-pill .email{
  display:none;
}

.user-pill--menu{
  position:relative;
  cursor:pointer;
  padding-right:34px;
}

.user-pill-caret{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  width:0;
  height:0;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  border-top:6px solid rgba(234,246,245,.75);
  pointer-events:none;
}

.user-menu{
  position:absolute;
  right:-12.5px;
  bottom:calc(100% + 10px);
  min-width:200px;
  background:#0f141b;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:6px;
  box-shadow:0 18px 30px rgba(0,0,0,.4);
  opacity:0;
  transform:translateY(6px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:20;
}

.user-pill--menu.user-pill--menu-down .user-menu{
  top:calc(100% + 10px);
  bottom:auto;
}

.user-pill--open .user-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.user-menu-item{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:10px;
  color:#eaf6f5;
  text-decoration:none;
  font-size:12px;
  font-weight:600;
}

.user-menu-icon{
  width:14px;
  height:14px;
  display:inline-block;
  opacity:.85;
  filter:brightness(0) invert(1);
}

.user-menu-item:hover{
  background:rgba(255,255,255,.08);
}

.user-menu-divider{
  height:1px;
  background:rgba(255,255,255,.12);
  margin:6px 6px;
}

.user-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  object-fit:cover;
  flex:0 0 auto;
  border:2px solid rgba(0,0,0,.6);
  box-shadow:0 2px 6px rgba(0,0,0,.35);
  background:rgba(0,0,0,.25);
}

.user-meta{
  display:grid;
  gap:1px;
  min-width:0;
  align-content:center;
}

.role{
  font-size:8px;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding:2px 6px;
  border-radius:999px;
  background:var(--teal);
  color:var(--ink);
  font-weight:800;
  display:none;
}

.username{
  font-weight:700;
  font-size:11px;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.email{font-size:9px;color:var(--muted)}

.dash-sidebar .user-pill{
  background:rgba(8,12,18,.42) !important;
  border:2px solid rgba(0,0,0,.55);
  color:#eaf6f5;
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-pill{
  width:calc(100% - 16px);
  margin:0 auto;
  position:relative;
  height:44px;
  min-height:44px;
  padding:0 36px 0 54px;
  gap:0;
  border-radius:999px;
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-pill.user-pill--menu{
  padding-right:36px;
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-pill.user-pill--menu .user-menu{
  left:0;
  right:auto;
  width:100%;
  min-width:100%;
  transform:translateY(6px);
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-pill.user-pill--menu.user-pill--menu-down .user-menu{
  transform:translateY(-6px);
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-pill--open .user-menu{
  transform:translateY(0);
}

.dash-frame:not(.sidebar-collapsed) .dash-sidebar .user-avatar{
  position:absolute;
  left:2px;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  border-radius:50%;
}

.dash-sidebar .role{
  background:rgba(8,16,22,.62);
  color:rgba(255,255,255,.9);
}

.dash-sidebar .email{
  color:rgba(234,246,245,.75);
}

/* Login */
.login-body{
  background:
    radial-gradient(circle at 12% 12%, rgba(var(--brand-rgb),.18), transparent 42%),
    radial-gradient(circle at 84% 18%, rgba(54,160,200,.18), transparent 45%),
    linear-gradient(180deg, #070d13 0%, #0a121b 50%, #0d1620 100%);
  overflow:hidden;
  position:relative;
  color:#eaf2fb;
  font-family:"Space Grotesk","Poppins","JetBrains Mono",sans-serif;
}

.login-body::before{
  content:"";
  position:fixed;
  inset:-20% -10%;
  background:
    linear-gradient(115deg, transparent 40%, rgba(var(--brand-rgb),.12) 46%, transparent 52%),
    linear-gradient(115deg, transparent 58%, rgba(var(--brand-rgb),.12) 64%, transparent 70%);
  opacity:.65;
  transform:skewY(-3deg);
  pointer-events:none;
}

.login-stars{
  position:fixed;
  inset:0;
  background-image:
    radial-gradient(rgba(255,255,255,.4) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,.2) 1px, transparent 1px);
  background-size: 160px 160px, 90px 90px;
  background-position: 0 0, 40px 30px;
  opacity:.14;
  pointer-events:none;
}

.login-planet{
  position:fixed;
  width:600px;
  height:600px;
  border-radius:50%;
  right:-120px;
  top:-120px;
  background:radial-gradient(circle at 30% 30%, rgba(var(--brand-rgb),.35), rgba(6,12,18,0) 60%);
  filter:blur(10px);
  opacity:.7;
  pointer-events:none;
}

.login-brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-align:center;
  color:#eaf2fb;
}

.login-brand-mark{
  display:grid;
  place-items:center;
  background:transparent;
  border:0;
  box-shadow:none;
}

.login-brand-mark img{
  width:72px;
  height:72px;
  display:block;
  filter:drop-shadow(0 6px 14px rgba(var(--brand-rgb),.45));
}

.login-brand-title{
  font-size:clamp(22px, 4.5vw, 36px);
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-family:"Space Grotesk", system-ui, -apple-system, sans-serif;
}

.login-brand-subtitle{
  font-size:13px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:rgba(234,242,251,.7);
}

.login-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:48px 20px;
  position:relative;
  z-index:1;
}

.login-hero{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:20px;
  width:min(460px, 92vw);
}

.login-card{
  background:rgba(12,18,26,.82);
  color:#eaf2fb;
  padding:26px;
  border-radius:20px;
  width:100%;
  text-align:left;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 26px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(8px);
}

.login-card-title{
  font-weight:600;
  font-size:18px;
  margin-bottom:4px;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.login-card-sub{
  color:rgba(234,242,251,.7);
  font-size:12px;
  margin-bottom:16px;
}

.login-card p{margin:0 0 20px;font-size:13px}
.login-sub{margin-top:12px;font-size:12px;opacity:.75;text-align:center}
.login-form{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:14px 0 12px;
}

.login-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:left;
  font-size:12px;
  color:rgba(234,242,251,.9);
}

.login-input{
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(8,12,18,.72);
  color:#eaf2fb;
  font-size:13px;
}

.login-input:focus{
  outline:none;
  border-color:rgba(var(--brand-rgb),.6);
  box-shadow:0 0 0 2px rgba(var(--brand-rgb),.2);
}

.login-error{
  background:rgba(255,88,88,.12);
  color:#ffb4b4;
  border:1px solid rgba(255,88,88,.4);
  padding:10px 12px;
  border-radius:10px;
  font-size:12px;
  margin:12px 0;
}

.login-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  opacity:.65;
  margin:12px 0 14px;
}

.login-divider::before,
.login-divider::after{
  content:"";
  flex:1;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.2));
}

.field-with-action .field-action-row{
  display:flex;
  align-items:center;
  gap:8px;
}

.field-with-action .field-action-row input{
  flex:1 1 auto;
}

.field-with-action .icon-button{
  width:32px;
  height:32px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(10,14,18,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  cursor:pointer;
}

.field-with-action .icon-button img{
  width:16px;
  height:16px;
}

.field-with-action .icon-button:hover{
  border-color:rgba(var(--brand-rgb),.4);
  box-shadow:inset 0 0 0 1px rgba(var(--brand-rgb),.2);
}

.plex-settings-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.ghost-button{
  padding:8px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(10,14,18,.4);
  color:#eaf6f5;
  font-size:12px;
  cursor:pointer;
}

.ghost-button:hover{
  border-color:rgba(var(--brand-rgb),.5);
  box-shadow:inset 0 0 0 1px rgba(var(--brand-rgb),.2);
}

.login-card .primary-button{
  background:linear-gradient(135deg, var(--brand-btn-start), var(--teal-dark));
  color:var(--on-brand);
  border:2px solid var(--teal-dark);
  box-shadow:0 10px 26px rgba(var(--brand-rgb),.35), inset 0 0 0 2px rgba(255,255,255,.18);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
}

.login-card .primary-button:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 32px rgba(var(--brand-rgb),.45), inset 0 0 0 2px rgba(255,255,255,.2);
}

.login-card .primary-button:focus-visible{
  outline:2px solid rgba(var(--brand-rgb),.8);
  outline-offset:2px;
}

.plex-button{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(var(--brand-rgb),.6);
  background:rgba(10,14,18,.6);
  color:#f2fbfb;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 10px 20px rgba(0,0,0,.35);
}

.plex-button img{
  width:46px;
  height:22px;
  object-fit:contain;
  filter:brightness(1.05);
}

.plex-button:hover{
  border-color:rgba(var(--brand-rgb),.85);
  box-shadow:0 12px 24px rgba(0,0,0,.45);
}

/* Dashboard layout */
.dash-body{
  background:
    radial-gradient(circle at 12% 12%, rgba(92,225,222,.16), transparent 45%),
    radial-gradient(circle at 88% 8%, rgba(255,170,110,.16), transparent 45%),
    linear-gradient(160deg, #0b1118, #0a0f16);
  overflow:hidden;
  overflow-x:clip;
  position:relative;
  isolation:isolate;
}

.dash-starfield-canvas{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  display:block;
  opacity:.95;
}

.dash-body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  background:
    linear-gradient(120deg, transparent 42%, rgba(255,255,255,.04) 50%, transparent 58%),
    radial-gradient(circle at 70% 80%, rgba(110,196,255,.1), transparent 45%);
  opacity:.6;
  pointer-events:none;
}

.dash-body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    radial-gradient(
      circle at 3% 9%,
      rgba(var(--brand-rgb, 28,198,194),.72) 0 calc(var(--star-size, 1.2) * .48px),
      transparent calc(var(--star-size, 1.2) * 1.35px)
    ),
    radial-gradient(
      circle at 11% 67%,
      rgba(255,255,255,.78) 0 calc(var(--star-size, 1.2) * .42px),
      transparent calc(var(--star-size, 1.2) * 1.18px)
    ),
    radial-gradient(
      circle at 19% 34%,
      rgba(194,224,255,.6) 0 calc(var(--star-size, 1.2) * .36px),
      transparent calc(var(--star-size, 1.2) * 1.06px)
    ),
    radial-gradient(
      circle at 24% 83%,
      rgba(var(--brand-rgb, 28,198,194),.74) 0 calc(var(--star-size, 1.2) * .41px),
      transparent calc(var(--star-size, 1.2) * 1.22px)
    ),
    radial-gradient(
      circle at 33% 14%,
      rgba(255,255,255,.72) 0 calc(var(--star-size, 1.2) * .39px),
      transparent calc(var(--star-size, 1.2) * 1.14px)
    ),
    radial-gradient(
      circle at 38% 56%,
      rgba(201,231,255,.64) 0 calc(var(--star-size, 1.2) * .37px),
      transparent calc(var(--star-size, 1.2) * 1.08px)
    ),
    radial-gradient(
      circle at 44% 91%,
      rgba(var(--brand-rgb, 28,198,194),.7) 0 calc(var(--star-size, 1.2) * .45px),
      transparent calc(var(--star-size, 1.2) * 1.3px)
    ),
    radial-gradient(
      circle at 52% 29%,
      rgba(255,255,255,.82) 0 calc(var(--star-size, 1.2) * .4px),
      transparent calc(var(--star-size, 1.2) * 1.16px)
    ),
    radial-gradient(
      circle at 59% 73%,
      rgba(194,224,255,.62) 0 calc(var(--star-size, 1.2) * .36px),
      transparent calc(var(--star-size, 1.2) * 1.05px)
    ),
    radial-gradient(
      circle at 67% 11%,
      rgba(var(--brand-rgb, 28,198,194),.74) 0 calc(var(--star-size, 1.2) * .43px),
      transparent calc(var(--star-size, 1.2) * 1.2px)
    ),
    radial-gradient(
      circle at 72% 47%,
      rgba(255,255,255,.74) 0 calc(var(--star-size, 1.2) * .38px),
      transparent calc(var(--star-size, 1.2) * 1.12px)
    ),
    radial-gradient(
      circle at 81% 82%,
      rgba(194,224,255,.58) 0 calc(var(--star-size, 1.2) * .34px),
      transparent calc(var(--star-size, 1.2) * 1.02px)
    ),
    radial-gradient(
      circle at 88% 22%,
      rgba(var(--brand-rgb, 28,198,194),.72) 0 calc(var(--star-size, 1.2) * .44px),
      transparent calc(var(--star-size, 1.2) * 1.26px)
    ),
    radial-gradient(
      circle at 94% 59%,
      rgba(255,255,255,.76) 0 calc(var(--star-size, 1.2) * .4px),
      transparent calc(var(--star-size, 1.2) * 1.17px)
    ),
    radial-gradient(
      circle at 15% 41%,
      rgba(var(--brand-rgb, 28,198,194),.2) 0 calc(var(--star-size, 1.2) * 2.1px),
      transparent calc(var(--star-size, 1.2) * 5.2px)
    ),
    radial-gradient(
      circle at 54% 17%,
      rgba(255,255,255,.16) 0 calc(var(--star-size, 1.2) * 1.8px),
      transparent calc(var(--star-size, 1.2) * 4.3px)
    ),
    radial-gradient(
      circle at 76% 63%,
      rgba(194,224,255,.14) 0 calc(var(--star-size, 1.2) * 1.65px),
      transparent calc(var(--star-size, 1.2) * 4.1px)
    ),
    radial-gradient(
      circle at 31% 74%,
      rgba(var(--brand-rgb, 28,198,194),.18) 0 calc(var(--star-size, 1.2) * 2.25px),
      transparent calc(var(--star-size, 1.2) * 5.5px)
    );
  background-size:calc(var(--star-density, 165) * 1px) calc(var(--star-density, 165) * 1.17px);
  background-position:0 0;
  opacity:.68;
  animation:launcharrStarDrift var(--star-speed, 45s) linear infinite;
  will-change:background-position;
}

.dash-body.starfield-3d::after{
  display:none;
}

html[data-bg-motion="0"] .dash-body::after{
  animation:none;
  opacity:.32;
}

@keyframes launcharrStarDrift{
  from{background-position:0 0}
  to{background-position:-460px 310px}
}

.dash-frame{
  max-width:min(1400px, 96vw);
  margin:16px auto;
  padding:10px;
  height:calc(100vh - 32px);
  height:calc(100svh - 32px);
  height:calc(100dvh - 32px);
  display:grid;
  grid-template-columns:190px 1fr;
  gap:0;
  background:linear-gradient(160deg, rgba(12,18,26,.92), rgba(9,13,19,.96));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  box-shadow:0 30px 70px rgba(0,0,0,.6);
  overflow:hidden;
  overflow-x:clip;
  position:relative;
  z-index:1;
}

html[data-embedded="1"] .dash-frame{
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  padding:0 !important;
  height:100vh !important;
  height:100svh !important;
  height:100dvh !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}

.dash-sidebar{
  --sidebar-brand-h:50px;
  --sidebar-user-h:56px;
  background:#1b1d23;
  border:3px solid #000;
  border-right:0;
  border-radius:12px 0 0 12px;
  padding:0;
  display:grid;
  grid-template-rows:var(--sidebar-brand-h) minmax(0,1fr) var(--sidebar-user-h);
  gap:0;
  min-height:0;
  overflow:hidden;
  color:#e7ebf0;
}

html[data-sidebar-invert="1"] .dash-sidebar,
html[data-sidebar-invert="1"] .dash-brand{
  background:var(--teal);
  color:var(--on-brand);
}

html[data-sidebar-invert="1"] .dash-title,
html[data-sidebar-invert="1"] .nav-item,
html[data-sidebar-invert="1"] .nav-accordion-trigger,
html[data-sidebar-invert="1"] .nav-subitem{
  color:var(--on-brand);
}

html[data-sidebar-invert="1"] .dash-brand::after,
html[data-sidebar-invert="1"] .nav-divider{
  background:rgba(0,0,0,.3);
  border-color:rgba(0,0,0,.48);
}

html[data-sidebar-invert="1"] .dash-user{
  background:transparent;
  border-color:#000;
}

html[data-sidebar-invert="1"] .nav-item:hover,
html[data-sidebar-invert="1"] .nav-accordion-item:not(.open) > .nav-accordion-trigger:hover{
  background:rgba(0,0,0,.12);
  border-color:rgba(0,0,0,.35);
}

html[data-sidebar-invert="1"] .nav-item.active,
html[data-sidebar-invert="1"] .nav-accordion-item.open > .nav-accordion-trigger{
  background:rgba(7,12,19,.72);
  color:#eaf2fb;
  border-color:rgba(0,0,0,.78);
}

html[data-sidebar-invert="1"] .dash-sidebar .user-pill{
  background:rgba(8,12,18,.42) !important;
  border-color:rgba(0,0,0,.62);
  color:#eaf6f5;
}

html[data-sidebar-invert="1"] .dash-sidebar .user-avatar{
  border-radius:50%;
}

html[data-sidebar-invert="1"] .dash-sidebar .email{
  color:rgba(234,246,245,.82);
}

html[data-square-corners="1"] .dash-frame,
html[data-square-corners="1"] .dash-sidebar,
html[data-square-corners="1"] .dash-main,
html[data-square-corners="1"] .main-window-bar,
html[data-square-corners="1"] .dash-panel,
html[data-square-corners="1"] .panel-card,
html[data-square-corners="1"] .plex-panel,
html[data-square-corners="1"] .plex-topbar,
html[data-square-corners="1"] .plex-select,
html[data-square-corners="1"] .plex-iconbtn,
html[data-square-corners="1"] .plex-card,
html[data-square-corners="1"] .plex-poster-well,
html[data-square-corners="1"] .plex-pill,
html[data-square-corners="1"] .plex-type-icon,
html[data-square-corners="1"] .plex-eye-icon,
html[data-square-corners="1"] .plex-source-icon,
html[data-square-corners="1"] .plex-watchlist-btn,
html[data-square-corners="1"] .prowlarr-row,
html[data-square-corners="1"] .queue-table,
html[data-square-corners="1"] .arr-calendar-pane,
html[data-square-corners="1"] .arr-calendar-day,
html[data-square-corners="1"] .arr-calendar-item,
html[data-square-corners="1"] .arr-calendar-overlay-card,
html[data-square-corners="1"] .settings-card,
html[data-square-corners="1"] .settings-row,
html[data-square-corners="1"] .settings-select,
html[data-square-corners="1"] .settings-users-role select,
html[data-square-corners="1"] .settings-tab-btn,
html[data-square-corners="1"] .settings-subtab-btn,
html[data-square-corners="1"] .theme-preset-card,
html[data-square-corners="1"] .primary-button,
html[data-square-corners="1"] .ghost-button,
html[data-square-corners="1"] .version-pill,
html[data-square-corners="1"] .nav-item,
html[data-square-corners="1"] .nav-accordion-trigger,
html[data-square-corners="1"] .nav-subitem,
html[data-square-corners="1"] .user-pill,
html[data-square-corners="1"] .user-avatar,
html[data-square-corners="1"] .user-menu,
html[data-square-corners="1"] .plex-modal,
html[data-square-corners="1"] .plex-modal-close,
html[data-square-corners="1"] .plex-modal-hero,
html[data-square-corners="1"] .plex-modal-poster,
html[data-square-corners="1"] .plex-modal-link,
html[data-square-corners="1"] .plex-pill2{
  border-radius:0 !important;
}

html[data-square-corners="0"] .dash-sidebar .user-pill{
  border-radius:999px !important;
}

html[data-square-corners="0"] .dash-sidebar .user-avatar{
  border-radius:50% !important;
}

.dash-brand{
  display:flex;
  gap:10px;
  align-items:center;
  position:relative;
  top:auto;
  z-index:2;
  height:var(--sidebar-brand-h);
  min-height:var(--sidebar-brand-h);
  box-sizing:border-box;
  padding:0 12px;
  background:#1b1d23;
  border-top-left-radius:12px;
  overflow:hidden;
}

.sidebar-toggle{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  background:rgba(6,10,14,.35);
  border:1px solid rgba(255,255,255,.12);
  border-radius:8px;
  cursor:pointer;
  padding:0;
}

.sidebar-toggle.main-toggle{
  margin-right:10px;
  width:30px;
  height:30px;
  min-width:30px;
  min-height:30px;
  flex:0 0 30px;
  background:rgba(8,12,18,.7);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 0 0 1px rgba(var(--brand-rgb),.28);
}

.toggle-icon{
  width:16px;
  height:16px;
}

.dash-brand::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:3px;
  height:2px;
  background:#000;
  border-top:0;
}

.dash-logo{
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:0;
  border-radius:0;
  width:auto;
  height:auto;
  padding:0;
}

.dash-logo img{
  width:41px;
  height:41px;
  display:block;
  object-fit:contain;
}

.dash-logo .nav-icon{
  width:41px;
  height:41px;
}


.dash-title{font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:12px}
.dash-title{color:#f2f5f8}
.dash-subtitle{font-size:12px;color:rgba(10,20,25,.65)}
.dash-subtitle{color:var(--on-brand-muted)}

.dash-nav{
  --nav-row-size:34px;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:6px;
  padding:8px 12px 6px;
  width:100%;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:thin;
  scrollbar-color:rgba(10,20,25,.5) transparent;
  position:relative;
}

.dash-nav::-webkit-scrollbar{
  width:10px;
}

.dash-nav::-webkit-scrollbar-track{
  background:transparent;
}

.dash-nav::-webkit-scrollbar-thumb{
  background:rgba(10,20,25,.45);
  border:2px solid transparent;
  border-radius:999px;
  background-clip:padding-box;
}

.dash-nav::-webkit-scrollbar-thumb:hover{
  background:rgba(10,20,25,.62);
  background-clip:padding-box;
}

.dash-nav::-webkit-scrollbar-button{
  display:none;
  width:0;
  height:0;
}

.nav-divider{
  height:1px;
  background:rgba(0,0,0,.35);
  border-top:1px solid rgba(255,255,255,.08);
  margin:4px 2px;
}

.nav-section{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.2em;
  color:rgba(10,20,25,.65);
  margin-bottom:6px;
  font-weight:700;
}

.nav-item{
  padding:7px 9px;
  border-radius:8px;
  background:transparent;
  border:1px solid transparent;
  text-decoration:none;
  font-weight:600;
  color:#dfe4ea;
  font-size:12px;
  line-height:1.2;
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  min-height:var(--nav-row-size);
  height:var(--nav-row-size);
  box-sizing:border-box;
}


.nav-item.active{
  background:var(--teal);
  color:var(--on-brand);
  border-color:rgba(0,0,0,.7);
  box-shadow:none;
}

.nav-item:hover{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
}

.dash-nav .nav-item[href="/dashboard"].active,
.dash-nav .nav-item[href="/settings"].active{
  background:var(--teal);
  border-color:rgba(0,0,0,.7);
  box-shadow:none;
}

html[data-sidebar-invert="1"] .dash-nav .nav-item[href="/dashboard"].active,
html[data-sidebar-invert="1"] .dash-nav .nav-item[href="/settings"].active{
  background:rgba(7,12,19,.72);
  color:#eaf2fb;
  border-color:rgba(0,0,0,.78);
}

.nav-accordion{
  display:grid;
  gap:6px;
}

.nav-accordion-item{
  border-radius:8px;
  background:transparent;
  border:0;
  overflow:visible;
  width:100%;
  box-sizing:border-box;
}

.nav-accordion-trigger{
  width:100%;
  padding:7px 9px;
  border:0;
  background:transparent;
  color:#dfe4ea;
  text-align:left;
  font-weight:600;
  cursor:pointer;
  font-size:12px;
  line-height:1.2;
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
  padding-right:26px;
  min-height:var(--nav-row-size);
  height:var(--nav-row-size);
  border-radius:8px;
  box-sizing:border-box;
}

.nav-accordion-trigger::after{
  content:"›";
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  font-size:14px;
  opacity:.9;
  color:#d4dbe3;
}

.nav-accordion-item.open > .nav-accordion-trigger::after{
  content:"⌄";
  font-size:13px;
  top:48%;
  color:var(--on-brand);
}

.nav-accordion-item.open > .nav-accordion-trigger{
  background:var(--teal);
  color:var(--on-brand);
  border:1px solid rgba(0,0,0,.7);
}

.dash-frame:not(.sidebar-collapsed) .nav-accordion-panel--category .nav-accordion-item.open > .nav-accordion-trigger{
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.14)), var(--teal);
  color:var(--on-brand);
  border-color:rgba(255,255,255,.42);
}

.nav-accordion-item:not(.open) > .nav-accordion-trigger:hover{
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
}

.nav-accordion-panel{
  display:none;
  padding:4px 0 2px 10px;
  gap:4px;
  margin-left:16px;
  border-left:0;
  position:relative;
}

.nav-accordion-panel::before{
  content:"";
  position:absolute;
  left:0;
  top:4px;
  bottom:4px;
  width:1px;
  background:rgba(255,255,255,.28);
}

.nav-accordion-item--category{
  background:transparent;
  border-color:transparent;
}

.nav-accordion-trigger--category{
  font-size:12px;
  letter-spacing:.04em;
  text-transform:none;
  min-height:34px;
  font-weight:700;
  color:#dfe4ea;
}

.nav-accordion-panel--category{
  padding:4px 0 2px;
  margin-left:0;
  border-left:0;
}

.nav-accordion-trigger--category .nav-label{
  font-weight:700;
  color:inherit;
}

.nav-accordion--nested{
  display:grid;
  gap:6px;
}

html:not([data-sidebar-invert="1"]) .dash-frame:not(.sidebar-collapsed) .nav-accordion-panel--category > .nav-accordion--nested > .nav-accordion-item.open > .nav-accordion-trigger{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  color:#eaf2fb;
}

.sidebar-collapsed{
  grid-template-columns:56px 1fr;
}

.sidebar-collapsed .dash-nav{
  padding:8px 0 6px;
  align-items:center;
}

.sidebar-collapsed .nav-divider{
  width:32px;
  margin:4px auto;
}

.sidebar-collapsed .dash-user{
  padding:0;
  height:var(--sidebar-user-h);
  min-height:var(--sidebar-user-h);
  display:flex;
  align-items:center;
  justify-content:center;
}

.sidebar-collapsed .nav-item{
  padding:0;
  width:34px;
  min-width:34px;
  min-height:var(--nav-row-size);
  height:var(--nav-row-size);
  border-radius:8px;
  margin:0 auto;
  display:grid;
  place-items:center;
  background:transparent;
  box-sizing:border-box;
  line-height:0;
  font-size:0;
  border:0;
}

.sidebar-collapsed .nav-accordion-trigger::after{
  display:none;
}

.sidebar-collapsed .nav-accordion-trigger{
  padding:0;
  width:34px;
  min-width:34px;
  min-height:var(--nav-row-size);
  height:var(--nav-row-size);
  border-radius:8px;
  margin:0 auto;
  background:transparent;
  border:0;
  display:grid;
  place-items:center;
  box-sizing:border-box;
  line-height:0;
  font-size:0;
}

.sidebar-collapsed .nav-item.active,
.sidebar-collapsed .nav-accordion-item:not(.nav-accordion-item--category).open > .nav-accordion-trigger{
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.14)), var(--teal);
  color:var(--on-brand);
  box-shadow:none;
  border:1px solid rgba(255,255,255,.42);
}

html[data-sidebar-invert="1"] .sidebar-collapsed .nav-item.active,
html[data-sidebar-invert="1"] .sidebar-collapsed .nav-accordion-item:not(.nav-accordion-item--category).open > .nav-accordion-trigger{
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.14)), var(--teal);
  color:var(--on-brand);
  border:1px solid rgba(255,255,255,.42);
}

.sidebar-collapsed .nav-accordion-item{
  display:grid;
  justify-items:center;
  align-items:center;
  width:34px;
  margin:0 auto;
  background:transparent;
  border:0;
  box-shadow:none;
  border-radius:10px;
  padding:0;
}

.sidebar-collapsed .nav-accordion-panel{
  padding:4px 0 2px;
  display:none;
  flex-direction:column;
  align-items:center;
  gap:4px;
  width:32px;
  margin:0 auto;
  justify-content:center;
  margin-left:0;
  border-left:0;
}

.sidebar-collapsed .nav-accordion-panel::before{
  display:none;
}

.sidebar-collapsed .nav-accordion-item.open > .nav-accordion-panel{
  display:flex;
}

.sidebar-collapsed .nav-subitem{
  width:20px;
  height:20px;
  padding:0;
  border-radius:0;
  margin:0 auto;
  background:transparent;
  border:0;
  box-shadow:none;
  display:grid;
  place-items:center;
  line-height:0;
  font-size:0;
}

.sidebar-collapsed .nav-subitem.active{
  background:transparent;
  border-color:transparent;
  box-shadow:none;
  font-weight:600;
}

.sidebar-collapsed .nav-subicon{
  width:14px;
  height:14px;
  display:block;
  margin:0 auto;
  filter:none;
}

.sidebar-collapsed .dash-nav .nav-icon{
  width:16px;
  height:16px;
}

.sidebar-collapsed .dash-nav .nav-icon.app-icon{
  width:18px;
  height:18px;
}

.sidebar-collapsed .nav-label,
.sidebar-collapsed .dash-title,
.sidebar-collapsed .dash-subtitle,
.sidebar-collapsed .user-pill .username,
.sidebar-collapsed .user-pill .email,
.sidebar-collapsed .user-pill .role{
  display:none;
}

.sidebar-collapsed .dash-brand{
  justify-content:center;
  height:var(--sidebar-brand-h);
  min-height:var(--sidebar-brand-h);
  box-sizing:border-box;
  padding:0;
  gap:0;
  width:100%;
  border-top-left-radius:12px;
}

.sidebar-collapsed .dash-brand > div{
  display:none;
}

.sidebar-collapsed .dash-logo{
  width:auto;
  height:auto;
  border-radius:0;
  padding:0;
  margin:0 auto;
  transform:none;
}

.sidebar-collapsed .dash-logo img{
  width:41px;
  height:41px;
}

.sidebar-collapsed .user-pill{
  justify-content:center;
  background:transparent;
  border:0;
  padding:0;
  width:44px;
  height:44px;
}

.sidebar-collapsed .user-pill-caret{
  display:none;
}

.dash-frame.sidebar-collapsed .user-menu-item{
  justify-content:center;
  padding:8px;
  gap:0;
}

.dash-frame.sidebar-collapsed .user-menu-text{
  display:none;
}

.dash-frame.sidebar-collapsed .user-menu{
  left:50%;
  right:auto;
  min-width:0;
  width:46px;
  transform:translate(-50%, 6px);
}

.dash-frame.sidebar-collapsed .user-pill--open .user-menu{
  transform:translate(-50%, 0);
}

.sidebar-collapsed .user-meta{
  display:none;
}

.sidebar-collapsed .user-avatar{
  width:36px;
  height:36px;
}

.sidebar-collapsed .nav-subitem span{
  display:none;
}

.nav-icon{
  width:14px;
  height:14px;
  flex:0 0 auto;
  display:block;
}

.nav-icon.app-icon{
  width:16px;
  height:16px;
}

.dash-frame:not(.sidebar-collapsed) .nav-icon{
  width:16px;
  height:16px;
}

.dash-frame:not(.sidebar-collapsed) .nav-icon.app-icon{
  width:18px;
  height:18px;
}
.dash-frame .dash-brand .dash-logo .nav-icon.app-icon{
  width:30px;
  height:30px;
  filter:drop-shadow(0 0 6px rgba(0,0,0,.6)) drop-shadow(0 0 12px rgba(var(--brand-rgb),.52));
}

.nav-accordion-item.open > .nav-accordion-panel{
  display:grid;
}

.nav-subitem{
  padding:0 0 0 8px;
  border-radius:0;
  background:transparent;
  border:0;
  text-decoration:none;
  font-size:11px;
  color:#d7dce3;
  display:flex;
  align-items:center;
  gap:6px;
  min-height:20px;
  height:20px;
  box-sizing:border-box;
}

.nav-subitem.active{
  background:transparent;
  color:#f4f7fb;
  border:0;
  box-shadow:none;
  font-weight:700;
}

.sidebar-collapsed .nav-subitem.active .nav-subicon{
  width:16px;
  height:16px;
  filter:contrast(1.35) saturate(1.15);
}

.nav-subitem.muted{
  opacity:.55;
  cursor:not-allowed;
}

.nav-subicon{
  width:12px;
  height:12px;
  flex:0 0 auto;
  display:block;
}

.dash-frame:not(.sidebar-collapsed) .nav-subicon{
  width:14px;
  height:14px;
}

.dash-user{
  padding:8px 12px;
  height:var(--sidebar-user-h);
  min-height:var(--sidebar-user-h);
  display:flex;
  align-items:center;
  position:relative;
  bottom:auto;
  z-index:1;
  background:transparent;
  box-shadow:none;
  border-top:3px solid #000;
}

.dash-main{
  --main-window-gap:10px;
  --main-window-pad-top:0;
  --main-window-pad-bottom:20px;
  display:grid;
  align-content:start;
  grid-auto-rows:max-content;
  gap:var(--main-window-gap);
  background:linear-gradient(180deg, rgba(18,24,34,.94), rgba(10,14,20,.96));
  border:3px solid #000;
  border-top:0;
  border-left:3px solid #000;
  border-radius:0 12px 12px 0;
  padding:var(--main-window-pad-top) var(--main-window-gap) var(--main-window-pad-bottom);
  overflow-y:auto;
  overflow-x:hidden;
  overflow-x:clip;
  overscroll-behavior-x:none;
  min-height:0;
}

.dash-main.bar-flush{
  --main-window-gap:10px;
}

.dash-main.bar-flush{
  grid-template-rows:auto 1fr;
}
.dash-body:not(.launch-page) .dash-main{
  padding-bottom:var(--main-window-gap);
}

.overview-panel{
  height:100%;
  display:flex;
  flex-direction:column;
}


.overview-panel .panel-card{
  flex:1;
}
.main-window-bar{
  display:flex;
  align-items:center;
  background:var(--teal);
  border:3px solid #000;
  border-left:0;
  border-right:0;
  border-radius:0 12px 0 0;
  height:50px;
  margin:0 calc((var(--main-window-gap) + 3px) * -1) 0 calc(var(--main-window-gap) * -1);
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
  position:sticky;
  top:0;
  z-index:20;
}

.main-window-title{
  padding:0 12px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:13px;
  color:var(--on-brand);
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}

.main-window-app{
  font-weight:800;
}

.main-window-rest{
  font-weight:600;
}

.main-window-icon{
  width:18px;
  height:18px;
  object-fit:contain;
  flex:0 0 auto;
}

.main-window-icon[src$="settings.svg"],
.main-window-icon[src$="user-profile.svg"]{
  filter:var(--on-brand-icon-filter);
}

.main-window-spacer{
  margin-left:auto;
}

.main-window-status{
  display:flex;
  align-items:center;
  gap:8px;
  margin-right:8px;
  font-size:12px;
  color:var(--muted);
  flex:0 0 auto;
}

.main-window-status .status-dot{
  display:none;
}

.theme-toggle{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
  cursor:pointer;
  padding:0;
}

.theme-toggle-icon{
  width:14px;
  height:14px;
  display:block;
}

.version-badge{
  display:flex;
  align-items:center;
  gap:6px;
  flex:0 0 auto;
}

.version-pill{
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);
  color:var(--text);
  font-size:11px;
  font-weight:700;
  letter-spacing:.02em;
  white-space:nowrap;
  flex:0 0 auto;
}

.theme-toggle:focus-visible,
.version-pill:focus-visible{
  outline:2px solid rgba(122,233,229,.5);
  outline-offset:2px;
}

.version-pill--latest{
  border-color:rgba(var(--brand-rgb),.5);
  background:rgba(18,28,36,.55);
  color:#bff6f0;
}

[data-theme="day"] .dash-frame{
  background:linear-gradient(160deg, #e7ecf1, #e1e6ec);
  border-color:rgba(10,20,30,.14);
  box-shadow:0 22px 50px rgba(8,14,20,.16);
}

[data-theme="day"] .dash-main{
  background:linear-gradient(180deg, #f2f5f8, #eef2f6);
  border-color:#000;
  color:#0b151e;
}

[data-theme="day"] .main-window-title{
  color:var(--on-brand);
}

[data-theme="day"] .main-window-icon{
  filter:none;
}

[data-theme="day"] .main-window-icon[src$="settings.svg"],
[data-theme="day"] .main-window-icon[src$="user-profile.svg"]{
  filter:var(--on-brand-icon-filter);
}

[data-theme="day"] .dash-panel,
[data-theme="day"] .panel-card,
[data-theme="day"] .settings-card,
[data-theme="day"] .settings-row,
[data-theme="day"] .settings-table,
[data-theme="day"] .settings-combined-item{
  background:#f7f9fb;
  border-color:rgba(10,20,30,.12);
  box-shadow:0 10px 24px rgba(8,14,20,.07);
}

[data-theme="day"] .plex-panel,
[data-theme="day"] .plex-topbar{
  background:#fbfcfe;
  border-color:rgba(10,20,30,.12);
  box-shadow:none;
}

[data-theme="day"] .panel-sub,
[data-theme="day"] .panel-card p,
[data-theme="day"] .settings-tip,
[data-theme="day"] .settings-card-sub,
[data-theme="day"] .settings-users-note{
  color:rgba(15,25,35,.6);
}

[data-theme="day"] .settings-users-row{
  background:#f2f5f8;
  border-color:rgba(15,25,35,.12);
}

[data-theme="day"] .settings-users-head{
  background:#e3e9f0;
  color:rgba(12,20,28,.65);
}

[data-theme="day"] .settings-users-login{
  color:rgba(12,20,28,.65);
}

[data-theme="day"] .settings-users-role select{
  background:#fff;
  border-color:rgba(15,25,35,.2);
  color:#0b151e;
}

[data-theme="day"] .settings-users-locked{
  color:#0e4f50;
  background:rgba(var(--brand-rgb),.25);
  border-color:rgba(var(--brand-rgb),.5);
}

[data-theme="day"] .dash-main input,
[data-theme="day"] .dash-main select,
[data-theme="day"] .dash-main textarea{
  background:rgba(255,255,255,.9);
  border-color:rgba(10,20,30,.2);
  color:#0b151e;
}

[data-theme="day"] .dash-main input::placeholder,
[data-theme="day"] .dash-main textarea::placeholder{
  color:rgba(20,30,40,.45);
}

[data-theme="day"] .plex-overview{
  --plex-text:#0b151e;
  --plex-muted:#5b6b7a;
  --plex-panel1:#f6f8fb;
  --plex-panel2:#e8eef4;
  --plex-ink:var(--on-brand);
}

[data-theme="day"] .plex-title{
  color:#1f2b38;
  text-shadow:none;
}

[data-theme="day"] .plex-select select{
  background:transparent;
  color:var(--plex-ink);
  color-scheme:light;
}

[data-theme="day"] .plex-select select option{
  background:#f4f7fb;
  color:#0b151e;
}

[data-theme="day"] .plex-search{
  background:#eef2f6;
  border-color:rgba(10,20,30,.2);
  box-shadow:inset 0 0 0 1px rgba(10,20,30,.08);
}

[data-theme="day"] .plex-search input{
  color:#0b151e;
}

[data-theme="day"] .plex-search input::placeholder{
  color:rgba(20,30,40,.45);
}

[data-theme="day"] .prowlarr-row{
  background:#f1f4f8;
  border-color:rgba(10,20,30,.12);
  box-shadow:0 6px 14px rgba(8,14,20,.06);
  color:#0b151e;
}

[data-theme="day"] .prowlarr-row--head{
  background:#dbe2ea;
  color:#1f2b38;
  border-color:rgba(10,20,30,.18);
}

[data-theme="day"] .prowlarr-row--empty{
  color:rgba(20,30,40,.55);
}

[data-theme="day"] .queue-table{
  background:#f1f4f8;
  border-color:rgba(10,20,30,.16);
}

[data-theme="day"] .queue-row{
  border-top:1px solid rgba(10,20,30,.12);
  color:#0b151e;
}

[data-theme="day"] .queue-row.header{
  background:#dbe2ea;
  color:#1f2b38;
}

[data-theme="day"] .queue-title,
[data-theme="day"] .queue-link,
[data-theme="day"] .queue-ep-title-link{
  color:#1c6f8f;
}

[data-theme="day"] .queue-link:hover,
[data-theme="day"] .queue-link:focus-visible{
  color:#155a73;
}

[data-theme="day"] .queue-episode,
[data-theme="day"] .queue-ep-title,
[data-theme="day"] .queue-time{
  color:rgba(20,30,40,.8);
}

[data-theme="day"] .queue-quality{
  background:rgba(10,20,30,.08);
  border-color:rgba(10,20,30,.12);
  color:#1f2b38;
}

[data-theme="day"] .queue-progress{
  background:rgba(10,20,30,.08);
  border-color:rgba(10,20,30,.12);
}

[data-theme="day"] .queue-progress > span{
  background:#7bb5ff;
}

[data-theme="day"] .queue-empty{
  color:rgba(20,30,40,.55);
}

[data-theme="day"] .plex-type-icon,
[data-theme="day"] .plex-eye-icon,
[data-theme="day"] .plex-source-icon{
  background:rgba(255,255,255,.85);
  border-color:rgba(10,20,30,.2);
}

[data-theme="day"] .plex-type-icon svg,
[data-theme="day"] .plex-eye-icon svg{
  fill:transparent;
  stroke:#0b151e;
  stroke-width:1.6;
  stroke-linecap:round;
  stroke-linejoin:round;
}

[data-theme="day"] .plex-modal{
  background:#f7f9fb;
  border-color:rgba(10,20,30,.16);
  box-shadow:0 18px 50px rgba(8,14,20,.18);
}

[data-theme="day"] .plex-modal-header{
  background:linear-gradient(180deg, #eef2f6, #e6ecf2);
  border-bottom:1px solid rgba(10,20,30,.12);
}

[data-theme="day"] .plex-modal-title,
[data-theme="day"] .plex-modal-subtitle,
[data-theme="day"] .plex-modal-meta,
[data-theme="day"] .plex-overview-text{
  color:#0b151e;
}

[data-theme="day"] .plex-modal-hero{
  background:#e8edf3;
  border-color:rgba(10,20,30,.12);
}

[data-theme="day"] .plex-modal-bg{
  opacity:.3;
  filter:saturate(.85) brightness(1.05);
}

[data-theme="day"] .plex-modal-hero::before{
  background:
    radial-gradient(900px 500px at 25% 15%, rgba(74,167,164,.18), transparent 60%),
    linear-gradient(90deg, rgba(246,249,252,.92) 0%, rgba(246,249,252,.78) 38%, rgba(246,249,252,.4) 70%);
}

[data-theme="day"] .plex-modal-poster{
  background:#f1f4f8;
  border-color:rgba(10,20,30,.12);
  box-shadow:0 12px 24px rgba(8,14,20,.12);
}

[data-theme="day"] .plex-overview-text{
  text-shadow:0 1px 0 rgba(255,255,255,.65), 0 2px 8px rgba(0,0,0,.08);
}

[data-theme="day"] .plex-pill2{
  background:rgba(255,255,255,.75);
  border-color:rgba(10,20,30,.12);
  color:#1f2b38;
}

[data-theme="day"] .plex-section{
  border-top:1px solid rgba(10,20,30,.12);
}

[data-theme="day"] .plex-section h4{
  color:#1f2b38;
}

[data-theme="day"] .plex-modal-close{
  background:#f0f4f8;
  border-color:rgba(10,20,30,.2);
  color:#0b151e;
}

[data-theme="day"] .plex-modal-link{
  background:#ffffff;
  border-color:rgba(10,20,30,.15);
  color:#0b151e;
}

[data-theme="day"] .plex-modal-body{
  background:#f2f5f8;
}

[data-theme="day"] .plex-modal-footer{
  background:linear-gradient(180deg, #eef2f6, #e4eaf1);
  border-top:1px solid rgba(10,20,30,.12);
}

[data-theme="day"] .dash-main .settings-head-icon,
[data-theme="day"] .dash-main .settings-expand-icon,
[data-theme="day"] .dash-main .settings-favourite-icon,
[data-theme="day"] .dash-main .field-with-action .icon-button img{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .plex-title .plex-logo[src$=".svg"]{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .plex-title .plex-logo[src$="app-arr.svg"],
[data-theme="day"] .dash-main .settings-element-icon[src$="app-arr.svg"]{
  filter:none;
}

[data-theme="day"] .dash-main .plex-title .plex-logo[src$="download.svg"],
[data-theme="day"] .dash-main .settings-element-icon[src$="download.svg"]{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .plex-mini-icon svg{
  fill:transparent;
  stroke:#0b151e;
}

[data-theme="day"] .dash-main .settings-tab-btn{
  background:#d4dbe3;
  border-color:rgba(10,20,30,.2);
  border-bottom-color:transparent;
  color:#1f2b38;
}
[data-theme="day"] .settings-tab-icon,
[data-theme="day"] .settings-subtab-icon{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .settings-tab-btn.is-active{
  background:#eef2f6;
  border-color:rgba(10,20,30,.22);
  color:#0b151e;
  box-shadow:0 -6px 16px rgba(8,14,20,.08);
}

[data-theme="day"] .dash-main .settings-tab-btn.is-active::after{
  background:#eef2f6;
}

[data-theme="day"] .dash-main .settings-subtab-btn{
  background:#d4dbe3;
  border-color:rgba(10,20,30,.2);
  color:#1f2b38;
}

[data-theme="day"] .dash-main .settings-subtab-btn.is-active{
  background:#f2f5f8;
  border-color:rgba(var(--brand-rgb),.45);
  color:#0b151e;
  box-shadow:0 -4px 10px rgba(var(--brand-rgb),.16), inset 0 1px 0 rgba(var(--brand-rgb),.28);
}

[data-theme="day"] .dash-main .settings-row,
[data-theme="day"] .dash-main .settings-head,
[data-theme="day"] .dash-main .settings-head-label{
  color:#1f2b38;
}

[data-theme="day"] .dash-main .settings-head{
  background:#e1e6ec;
}

[data-theme="day"] .dash-main .panel-header h2,
[data-theme="day"] .dash-main .settings-card-title,
[data-theme="day"] .dash-main .settings-card-sub,
[data-theme="day"] .dash-main .settings-head-label{
  color:#0b151e;
}

[data-theme="day"] .dash-main .settings-icon-card span{
  color:#1f2b38;
}

[data-theme="day"] .dash-main .settings-select,
[data-theme="day"] .dash-main .category-icon-display,
[data-theme="day"] .dash-main .icon-picker-trigger{
  background:#e7ecf1;
  border-color:rgba(10,20,30,.18);
  color:#0b151e;
}

[data-theme="day"] .dash-main .icon-picker-menu{
  background:#f7f9fb;
  border-color:rgba(10,20,30,.15);
  box-shadow:0 10px 20px rgba(8,14,20,.12);
}

[data-theme="day"] .dash-main .icon-picker-option{
  color:#0b151e;
}

[data-theme="day"] .dash-main .icon-picker-option:hover{
  background:rgba(var(--brand-rgb),.12);
}

[data-theme="day"] .dash-main .theme-preset-card{
  background:#e7ecf1;
  border-color:rgba(10,20,30,.18);
  color:#0b151e;
}

[data-theme="day"] .dash-main .theme-preset-card:hover{
  border-color:rgba(var(--brand-rgb),.45);
}

[data-theme="day"] .dash-main .theme-preset-card.is-active{
  border-color:rgba(var(--brand-rgb),.7);
  box-shadow:0 10px 24px rgba(var(--brand-rgb),.18), inset 0 0 0 1px rgba(var(--brand-rgb),.28);
}

[data-theme="day"] .dash-main .icon-picker-icon{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .category-icon-display-img{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .settings-subtab-panel[data-subtab="images"] .settings-card:first-of-type .settings-icon-card img{
  filter:brightness(0) saturate(100%);
}

[data-theme="day"] .dash-main .primary-button{
  background:linear-gradient(135deg, var(--brand-btn-start), var(--brand-btn-mid) 55%, var(--brand-btn-end));
  color:var(--on-brand);
  box-shadow:0 12px 30px rgba(var(--brand-btn-shadow),.24), inset 0 0 0 1px rgba(255,255,255,.28);
}

[data-theme="day"] .dash-main .order-button{
  background:#e7ecf1;
  border-color:rgba(10,20,30,.2);
  color:#1f2b38;
}

.sidebar-toggle.main-toggle{
  margin-right:10px;
  width:30px;
  height:30px;
  min-width:30px;
  min-height:30px;
  flex:0 0 30px;
  background:rgba(8,12,18,.7);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 0 0 1px rgba(var(--brand-rgb),.28);
}

.sidebar-toggle.left-toggle{
  margin-left:8px;
  margin-right:8px;
}

.dash-topbar{
  background:linear-gradient(180deg, #2b313d, #252b36);
  border:1px solid rgba(0,0,0,.55);
  border-radius:10px;
  padding:14px 18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}


.dash-heading h1{margin:0;font-size:24px}
.tag{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.18em;
  padding:4px 8px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:8px;
  color:var(--muted);
  margin-left:10px;
}

.dash-actions{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--muted);
}

.status-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--pill);
  box-shadow:0 0 10px rgba(43,213,111,.6);
}

.status-dot--ok{
  background:#2bd56f;
  box-shadow:0 0 10px rgba(43,213,111,.6);
}

.status-dot--bad{
  background:#ff5b5b;
  box-shadow:0 0 10px rgba(255,91,91,.5);
}

.dash-panel{
  background:linear-gradient(180deg, rgba(20,28,40,.94), rgba(12,18,26,.96));
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.panel-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
}

.panel-header--collapsible{
  margin-bottom:10px;
}

.settings-inline-collapsible{
  margin-top:14px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
}

.settings-inline-toggle{
  margin:0;
}

.settings-inline-watch-config{
  margin-top:10px;
}

.settings-panel-copy{
  display:grid;
  gap:3px;
}

.settings-expand-toggle{
  width:34px;
  height:30px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.2);
  display:grid;
  place-items:center;
  cursor:pointer;
  color:#ffffff;
}

.settings-expand-icon{
  width:16px;
  height:16px;
  display:block;
  filter:brightness(0) invert(1);
  transform:rotate(90deg);
  transition:transform .2s ease;
}

.settings-expand-toggle[aria-expanded="true"] .settings-expand-icon{
  transform:rotate(-90deg);
}

.settings-collapsible{
  overflow:hidden;
  transition:max-height .25s ease, opacity .2s ease, margin-top .2s ease;
  max-height:1400px;
  opacity:1;
  margin-top:8px;
}
.settings-subtab-panel[data-subtab="dashboard"] .settings-inline-collapsible{
  margin-top:1px;
  padding-top:1px;
}
.settings-subtab-panel[data-subtab="dashboard"] .settings-collapsible{
  margin-top:1px;
}

.settings-collapsible.is-collapsed{
  max-height:0;
  opacity:0;
  margin-top:0;
  pointer-events:none;
}

.panel-header h2{margin:0;font-size:16px;letter-spacing:.08em;text-transform:uppercase}
.panel-sub{font-size:12px;color:var(--muted)}

.panel-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:16px;
}

.panel-card{
  padding:16px;
  border-radius:12px;
  background:rgba(10,14,20,.55);
  border:1px solid rgba(255,255,255,.1);
  text-decoration:none;
  display:grid;
  gap:8px;
}

.panel-card-head{
  display:flex;
  align-items:center;
  gap:8px;
}

.panel-card-icon{
  width:20px;
  height:20px;
  flex:0 0 auto;
}

.panel-title{font-weight:700}
.panel-card p{margin:0;color:var(--muted);font-size:12px}
.panel-link{color:var(--teal);font-size:12px;font-weight:700}

/* Settings */
.settings-tabs{
  position:relative;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:16px 0 0;
  padding:8px 10px 0;
  border-radius:12px;
  background:transparent;
  border:0;
  box-shadow:none;
  z-index:5;
}
.settings-debug{
  margin:12px 0;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,72,92,.45);
  background:rgba(255,72,92,.12);
  color:#ffb4bf;
  font-size:12px;
  font-weight:600;
}
.settings-tab-btn{
  position:relative;
  border:1px solid rgba(255,255,255,.16);
  border-bottom-color:transparent;
  background:linear-gradient(180deg, rgba(16,20,26,.95), rgba(8,11,15,.98));
  color:var(--plex-text);
  padding:8px 16px 7px;
  border-radius:12px 12px 0 0;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:none;
  transform:translateY(-1px);
  z-index:0;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.settings-tab-icon{
  width:14px;
  height:14px;
  display:block;
  flex:0 0 auto;
}
.settings-tab-text{
  display:inline;
}
.settings-tab-btn.is-active{
  background:#131a25;
  border-color:rgba(255,255,255,.18);
  border-bottom-color:transparent;
  box-shadow:0 -4px 10px rgba(var(--brand-rgb),.25);
  transform:translateY(2);
  color:#f1f6f8;
  z-index:6;
}
.settings-tab-btn.is-active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  background:#131a25;
}
.settings-tab-panel{
  display:none;
  margin-top:calc(var(--main-window-gap) * -1 - 2px);
  position:relative;
  z-index:2;
}
.settings-tab-panel .dash-panel:first-child{
  box-shadow:none;
}
.settings-tab-panel.is-active{display:block}
.settings-subtabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:8px 0 16px;
}
.settings-subtab-btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(9,18,24,.65);
  color:var(--plex-text);
  padding:8px 14px;
  border-radius:10px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.settings-subtab-icon{
  width:13px;
  height:13px;
  display:block;
  flex:0 0 auto;
}
.settings-subtab-text{
  display:inline;
}
.settings-subtab-btn.is-active{
  background:rgba(15,35,44,.8);
  border-color:rgba(var(--brand-rgb),.45);
  box-shadow:0 -4px 10px rgba(var(--brand-rgb),.16), inset 0 1px 0 rgba(var(--brand-rgb),.22);
}
.settings-subtab-panel{display:none}
.settings-subtab-panel.is-active{display:block}
.app-settings-switcher{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 14px;
}
.app-settings-switcher-btn{
  appearance:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(9,18,24,.6);
  color:var(--text);
  text-decoration:none;
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
  min-height:34px;
  cursor:pointer;
}
.app-settings-switcher-btn:hover{
  border-color:rgba(var(--brand-rgb),.45);
}
.app-settings-switcher-btn.is-active{
  border-color:rgba(var(--brand-rgb),.55);
  box-shadow:0 -4px 10px rgba(var(--brand-rgb),.16);
}
.app-settings-switcher-icon{
  width:16px;
  height:16px;
  min-width:16px;
  min-height:16px;
}
.app-settings-switcher-text{
  display:inline;
}
.app-settings-panel{
  display:none;
  margin-top:12px;
}
.app-settings-panel.is-active{
  display:block;
}
.settings-card--themes{
  display:grid;
  gap:14px;
}
.theme-presets{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:12px;
}
.theme-preset-card{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius:12px;
  color:var(--text);
  text-align:left;
  padding:12px;
  display:grid;
  gap:6px;
  cursor:pointer;
  transition:border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}
.theme-preset-card:hover{
  transform:translateY(-1px);
  border-color:rgba(var(--brand-rgb),.5);
}
.theme-preset-card:focus-visible{
  outline:2px solid rgba(var(--brand-rgb),.65);
  outline-offset:2px;
}
.theme-preset-card.is-active{
  border-color:rgba(var(--brand-rgb),.9);
  box-shadow:0 10px 24px rgba(var(--brand-rgb),.25), inset 0 0 0 1px rgba(var(--brand-rgb),.25);
}
.theme-preset-chip{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.45), transparent 48%), var(--theme-color);
  position:relative;
  overflow:hidden;
}
.theme-preset-name{
  font-weight:700;
}
.theme-preset-meta{
  font-size:12px;
  color:var(--muted);
}
.theme-preset-chip--custom{
  cursor:pointer;
}
.theme-chip-picker{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
  border:0;
  padding:0;
}
.theme-options{
  display:grid;
  gap:8px;
  margin-top:2px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.1);
}
.theme-option{
  justify-content:flex-start;
  gap:10px;
}
.theme-option-copy{
  display:grid;
  gap:2px;
}
.theme-option-copy strong{
  font-size:12px;
  letter-spacing:.03em;
  color:var(--text);
}
.theme-option-copy small{
  font-size:11px;
  color:var(--muted);
}
.icon-picker{
  position:relative;
  min-width:190px;
}
.category-manager-add{
  display:flex;
  gap:10px;
  align-items:center;
  width:100%;
}
.category-manager-input{
  max-width:none;
  width:100%;
  flex:1 1 auto;
}
.category-manager-add .primary-button{
  width:160px;
  padding-left:18px;
  padding-right:18px;
  white-space:nowrap;
}
.category-manager-add .icon-picker{
  min-width:0;
  width:100%;
  flex:0 0 360px;
}
.icon-picker-trigger{
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  justify-content:flex-start;
  padding:10px 12px;
  min-height:38px;
}
.icon-picker-preview img{
  width:16px;
  height:16px;
}
.icon-picker-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  max-height:220px;
  overflow:auto;
  background:#0f1520;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:6px;
  display:none;
  z-index:30;
  box-shadow:0 10px 20px rgba(0,0,0,.4);
}
.icon-picker-menu.is-open{display:block}
.icon-picker-option{
  width:100%;
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 8px;
  border-radius:8px;
  background:transparent;
  border:0;
  color:var(--text);
  text-align:left;
  cursor:pointer;
  font-size:12px;
}
.icon-picker-option:hover{
  background:rgba(var(--brand-rgb),.12);
}
.icon-picker-icon{
  width:16px;
  height:16px;
  filter:brightness(0) invert(1);
}
.settings-form{display:grid;gap:16px}
.settings-log-row{
  display:flex;
  gap:12px;
  align-items:flex-end;
  flex-wrap:wrap;
}
.settings-log-row .field{
  min-width:150px;
  flex:1 1 160px;
}
.settings-log-row .primary-button{
  min-width:170px;
  height:40px;
}
.field{display:grid;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.field input,.field textarea,.field select{
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  padding:10px;
  font-family:"JetBrains Mono", monospace;
  font-size:13px;
}
.field select option,
.settings-select option,
.category-manager-icon-select option{
  background:#0f1520;
  color:#f1f6f8;
}

.field input[type="checkbox"]{
  width:16px;
  height:16px;
  padding:0;
  border-radius:4px;
  accent-color:var(--teal);
}

.settings-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:16px;
}

.settings-table{
  display:grid;
  gap:0;
}
.settings-table--display{
  gap:0;
}

.settings-row{
  display:grid;
  grid-template-columns:minmax(45px, 1.2fr) repeat(3, minmax(32px, .36fr)) minmax(38px, .36fr) minmax(48px, .5fr) minmax(60px, .6fr);
  gap:8px;
  align-items:center;
  padding:5.5px;
  border-radius:10px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
  text-align:center;
}
.settings-row--display{
  grid-template-columns:minmax(180px, 1.5fr) minmax(72px, .38fr) minmax(82px, .42fr) minmax(150px, 1.05fr) minmax(52px, .3fr) minmax(130px, .85fr) minmax(64px, .42fr) minmax(56px, .34fr);
}
.settings-row--display,
.settings-row--categories{
  min-height:38px;
}
.settings-row--display .settings-select{
  height:28px;
  padding:4px 8px;
  max-width:none;
}
.settings-row--categories .category-icon-display{
  height:28px;
  padding:4px 8px;
}
.settings-row--form{
  grid-template-columns:minmax(160px, 1.2fr) minmax(160px, 1fr) minmax(180px, 1.4fr);
  text-align:left;
}
.settings-row--form.settings-head > div{
  justify-content:flex-start;
}
.settings-row--form .settings-cell{
  justify-content:flex-start;
}
.settings-row--form .settings-input,
.settings-row--form .settings-select{
  width:100%;
  max-width:none;
}
.settings-table--custom .settings-row{
  grid-template-columns:minmax(160px, 1.4fr) minmax(120px, .8fr) minmax(60px, .3fr);
  text-align:left;
}
.settings-table--custom .settings-row.settings-head{
  grid-template-columns:minmax(160px, 1.4fr) minmax(120px, .8fr) minmax(60px, .3fr);
}

.settings-row--elements{
  grid-template-columns:minmax(140px, 1.6fr) repeat(2, minmax(36px, .4fr)) 40px;
}
.settings-row--elements.settings-head{
  min-height:38px;
}

.settings-row--with-expand{
  grid-template-columns:minmax(140px, 1.6fr) repeat(2, minmax(36px, .4fr)) 40px;
}

.settings-row--tautulli-cards{
  grid-template-columns:minmax(140px, 1.6fr) repeat(2, minmax(36px, .4fr)) minmax(44px, .4fr) 40px;
}

.settings-row--arr-combine{
  grid-template-columns:minmax(90px, 1.4fr) repeat(3, minmax(44px, .44fr));
}
.settings-row--arr-combine > :first-child{
  padding-left:6px;
}
.settings-row--arr-combine .settings-app{
  justify-content:flex-start;
}
.settings-row--arr-combine .settings-app .app-icon{
  width:18px;
  height:18px;
  object-fit:contain;
}

.settings-table--categories{
  gap:0;
}

.settings-row--categories{
  grid-template-columns:minmax(150px, 1.5fr) minmax(96px, .8fr) minmax(80px, .6fr) minmax(70px, .4fr) minmax(50px, .35fr);
}

.settings-app--category{
  justify-content:flex-start;
  gap:10px;
}

.category-icon-preview{
  width:18px;
  height:18px;
}

.category-icon-input{
  width:100%;
  padding:6px 8px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  font-size:12px;
}
.category-icon-display{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 8px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  font-size:12px;
  overflow:hidden;
  width:180px;
}
.category-icon-display-img{
  width:16px;
  height:16px;
  flex:0 0 auto;
}
.category-icon-display-text{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.settings-app-name--category{
  display:inline;
}

.category-drag-handle{
  cursor:grab;
  font-size:14px;
  letter-spacing:0;
}

.category-row{
  transition:border-color .15s ease, background .15s ease;
}

.category-row:hover{
  border-color:rgba(255,255,255,.2);
}

.category-row--dragging{
  opacity:.6;
  border-color:rgba(var(--brand-rgb),.55);
  background:rgba(var(--brand-rgb),.12);
}

.category-delete-button{
  width:44px;
  height:28px;
  min-width:44px;
  min-height:28px;
  font-size:36px;
  font-weight:800;
  line-height:1;
  border-radius:8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}

.custom-app-delete{
  width:44px;
  height:28px;
  min-width:44px;
  min-height:28px;
  font-size:36px;
  font-weight:800;
  line-height:1;
  border-radius:8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}

.category-delete-button:disabled{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  color:var(--muted);
}
.category-row[data-default="true"] .category-delete-button{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  color:var(--muted);
}
.custom-app-delete:disabled{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  color:var(--muted);
}
.category-edit-button:disabled{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  color:var(--muted);
}

.category-manager-add{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:nowrap;
  width:100%;
}

.category-manager-input{
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  padding:10px;
  font-family:"JetBrains Mono", monospace;
  font-size:12px;
  flex:1 1 auto;
  width:100%;
  max-width:none;
}
.category-manager-add .icon-picker{
  flex:0 0 200px;
  width:200px;
}
.app-manager-add .app-manager-select{
  flex:0 0 200px;
  width:200px;
}
.category-manager-add .primary-button{
  flex:0 0 160px;
  width:160px;
}
.category-edit-button{
  padding:0 10px;
  width:auto;
  min-width:44px;
  height:28px;
  min-height:28px;
  border-radius:8px;
  text-align:center;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.custom-app-edit{
  padding:0 10px;
  width:auto;
  min-width:44px;
  height:28px;
  min-height:28px;
  border-radius:8px;
  text-align:center;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.custom-app-edit:disabled{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  color:var(--muted);
}
.category-manager-add .icon-picker-trigger{
  max-width:none;
}

.settings-users-note--error{
  color:#ff9e9e;
}

.settings-cell--blank{
  opacity:.15;
}

.settings-expand-cell{
  justify-content:center;
}

.settings-element{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:600;
}
.settings-element-name{
  display:block;
  font-weight:600;
}
.settings-element-icon{
  width:18px;
  height:18px;
  object-fit:contain;
}

.settings-element-icon[src$="app-arr.svg"]{
  filter:none;
}
.settings-favourite-input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.settings-favourite-toggle{
  width:30px;
  height:30px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(0,0,0,.2);
  display:grid;
  place-items:center;
  cursor:pointer;
  padding:0;
}
.settings-favourite-toggle.is-active{
  border-color:rgba(var(--brand-rgb),.4);
  box-shadow:0 0 0 1px rgba(var(--brand-rgb),.2) inset;
}
.settings-favourite-icon{
  width:16px;
  height:16px;
  display:block;
}
.settings-row--elements.is-muted{
  opacity:.6;
}
.settings-row--elements.is-disabled{
  opacity:.35;
}
.settings-row--elements.is-inactive{
  opacity:.5;
}
.settings-row--display.is-disabled{
  opacity:.35;
}

.settings-head{
  background:rgba(0,0,0,.3);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:700;
}

.settings-head > div{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.settings-table .settings-row > :first-child{
  justify-content:flex-start;
  text-align:left;
}

.settings-table .settings-row.settings-head > :first-child{
  padding-left:6px;
}

.settings-row.settings-row--display.settings-head > :nth-child(2),
.settings-row.settings-row--display.settings-head > :nth-child(3){
  justify-content:flex-start;
  padding-left:8px;
}

.settings-head-icon{
  width:18px;
  height:18px;
  display:block;
  color:#fff;
}
.settings-head-icon[src$="collapse.svg"]{
  filter:brightness(0) invert(1);
}

.settings-head-label{
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}

.settings-tip{
  display:inline-grid;
  place-items:center;
  width:14px;
  height:14px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.28);
  color:var(--muted);
  font-size:9px;
  line-height:1;
  cursor:help;
}

.settings-app{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:center;
  font-weight:600;
}

.settings-app--draggable{
  justify-content:flex-start;
  text-align:left;
}

.settings-cell{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:center;
}

.settings-cell--launch{
  justify-content:flex-start;
}

.settings-cell--launch .settings-select{
  flex:1 1 auto;
}

.settings-cell input{
  margin:0 auto;
}

.settings-radio{
  width:16px;
  height:16px;
  margin:0;
  border-radius:50%;
  accent-color:var(--teal);
}

.settings-select{
  width:100%;
  max-width:170px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  padding:6px 8px;
  font-family:"JetBrains Mono", monospace;
  font-size:12px;
}

.settings-order-cell{
  justify-content:center;
}

.settings-order-controls{
  display:grid;
  grid-template-columns:repeat(4, 26px);
  gap:3px;
}

.settings-order-controls--drag{
  grid-template-columns:26px;
}

.order-button{
  width:26px;
  height:22px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.25);
  color:var(--text);
  font-size:11px;
  font-weight:700;
  line-height:1;
  cursor:pointer;
}

.settings-drag-handle{
  cursor:grab;
  font-size:14px;
  letter-spacing:0;
}
.category-drag-handle{
  cursor:grab;
  font-size:14px;
  letter-spacing:0;
}

.settings-drag-handle--app{
  flex:0 0 auto;
}

.settings-row--dragging{
  opacity:.6;
  border-color:rgba(var(--brand-rgb),.55);
  background:rgba(var(--brand-rgb),.12);
}

.settings-order-rank{
  font-weight:700;
  font-size:13px;
}

.order-button:hover{
  border-color:rgba(255,255,255,.35);
  background:rgba(0,0,0,.35);
}

.launch-frame-panel{
  padding:0;
  min-height:calc(100vh - 130px);
  overflow:hidden;
  position:relative;
  border:0;
  border-radius:0;
  box-shadow:none;
  background:transparent;
}

.launch-frame{
  display:block;
  width:100%;
  min-height:calc(100vh - 130px);
  border:0;
  border-radius:0;
  background:rgba(0,0,0,.35);
}

.dash-body.launch-page .dash-main{
  grid-template-rows:auto 1fr;
  overflow:hidden;
  --main-window-gap:0;
  --main-window-pad-bottom:0;
  gap:0;
  padding:0;
}
.dash-body.launch-page .main-window-bar{
  margin:0;
  border-radius:0;
}
.dash-body.launch-page .launch-frame-panel{
  min-height:0;
  height:100%;
  background:#0b1118;
}
.dash-body.launch-page .launch-frame{
  min-height:0;
  height:100%;
  background:#0b1118;
}

.launch-frame-overlay{
  position:absolute;
  inset:0;
  display:none;
  z-index:2;
  background:transparent;
}

body.mobile-nav-open .launch-frame-overlay{
  display:block;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

input[type="checkbox"]{
  accent-color:var(--teal);
}

.radio-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(0,0,0,.4);
  font-size:11px;
}

.radio-pill input{
  margin:0;
}

.settings-card{
  background:rgba(0,0,0,.2);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  padding:14px;
  display:grid;
  gap:10px;
}
.settings-card-fields{
  border:0;
  padding:0;
  margin:0;
  min-inline-size:0;
  display:grid;
  gap:10px;
}
.settings-combined-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(160px, 1fr));
  gap:10px 14px;
}
.settings-combined-grid--arr{
  grid-template-columns:repeat(4, minmax(120px, 1fr));
}
.settings-combined-item{
  padding:5px 8px;
  font-size:11px;
}
.settings-combined-icon{
  width:16px;
  height:16px;
}
.settings-combined-item{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.2);
  font-size:12px;
  color:var(--text);
}
.settings-combined-item input{
  margin-left:auto;
}
.settings-combined-icon{
  width:18px;
  height:18px;
  object-fit:contain;
}
.settings-combined-name{
  white-space:nowrap;
}
.settings-subtab-panel[data-subtab="dashboard"] .settings-inline-collapsible .settings-card{
  width:100%;
  max-width:none;
}
.settings-subtab-panel[data-subtab="dashboard"] .settings-inline-collapsible .settings-grid{
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
}

.settings-card-lines{
  display:grid;
  gap:6px;
}

.settings-row--images-upload{
  grid-template-columns:minmax(200px, 1fr) minmax(240px, 1fr) minmax(120px, .4fr);
  align-items:center;
  text-align:left;
}
.settings-icon-name{
  width:100%;
  height:40px;
}
.settings-icon-file{
  padding:6px 6px;
  height:40px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--muted);
  font-size:12px;
  font-family:"JetBrains Mono", monospace;
}
.settings-icon-file::file-selector-button{
  margin-right:10px;
  padding:6px 10px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(15,35,44,.8);
  color:var(--text);
  font-size:12px;
  cursor:pointer;
}
.settings-icon-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));
  gap:10px;
}
.settings-icon-card{
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.2);
  display:grid;
  gap:6px;
  justify-items:start;
}
.settings-icon-card img{
  width:24px;
  height:24px;
  object-fit:contain;
}
.settings-icon-card span{
  font-size:11px;
  color:var(--muted);
  word-break:break-word;
}
.settings-icon-card--custom{
  position:relative;
}
.settings-icon-card--custom form{
  position:absolute;
  top:6px;
  right:6px;
}

.settings-card-line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:12px;
  color:var(--text);
}

.settings-card-line span{
  color:var(--muted);
  font-size:11px;
}

.settings-card-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.settings-access-form{
  margin-top:6px;
}

.settings-access-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.settings-toggle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
}

.settings-toggle input{
  position:absolute;
  opacity:0;
  width:0;
  height:0;
}

.settings-toggle-slider{
  position:relative;
  width:42px;
  height:22px;
  border-radius:999px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.12);
  transition:background .2s ease, border-color .2s ease;
}

.settings-toggle-slider::before{
  content:"";
  position:absolute;
  top:1px;
  left:2px;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#c7d0e0;
  box-shadow:0 2px 6px rgba(0,0,0,.45);
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.settings-toggle input:checked + .settings-toggle-slider{
  background:rgba(var(--brand-rgb),.3);
  border-color:rgba(var(--brand-rgb),.6);
}

.settings-toggle input:checked + .settings-toggle-slider::before{
  transform:translateX(20px);
  background:var(--teal);
  box-shadow:0 0 10px rgba(var(--brand-rgb),.45);
}

.settings-toggle-text{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--muted);
}

.settings-users{
  gap:14px;
}

.settings-users-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.settings-users-actions .primary-button{
  flex:1 1 calc(50% - 5px);
  width:calc(50% - 5px);
}

.settings-users-actions .settings-users-note{
  flex-basis:100%;
}

.settings-users-note{
  font-size:11px;
  color:var(--muted);
}

.settings-users-table{
  display:grid;
  gap:6px;
}

.settings-users-row{
  display:grid;
  grid-template-columns:minmax(180px, 1.3fr) minmax(140px, 1fr) minmax(140px, 1fr) 180px;
  gap:10px;
  align-items:center;
  padding:6px 10px;
  border-radius:8px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
}

.settings-users-row > :first-child{
  text-align:left;
}

.settings-users-head{
  background:rgba(0,0,0,.3);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:700;
}

.settings-users-head-cell{
  display:flex;
  align-items:center;
  gap:6px;
}

.settings-users-head-cell[data-sort-key]{
  cursor:pointer;
  user-select:none;
}

.settings-users-head-cell[data-sort-key]::after{
  content:'';
  margin-left:6px;
  font-size:9px;
  color:currentColor;
  opacity:0;
}

.settings-users-head-cell[data-sort-dir="asc"]::after{
  content:'▲';
  opacity:.55;
}

.settings-users-head-cell[data-sort-dir="desc"]::after{
  content:'▼';
  opacity:.55;
}

.settings-users-name{
  font-weight:600;
  font-size:12px;
}

.settings-users-login{
  font-size:11px;
  color:var(--muted);
  font-family:"JetBrains Mono", monospace;
}

.settings-users-role{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:flex-start;
}

.settings-users-role select{
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.2);
  color:var(--text);
  padding:6px 8px;
  font-family:"JetBrains Mono", monospace;
  font-size:11px;
  min-height:30px;
}

.settings-role-inline-form{
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
}

.settings-role-inline-form select{
  flex:1 1 auto;
  min-width:0;
}

.settings-role-inline-form .primary-button{
  min-height:30px;
  padding:0 12px;
}

.settings-users-locked{
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.12em;
  padding:3px 6px;
  border-radius:999px;
  background:rgba(var(--brand-rgb),.16);
  border:1px solid rgba(var(--brand-rgb),.35);
  color:#c6f1ef;
  font-weight:700;
}

.settings-card-title{
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text);
}

.settings-card-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:-4px;
  margin-bottom:4px;
}

.plex-settings-body{
  background:
    radial-gradient(circle at 18% 10%, rgba(255,158,56,.18), transparent 45%),
    radial-gradient(circle at 80% 20%, rgba(74,167,164,.16), transparent 40%),
    linear-gradient(140deg, #12151c, #0d1118);
}

.plex-settings-panel{
  padding:18px;
  border-color:rgba(0,0,0,.6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03), 0 18px 32px rgba(0,0,0,.45);
}

.plex-settings-banner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px;
  border-radius:12px;
  background:linear-gradient(135deg, #2b313d, #1f2530);
  border:1px solid rgba(255,255,255,.08);
  margin-bottom:16px;
}

.plex-settings-brand{
  display:flex;
  align-items:center;
  gap:12px;
}

.plex-settings-logo{
  width:44px;
  height:44px;
  border-radius:10px;
  background:rgba(255,149,0,.16);
  border:1px solid rgba(255,149,0,.45);
  padding:6px;
  box-shadow:inset 0 0 0 2px rgba(255,149,0,.12);
}

.plex-settings-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  filter:saturate(1.1);
}

.plex-settings-title{
  font-weight:800;
  font-size:16px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.plex-settings-sub{
  font-size:12px;
  color:var(--muted);
  max-width:360px;
}

.plex-settings-hint{
  font-size:11px;
  color:var(--teal);
  font-weight:700;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(var(--brand-rgb),.12);
  border:1px solid rgba(var(--brand-rgb),.4);
  white-space:nowrap;
}

.plex-settings-card{
  background:linear-gradient(180deg, rgba(24,30,39,.92), rgba(16,20,28,.92));
  border-color:rgba(var(--brand-rgb),.35);
}

.plex-settings-fields{
  display:grid;
  gap:10px;
}

.plex-settings-note{
  font-size:11px;
  color:var(--teal);
  background:rgba(var(--brand-rgb),.12);
  border:1px solid rgba(var(--brand-rgb),.32);
  padding:8px 10px;
  border-radius:10px;
}

@media (max-width: 720px){
  .plex-settings-banner{
    flex-direction:column;
    align-items:flex-start;
  }
  .plex-settings-hint{
    white-space:normal;
  }
  .settings-tab-btn,
  .settings-subtab-btn{
    min-width:40px;
    justify-content:center;
    padding-left:10px;
    padding-right:10px;
  }
  .settings-tab-text,
  .settings-subtab-text{
    display:none;
  }
  .app-settings-switcher{
    gap:6px;
  }
  .app-settings-switcher-btn{
    width:34px;
    min-width:34px;
    height:34px;
    min-height:34px;
    padding:0;
    justify-content:center;
    border-radius:9px;
  }
  .app-settings-switcher-icon{
    width:18px;
    height:18px;
    min-width:18px;
    min-height:18px;
  }
  .app-settings-switcher-text{
    display:none;
  }
  .settings-tab-icon{
    width:16px;
    height:16px;
  }
  .settings-subtab-icon{
    width:15px;
    height:15px;
  }
  .settings-card--themes{
    gap:10px;
  }
  .theme-presets{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:8px;
  }
  .theme-preset-card{
    padding:10px;
    border-radius:10px;
    gap:4px;
    min-width:0;
  }
  .theme-preset-chip{
    width:24px;
    height:24px;
  }
  .theme-preset-name{
    font-size:14px;
  }
  .theme-preset-meta{
    font-size:11px;
  }
  .category-delete-button,
  .custom-app-delete{
    width:44px;
    height:28px;
    min-width:44px;
    min-height:28px;
    font-size:36px;
    font-weight:800;
    line-height:1;
    border-radius:8px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0;
  }
  .category-edit-button,
  .custom-app-edit{
    min-width:44px;
    height:28px;
    min-height:28px;
    border-radius:8px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0 10px;
  }
}

@media (max-width: 980px){
  .dash-body{
    overflow-y:auto;
    overflow-x:hidden;
  }
  .dash-frame{
    grid-template-columns:1fr;
    width:100vw;
    height:auto;
    min-height:100vh;
    min-height:100svh;
    min-height:100dvh;
    position:relative;
    max-width:100vw;
    margin:0;
    padding:0;
    border:0;
    border-radius:0;
    box-shadow:none;
    background:transparent;
    overflow-x:hidden;
  }
  .dash-frame.sidebar-collapsed{
    grid-template-columns:1fr;
  }
  .dash-sidebar{
    min-height:auto;
    position:fixed;
    left:0;
    top:0;
    height:100vh;
    height:100svh;
    height:100dvh;
    width:49vw;
    max-width:420px;
    transform:translateX(calc(-100% - 24px));
    transition:transform .25s ease;
    border-radius:0 12px 12px 0;
    z-index:1000;
    box-shadow:12px 0 24px rgba(0,0,0,.35);
    overflow:hidden;
  }
  .dash-frame.mobile-nav-open .dash-sidebar{
    transform:translateX(0);
  }
  .dash-body.mobile-nav-open{
    overflow:hidden;
  }
  .dash-frame.mobile-nav-open .dash-sidebar{
    overflow-y:hidden;
  }
  .dash-nav{
    overflow-y:auto;
    flex:1;
  }
  .dash-user{
    position:sticky;
    bottom:0;
    margin-top:auto;
    padding-bottom:calc(8px + env(safe-area-inset-bottom, 0px));
    box-shadow:0 -1px 0 rgba(0,0,0,.35);
  }
  .dash-main{
    overflow-y:visible;
    overflow-x:hidden;
    overflow-x:clip;
  }
  .dash-main{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:0 2px 2px;
    border-radius:0;
    padding-top:48px;
  }
  .dash-body.launch-page .dash-main{
    padding:48px 0 0;
    overflow:hidden;
  }
  .dash-body.launch-page .launch-frame-panel{
    margin:0;
    width:100%;
    max-width:100%;
    height:calc(100dvh - 48px);
    min-height:calc(100dvh - 48px);
    border:0;
    border-radius:0;
    box-shadow:none;
  }
  .dash-body.launch-page .launch-frame{
    width:100%;
    height:100%;
    min-height:0;
  }
  .main-window-bar{
    position:fixed;
    top:0;
    left:0;
    right:0;
    margin:0;
    border-radius:0;
    height:48px;
    z-index:1100;
    transition:none;
  }
  .sidebar-toggle.main-toggle{
    width:30px;
    height:30px;
    min-width:30px;
    min-height:30px;
    flex:0 0 30px;
    margin-right:6px;
  }
  .main-window-title{
    flex:1 1 auto;
    min-width:0;
    padding:0 6px 0 2px;
    gap:6px;
    overflow:hidden;
    white-space:nowrap;
  }
  .main-window-app{
    flex:0 0 auto;
    white-space:nowrap;
  }
  .main-window-rest{
    flex:1 1 auto;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .main-window-status{
    flex:0 0 auto;
    margin-right:6px;
    gap:6px;
  }
  .version-badge{
    gap:4px;
  }
  .version-pill{
    max-width:88px;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .theme-toggle{
    flex:0 0 28px;
  }
  .dash-frame.mobile-nav-open .main-window-bar{
    left:0;
    right:0;
    transform:none;
    z-index:900;
  }
  .settings-app-name{
    display:none;
  }
  .settings-head-label{
    display:none;
  }
  .settings-row{
    grid-template-columns:minmax(10px, .8fr) repeat(3, minmax(28px, .3fr)) minmax(30px, .3fr) minmax(44px, .5fr) minmax(48px, .6fr);
    gap:5px;
    padding:5px;
  }
  .settings-row--elements{
    grid-template-columns:minmax(0, 1fr) 28px 28px 40px;
    gap:4px;
  }
  .settings-row--with-expand{
    grid-template-columns:minmax(0, 1fr) 28px 28px 40px;
    gap:4px;
  }
  .settings-row--tautulli-cards{
    grid-template-columns:minmax(0, 1fr) 28px 28px 40px;
    gap:4px;
  }
  .settings-row--arr-combine{
    grid-template-columns:minmax(45px, .9fr) repeat(3, minmax(28px, .3fr));
  }
  .settings-row--display{
    grid-template-columns:22px 22px 22px minmax(0, 1.15fr) 30px minmax(0, 1fr) 44px 28px;
    gap:1px;
    padding:4px 3px;
  }
  .settings-row--display > *{
    min-width:0;
    justify-content:center;
    text-align:center;
  }
  .settings-row--display > :first-child{
    justify-content:center;
    text-align:center;
    padding-left:0;
  }
  .settings-row.settings-row--display.settings-head > :first-child{
    padding-left:0;
  }
  .settings-row--display .settings-app{
    gap:0;
  }
  .settings-row--display .settings-app--draggable{
    justify-content:center;
  }
  .settings-row--display .settings-app .app-icon{
    width:20px;
    height:20px;
    min-width:20px;
    min-height:20px;
    display:block;
  }
  .settings-row--display .settings-drag-handle--app{
    display:none;
  }
  .settings-row--display .settings-select{
    width:100%;
    min-width:0;
    max-width:none;
  }
  .settings-row--display .settings-cell{
    min-width:0;
    gap:2px;
  }
  .settings-row--display .settings-cell input{
    width:20px;
    height:20px;
    min-width:20px;
    min-height:20px;
    margin:0;
    padding:2px;
  }
  .settings-row--display .settings-cell .settings-radio{
    width:20px;
    height:20px;
    min-width:20px;
    min-height:20px;
  }
  .settings-row--display .settings-cell--launch{
    gap:2px;
    min-width:0;
  }
  .settings-row--display .settings-cell .category-edit-button,
  .settings-row--display .settings-cell .custom-app-edit{
    width:100%;
    min-width:0;
    height:28px;
    padding:0 4px;
    font-size:13px;
  }
  .settings-row--display .settings-cell .category-delete-button,
  .settings-row--display .settings-cell .custom-app-delete{
    width:100%;
    min-width:0;
    height:28px;
    font-size:24px;
    padding:0;
  }
  .settings-table input[type="checkbox"]{
    width:20px;
    height:20px;
    min-width:20px;
    min-height:20px;
    margin:0;
    padding:2px;
  }
  .settings-table .category-edit-button,
  .settings-table .custom-app-edit,
  .settings-table .category-delete-button,
  .settings-table .custom-app-delete{
    height:28px;
    min-height:28px;
    border-radius:8px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .settings-table .category-edit-button,
  .settings-table .custom-app-edit{
    min-width:44px;
    padding:0 8px;
    font-size:13px;
  }
  .settings-table .category-delete-button,
  .settings-table .custom-app-delete{
    width:28px;
    min-width:28px;
    padding:0;
    font-size:24px;
    line-height:1;
    font-weight:800;
  }
  .settings-row--categories{
    grid-template-columns:minmax(80px, 1fr) minmax(72px, .7fr) minmax(44px, .35fr) minmax(40px, .3fr) minmax(30px, .25fr);
  }
  .settings-row--form{
    grid-template-columns:repeat(3, minmax(80px, 1fr));
  }
  .settings-table--custom .settings-row{
    grid-template-columns:minmax(90px, 1fr) minmax(60px, .6fr) minmax(30px, .3fr);
  }
  .settings-app-name--category{
    display:inline;
    font-size:11px;
  }
  .category-manager-add{
    display:flex;
    flex-wrap:wrap;
  }
  .app-manager-add{
    display:grid;
    grid-template-columns:minmax(92px, .75fr) minmax(0, 1fr) minmax(132px, .9fr);
    gap:8px;
    align-items:stretch;
  }
  .app-manager-add #customAppName{
    grid-column:1 / -1;
  }
  .app-manager-add #customAppCategory,
  .app-manager-add [data-app-icon-picker],
  .app-manager-add #customAppSubmit{
    grid-row:2;
    min-width:0;
  }
  .app-manager-add #customAppCategory,
  .app-manager-add .icon-picker-trigger,
  .app-manager-add #customAppSubmit{
    height:44px;
    min-height:44px;
  }
  .app-manager-add #customAppCategory,
  .app-manager-add .icon-picker-trigger{
    max-width:none;
    width:100%;
  }
  .app-manager-add #customAppSubmit{
    width:100%;
    min-width:0;
    padding-left:10px;
    padding-right:10px;
  }
  .app-manager-add [data-app-icon-picker]{
    width:100%;
  }
  .app-manager-add [data-app-icon-picker] .icon-picker-trigger{
    width:100%;
    justify-content:flex-start;
  }
  .settings-row--images-upload{
    grid-template-columns:minmax(0, 1.7fr) minmax(0, 1.2fr) 96px;
    gap:8px;
    align-items:stretch;
  }
  .settings-row--images-upload .settings-icon-file,
  .settings-row--images-upload .settings-icon-name,
  .settings-row--images-upload .primary-button{
    width:100%;
    height:44px;
    min-height:44px;
    min-width:0;
    box-sizing:border-box;
  }
  .settings-row--images-upload .settings-icon-file{
    padding:4px 6px;
  }
  .settings-row--images-upload .settings-icon-file::file-selector-button{
    height:32px;
    padding:0 10px;
    margin-right:8px;
  }
  .settings-row--images-upload .primary-button{
    width:100%;
    justify-self:stretch;
  }
  .settings-users-actions{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
    align-items:stretch;
  }
  .settings-users-actions .primary-button{
    width:100%;
    min-width:0;
    flex:initial;
  }
  .settings-users-actions .settings-users-note{
    grid-column:1 / -1;
  }
  .settings-log-row{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(0, .95fr) 108px minmax(96px, 1fr);
    gap:8px;
    align-items:end;
  }
  .settings-log-row .field{
    min-width:0;
    width:100%;
  }
  .settings-log-row .primary-button{
    min-width:0;
    width:100%;
    height:40px;
  }
  .settings-log-row .log-status{
    min-width:0;
    white-space:nowrap;
    text-align:right;
    font-size:11px;
    line-height:1.2;
  }
  .log-toolbar{
    display:flex;
    gap:8px;
    align-items:end;
  }
  .log-filter{
    min-width:0;
    display:grid;
    grid-template-columns:auto minmax(0, 1fr);
    gap:8px;
    align-items:center;
    flex:1 1 0;
  }
  .log-filter .settings-select{
    width:100%;
    max-width:none;
  }
  .log-refresh{
    width:84px;
    min-width:0;
    margin-left:auto;
    justify-self:auto;
    height:36px;
    min-height:36px;
    padding:0 8px;
    font-size:12px;
    flex:0 0 auto;
  }
  .log-toolbar .log-status{
    display:none;
  }
  .settings-users-row{
    grid-template-columns:minmax(112px, 1.1fr) minmax(86px, .85fr) minmax(86px, .85fr) minmax(74px, .72fr);
    gap:6px;
    padding:6px 8px;
  }
  .settings-users-head{
    font-size:10px;
    letter-spacing:.1em;
  }
  .settings-users-name{
    font-size:11px;
  }
  .settings-users-login{
    font-size:10px;
  }
  .settings-users-role select{
    min-width:0;
    width:100%;
    font-size:10px;
    padding:5px 6px;
    min-height:28px;
  }
  .settings-role-inline-form{
    flex-direction:column;
    align-items:stretch;
    gap:6px;
  }
  .settings-role-inline-form .primary-button{
    width:100%;
    min-height:28px;
    padding:0 8px;
  }
  .settings-select{
    max-width:130px;
  }
  .settings-order-controls{
    grid-template-columns:repeat(4, 22px);
    gap:2px;
  }
  .settings-order-controls--drag{
    grid-template-columns:22px;
  }
  .order-button{
    width:22px;
    height:20px;
    font-size:10px;
  }
  .order-button[data-action="top"],
  .order-button[data-action="bottom"]{
    display:none;
  }
  .settings-order-controls{
    grid-template-columns:repeat(2, 22px);
  }
  #tautulliStatsPrevBtn,
  #tautulliStatsNextBtn{
    display:none;
  }
  .plex-iconbtn[id$="PrevBtn"],
  .plex-iconbtn[id$="NextBtn"]{
    display:none;
  }
}

/* Plex overview (scoped) */
.plex-overview{
  --plex-teal:var(--teal);
  --plex-text:#e8eef7;
  --plex-muted:#b7c0cf;
  --plex-pill:#2bd56f;
  --plex-panel1:#2f3640;
  --plex-panel2:#262c36;
  --plex-ink:var(--on-brand);
  --plex-cardW:203;
  --plex-gap:24;
  --plex-cardTextScale:.7;
  --plex-posterH:266;
  --plex-footerH:48;
  --plex-cardH:350;
  display:grid;
  align-content:start;
  justify-content:stretch;
  grid-auto-rows:max-content;
  gap:6px;
  min-width:0;
  overflow-x:hidden;
  overflow-y:visible;
  width:100%;
  padding-bottom:2px;
}

.plex-module{margin:0}
.plex-module{min-width:0;max-width:100%}
.plex-module--no-subtitle .plex-subtitle{display:none}

.plex-topbar{
  display:flex;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:0;
  padding:10px 12px;
  background:var(--plex-panel1);
  border:1px solid rgba(0,0,0,.45);
  border-radius:10px;
  width:100%;
  max-width:100%;
}
.plex-title-wrap{display:flex;flex-direction:column;gap:6px}
.plex-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--plex-ink);
  text-shadow:0 2px 0 rgba(0,0,0,.35);
  line-height:1;
}
[data-theme="night"] .plex-title{
  color:#e8eef7;
}
.plex-subtitle{font-weight:600;color:rgba(232,238,247,.78);line-height:1.1}
.plex-logo{
  width:16px;
  height:16px;
  display:block;
  flex:0 0 16px;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));
  object-fit:contain;
}
.plex-spacer{flex:1}
.plex-controls-right{
  display:flex;
  align-items:center;
  gap:12px;
  margin-left:auto;
  flex-wrap:wrap;
  justify-content:flex-end;
  max-width:100%;
}
.plex-search{
  display:flex;
  align-items:center;
  gap:8px;
  padding:4px 6px;
  background:rgba(9,13,20,.7);
  border:2px solid #111;
  border-radius:6px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.08);
}
.plex-search input{
  background:transparent;
  border:none;
  outline:none;
  color:var(--plex-text);
  font-size:12px;
  font-weight:600;
  min-width:180px;
}
.plex-search input::placeholder{color:rgba(232,238,247,.6)}
.plex-search-btn{
  background:var(--plex-teal);
  border:2px solid #111;
  border-radius:6px;
  color:var(--plex-ink);
  font-weight:700;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:6px 10px;
  cursor:pointer;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
}
.plex-search-btn:disabled{opacity:.5;cursor:not-allowed;filter:saturate(.6)}
.plex-select{
  position:relative;
  display:inline-flex;
  align-items:center;
  background:var(--plex-teal);
  border:2px solid #111;
  border-radius:6px;
  height:32px;
  padding:0 30px 0 10px;
  color:var(--plex-ink);
  font-weight:700;
  font-size:12px;
  min-width:110px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
}
.plex-select.plex-icon{
  min-width:96px;
  padding-left:30px;
}
.plex-select.plex-xsmall{min-width:60px}
.plex-select select{
  appearance:none;border:none;background:transparent;outline:none;
  font:inherit;color:inherit;width:100%;cursor:pointer;
  line-height:1;
  color-scheme:dark;
}

.plex-select select option{
  background:#141b25;
  color:#e8eef7;
}
.plex-select:after{
  content:"";
  position:absolute;right:10px;top:50%;
  width:8px;height:8px;margin-top:-5px;
  border-right:2px solid var(--plex-ink);
  border-bottom:2px solid var(--plex-ink);
  transform:rotate(45deg);
  opacity:.9;
  pointer-events:none;
}

.plex-select.plex-icon:before{
  content:"";
  position:absolute;
  left:8px;
  top:50%;
  width:14px;
  height:14px;
  transform:translateY(-50%);
  background-repeat:no-repeat;
  background-size:14px 14px;
  background-position:center;
  pointer-events:none;
}

.plex-select.plex-icon.plex-filter-media:before{background-image:url('/icons/all-type.svg');}
.plex-select.plex-icon.plex-filter-media[data-filter-value="all"]:before{background-image:url('/icons/all-type.svg');}
.plex-select.plex-icon.plex-filter-media[data-filter-value="movie"]:before{background-image:url('/icons/movie.svg');}
.plex-select.plex-icon.plex-filter-media[data-filter-value="tv"]:before,
.plex-select.plex-icon.plex-filter-media[data-filter-value="show"]:before{background-image:url('/icons/tv.svg');}
.plex-select.plex-icon.plex-filter-media[data-filter-value="music"]:before{background-image:url('/icons/music.svg');}
.plex-select.plex-icon.plex-filter-media[data-filter-value="book"]:before{background-image:url('/icons/book.svg');}
.plex-select.plex-icon.plex-filter-window:before{background-image:url('/icons/window.svg');}
.plex-select.plex-icon.plex-filter-status:before{background-image:url('/icons/status.svg');}
.plex-select.plex-icon.plex-filter-event:before{background-image:url('/icons/activity-queue.svg');}

.plex-panel{
  background:linear-gradient(180deg,var(--plex-panel1),var(--plex-panel2));
  border:1px solid rgba(0,0,0,.45);
  border-radius:10px;
  padding:5px;
  box-shadow:none;
  position:relative;
  overflow:hidden;
  min-width:0;
  max-width:100%;
}
.prowlarr-table{
  display:grid;
  gap:8px;
  padding:10px;
  overflow-x:auto;
}
.prowlarr-results{
  display:grid;
  gap:8px;
}
.prowlarr-row{
  display:grid;
  grid-template-columns:minmax(220px, 2fr) 120px 120px 110px 120px;
  gap:12px;
  align-items:center;
  min-width:640px;
  background:rgba(7,12,20,.75);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  padding:10px 12px;
  box-shadow:0 6px 14px rgba(0,0,0,.35);
  font-size:12px;
  color:var(--plex-text);
}
.prowlarr-row--head{
  background:rgba(20,28,40,.85);
  border-color:rgba(255,255,255,.15);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  font-size:11px;
}
.prowlarr-row--empty{
  grid-template-columns:1fr;
  justify-items:center;
  color:var(--plex-muted);
}
.prowlarr-result-title{
  font-weight:700;
  color:var(--plex-text);
  font-size:14px;
}
.prowlarr-result-meta{
  margin-top:4px;
  color:var(--plex-muted);
  font-size:12px;
}
.prowlarr-result-link{
  color:var(--plex-teal);
  font-weight:700;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  text-decoration:none;
}
.prowlarr-result-link:hover{color:#7be1dc}
.prowlarr-download-btn{
  background:var(--plex-teal);
  border:2px solid #111;
  border-radius:6px;
  color:var(--plex-ink);
  font-weight:700;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:6px 10px;
  cursor:pointer;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
}
.prowlarr-download-btn:disabled{opacity:.6;cursor:not-allowed}
.prowlarr-pagination{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.prowlarr-page-label{
  color:var(--plex-muted);
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.log-panel{margin-top:18px}
.log-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  cursor:pointer;
}
.log-header-actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.log-chevron{
  width:8px;
  height:8px;
  border-right:2px solid var(--plex-muted);
  border-bottom:2px solid var(--plex-muted);
  transform:rotate(45deg);
  transition:transform .2s ease;
}
.log-panel .log-body{display:none}
.log-panel--open .log-body{display:block}
.log-panel--open .log-chevron{transform:rotate(-135deg)}
.log-panel .panel-card{padding:16px}
.log-panel--full .log-body{display:block}
.log-panel--full .log-header{cursor:default}
.log-panel--full .log-chevron{display:none}
.log-toolbar{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.log-filter{
  display:flex;
  align-items:center;
  gap:8px;
}
.log-filter-label{
  color:var(--plex-muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.log-status{
  color:var(--plex-muted);
  font-size:12px;
}
.log-list{
  display:grid;
  gap:10px;
  --log-row-height:56px;
  --log-visible-rows:10;
  max-height:min(calc(100vh - 260px), calc(var(--log-row-height) * var(--log-visible-rows)));
  overflow:auto;
}
.log-panel--full .log-body{
  max-height:calc(100vh - 220px);
  overflow:auto;
}
.log-panel--full .log-list{
  max-height:none;
  overflow:visible;
}
.log-row{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:12px;
  align-items:start;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(7,12,20,.75);
  font-size:12px;
}
.log-row--error{border-color:rgba(255,80,80,.45)}
.log-row--info{border-color:rgba(74,167,164,.45)}
.log-time{
  color:var(--plex-muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.log-title{
  font-weight:700;
  color:var(--plex-text);
}
.log-app-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:2px 8px;
  border-radius:999px;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  background:rgba(255,255,255,.08);
  color:#dfe9ea;
  margin-right:6px;
}
.log-row[data-app="system"]{border-color:rgba(150,160,170,.55)}
.log-row[data-app="plex"]{border-color:rgba(255,200,90,.65)}
.log-row[data-app="tautulli"]{border-color:rgba(112,190,255,.65)}
.log-row[data-app="sonarr"]{border-color:rgba(74,167,164,.65)}
.log-row[data-app="radarr"]{border-color:rgba(120,215,160,.65)}
.log-row[data-app="lidarr"]{border-color:rgba(180,140,255,.65)}
.log-row[data-app="readarr"]{border-color:rgba(255,150,120,.65)}
.log-row[data-app="pulsarr"]{border-color:rgba(110,205,255,.65)}
.log-row[data-app="prowlarr"]{border-color:rgba(255,120,180,.65)}
.log-row[data-app="transmission"]{border-color:rgba(255,140,80,.65)}
.log-app-pill[data-app="system"]{background:rgba(150,160,170,.25);color:#e6edf1}
.log-app-pill[data-app="plex"]{background:rgba(255,200,90,.2);color:#ffe2a6}
.log-app-pill[data-app="tautulli"]{background:rgba(112,190,255,.2);color:#d7ecff}
.log-app-pill[data-app="sonarr"]{background:rgba(74,167,164,.2);color:#c9f2f0}
.log-app-pill[data-app="radarr"]{background:rgba(120,215,160,.2);color:#d9ffe8}
.log-app-pill[data-app="lidarr"]{background:rgba(180,140,255,.2);color:#f0e3ff}
.log-app-pill[data-app="readarr"]{background:rgba(255,150,120,.2);color:#ffe1d6}
.log-app-pill[data-app="pulsarr"]{background:rgba(110,205,255,.2);color:#d5f1ff}
.log-app-pill[data-app="prowlarr"]{background:rgba(255,120,180,.2);color:#ffd3e9}
.log-app-pill[data-app="transmission"]{background:rgba(255,140,80,.2);color:#ffd9c4}
.log-text{
  margin-top:4px;
  color:var(--plex-muted);
}
.log-empty{
  padding:12px;
  color:var(--plex-muted);
  text-align:center;
}

[data-theme="day"] .log-row{
  background:#f1f4f8;
  border-color:rgba(10,20,30,.12);
}

[data-theme="day"] .log-row[data-app="system"]{border-color:rgba(150,160,170,.55)}
[data-theme="day"] .log-row[data-app="plex"]{border-color:rgba(255,200,90,.65)}
[data-theme="day"] .log-row[data-app="tautulli"]{border-color:rgba(112,190,255,.65)}
[data-theme="day"] .log-row[data-app="sonarr"]{border-color:rgba(74,167,164,.65)}
[data-theme="day"] .log-row[data-app="radarr"]{border-color:rgba(120,215,160,.65)}
[data-theme="day"] .log-row[data-app="lidarr"]{border-color:rgba(180,140,255,.65)}
[data-theme="day"] .log-row[data-app="readarr"]{border-color:rgba(255,150,120,.65)}
[data-theme="day"] .log-row[data-app="pulsarr"]{border-color:rgba(110,205,255,.65)}
[data-theme="day"] .log-row[data-app="prowlarr"]{border-color:rgba(255,120,180,.65)}
[data-theme="day"] .log-row[data-app="transmission"]{border-color:rgba(255,140,80,.65)}

[data-theme="day"] .log-time,
[data-theme="day"] .log-title,
[data-theme="day"] .log-text,
[data-theme="day"] .log-empty{
  color:#1f2b38;
}

[data-theme="day"] .log-app-pill{
  border:1px solid rgba(10,20,30,.12);
}

[data-theme="day"] .log-app-pill[data-app="system"]{
  background:rgba(150,160,170,.32);
  border-color:rgba(150,160,170,.55);
  color:#1f2b38;
}
[data-theme="day"] .log-app-pill[data-app="plex"]{
  background:rgba(255,200,90,.35);
  border-color:rgba(255,200,90,.6);
  color:#513400;
}
[data-theme="day"] .log-app-pill[data-app="tautulli"]{
  background:rgba(112,190,255,.32);
  border-color:rgba(112,190,255,.6);
  color:#1a4a78;
}
[data-theme="day"] .log-app-pill[data-app="sonarr"]{
  background:rgba(74,167,164,.32);
  border-color:rgba(74,167,164,.6);
  color:#0f4b4a;
}
[data-theme="day"] .log-app-pill[data-app="radarr"]{
  background:rgba(120,215,160,.32);
  border-color:rgba(120,215,160,.6);
  color:#0f4b2f;
}
[data-theme="day"] .log-app-pill[data-app="lidarr"]{
  background:rgba(180,140,255,.32);
  border-color:rgba(180,140,255,.6);
  color:#3a246b;
}
[data-theme="day"] .log-app-pill[data-app="readarr"]{
  background:rgba(255,150,120,.32);
  border-color:rgba(255,150,120,.6);
  color:#6b2e1f;
}
[data-theme="day"] .log-app-pill[data-app="pulsarr"]{
  background:rgba(110,205,255,.32);
  border-color:rgba(110,205,255,.6);
  color:#1a4f7a;
}
[data-theme="day"] .log-app-pill[data-app="prowlarr"]{
  background:rgba(255,120,180,.32);
  border-color:rgba(255,120,180,.6);
  color:#6b1f47;
}
[data-theme="day"] .log-app-pill[data-app="transmission"]{
  background:rgba(255,140,80,.32);
  border-color:rgba(255,140,80,.6);
  color:#6b2f10;
}

.plex-iconbtn{
  width:32px;height:32px;border-radius:6px;border:2px solid #0b0e15;background:var(--plex-teal);
  cursor:pointer;display:inline-grid;place-items:center;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
  flex:0 0 auto;
}
.plex-iconbtn:disabled{opacity:.5;cursor:not-allowed;filter:saturate(.5)}
.plex-chev{width:8px;height:8px;border-right:2px solid var(--plex-ink);border-bottom:2px solid var(--plex-ink)}
.plex-chev.plex-left{transform:rotate(135deg)}
.plex-chev.plex-right{transform:rotate(-45deg)}
.plex-chev.plex-down{transform:rotate(45deg)}
.plex-chev.plex-up{transform:rotate(-135deg)}
.plex-doublechev{display:grid;gap:0}

.plex-collapsed .plex-panel{display:none}

.plex-carousel-viewport{
  padding:5px;
  overflow:hidden;
  touch-action: pan-y;
  min-width:0;
  width:100%;
  max-width:100%;
  -webkit-overflow-scrolling: touch;
}
#plex-active .plex-carousel-viewport{ min-height: calc((var(--plex-cardH) * 1px) + 2px); }
#plex-active .plex-carousel-track{ min-height: calc((var(--plex-cardH) * 1px) + 2px); }
#tautulli-stats{
  --plex-cardW: 385;
  --plex-cardH: 300;
}
.plex-carousel-track{
  display:flex;
  gap: calc(var(--plex-gap) * 1px);
  align-items:stretch;
  will-change: transform;
  transform: translate3d(0,0,0);
  transition: transform 420ms cubic-bezier(.22,.9,.24,1);
  min-width:0;
}

.plex-card{
  width: calc(var(--plex-cardW) * 1px);
  height: calc(var(--plex-cardH) * 1px);
  background:var(--plex-teal);
  border:3px solid #0b0e15;
  border-radius:10px;
  overflow:hidden;
  box-shadow:none;
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
}
.plex-poster-wrap{position:relative;padding:10px 10px 8px;background:var(--plex-teal)}
.plex-poster-well{
  position:relative;
  background:#0b0c12;
  border-radius:10px;
  overflow:hidden;
  height: calc(var(--plex-posterH) * 1px);
  box-shadow:inset 0 0 0 4px rgba(0,0,0,.65);
}
.plex-poster-well img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.05)}
.plex-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  color:#d7e5ff;font-weight:900;text-align:center;padding:18px;
  background:
    radial-gradient(1200px 500px at 20% 0%, rgba(74,167,164,.45), transparent 60%),
    radial-gradient(900px 600px at 80% 10%, rgba(155,89,182,.25), transparent 55%),
    linear-gradient(180deg, #0b0c12, #0b0c12);
}
.plex-placeholder-big{font-size:calc(22px * var(--plex-cardTextScale));line-height:1.1;text-shadow:0 2px 0 rgba(0,0,0,.45)}
.plex-placeholder-small{font-size:calc(12px * var(--plex-cardTextScale));color:#9fb3d6;margin-top:8px;font-weight:800}

.plex-pill{
  position:absolute;top:3px;right:3px;background:var(--plex-pill);color:var(--plex-ink);font-weight:900;
  font-size:calc(14px * var(--plex-cardTextScale));padding:6px 12px;border-radius:8px;border:2px solid #0b0e15;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
  text-transform:capitalize;
}
.plex-type-icon,.plex-eye-icon{
  position:absolute;width:28px;height:24px;border-radius:8px;background:rgba(20,24,36,.92);
  border:2px solid rgba(255,255,255,.22);display:grid;place-items:center;
}
.plex-type-icon{top:3px;left:3px;border-radius:6px;z-index:3;pointer-events:none}
.plex-eye-icon{right:3px;bottom:3px;cursor:pointer;z-index:5;pointer-events:auto}
.plex-eye-icon:hover{filter:brightness(1.1)}
.plex-type-icon svg,.plex-eye-icon svg{width:16px;height:16px;opacity:.95}
.plex-source-icon{
  position:absolute;left:3px;bottom:3px;width:28px;height:24px;border-radius:8px;background:rgba(20,24,36,.92);
  border:2px solid rgba(255,255,255,.22);display:grid;place-items:center;overflow:hidden;padding:2px;
  z-index:4;
  pointer-events:none;
}
.plex-source-icon img{
  width:16px;height:16px;display:block;object-fit:contain;filter:none;
}

.plex-watchlist-btn{
  position:absolute;
  top:3px;
  right:3px;
  width:28px;
  height:24px;
  border-radius:8px;
  border:2px solid rgba(255,255,255,.22);
  background:rgba(20,24,36,.92);
  color:#f6d66a;
  display:grid;
  place-items:center;
  cursor:pointer;
  z-index:3;
}

.plex-watchlist-btn svg{
  width:16px;
  height:16px;
  display:block;
}

.plex-watchlist-btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}

.plex-watchlist-btn--modal{
  top:8px;
  right:8px;
  width:34px;
  height:29px;
  border-radius:9px;
  z-index:4;
}

.plex-watchlist-btn--modal svg{
  width:19px;
  height:19px;
}

.plex-card--watchlisted .plex-eye-icon{
  right:3px;
  bottom:3px;
}


.plex-footer{
  padding:8px 10px 10px;
  background:transparent;
  min-height: calc(var(--plex-footerH) * 1px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  margin-top:auto;
}
.plex-name{
  font-weight:900;
  color:var(--plex-ink);
  font-size:calc(18px * var(--plex-cardTextScale));
  line-height:1.1;
  margin-bottom:4px;
  text-shadow:0 1px 0 rgba(255,255,255,.12);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.plex-meta{font-weight:800;color:var(--on-brand-muted);font-size:calc(14px * var(--plex-cardTextScale))}

/* Keep carousel headings and card text readable across dark brand themes. */
html:not([data-theme="day"]) .plex-overview .plex-title{
  color:#e8eef7;
}

.plex-overview .plex-card .plex-name{
  color:var(--plex-ink);
}

.plex-overview .plex-card .plex-meta{
  color:var(--on-brand-muted);
}

.plex-empty{padding:40px 10px 20px;color:var(--plex-muted);font-weight:800}

.queue-panel{padding:14px}
.queue-table{
  --queue-row-height: 48px;
  --queue-header-height: 44px;
  --queue-visible-rows: 10;
  --queue-col-detail: 140px;
  --queue-col-subdetail: 160px;
  --queue-col-quality: 130px;
  --queue-col-protocol: 116px;
  --queue-col-timeleft: 110px;
  --queue-col-progress: 170px;
  --queue-grid-template:
    minmax(220px, 1fr)
    var(--queue-col-detail)
    var(--queue-col-subdetail)
    var(--queue-col-quality)
    var(--queue-col-protocol)
    var(--queue-col-timeleft)
    var(--queue-col-progress);
  background:#2c313d;
  border:2px solid #0b0e15;
  border-radius:10px;
  max-height:calc(var(--queue-header-height) + (var(--queue-row-height) * var(--queue-visible-rows)));
  overflow:auto;
}
.queue-hide-detail{--queue-col-detail:0px}
.queue-hide-subdetail{--queue-col-subdetail:0px}
.queue-hide-size{--queue-col-quality:0px}
.queue-hide-protocol{--queue-col-protocol:0px}
.queue-hide-timeleft{--queue-col-timeleft:0px}
.queue-hide-progress{--queue-col-progress:0px}
.queue-hide-detail .queue-col-detail{display:none}
.queue-hide-subdetail .queue-col-subdetail{display:none}
.queue-hide-size .queue-col-size{display:none}
.queue-hide-protocol .queue-col-protocol{display:none}
.queue-hide-timeleft .queue-col-time{display:none}
.queue-hide-progress .queue-col-progress{display:none}
.queue-hide-detail .queue-row > .queue-episode{display:none}
.queue-hide-subdetail .queue-row > .queue-ep-title{display:none}
.queue-hide-size .queue-row > .queue-col-size{display:none}
.queue-hide-protocol .queue-row > .queue-protocol{display:none}
.queue-hide-timeleft .queue-row > .queue-time{display:none}
.queue-hide-progress .queue-row > .queue-progress{display:none}
.queue-row{
  display:grid;
  grid-template-columns: var(--queue-grid-template);
  gap:12px;
  align-items:center;
  padding:10px 12px;
  border-top:1px solid rgba(255,255,255,.08);
  min-width:0;
}
.queue-row > div{
  min-width:0;
}
.queue-row > div:first-child{
  overflow:hidden;
}
.queue-row > div:not(:first-child){
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-row.header{
  position:sticky;
  top:0;
  background:#232833;
  font-size:12px;
  font-weight:700;
  border-top:none;
  z-index:2;
}
.queue-row.header > div{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-sortable{
  cursor:pointer;
  user-select:none;
}
.queue-sortable:after{
  content:' ⇅';
  font-weight:600;
  opacity:.6;
  font-size:11px;
  margin-left:4px;
}
.queue-title{
  font-weight:700;
  color:#8ecbff;
}
.queue-link{
  background:transparent;
  border:none;
  padding:0;
  margin:0;
  color:#8ecbff;
  font:inherit;
  font-weight:700;
  text-align:left;
  cursor:pointer;
}
.queue-link:hover,
.queue-link:focus-visible{
  color:#b9deff;
  text-decoration:underline;
}
.queue-link:focus-visible{
  outline:2px solid rgba(142,203,255,.45);
  outline-offset:2px;
  border-radius:2px;
}
.queue-episode,
.queue-ep-title,
.queue-time{
  color:rgba(232,238,247,.85);
  font-weight:600;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.queue-ep-title-link{
  color:#8ecbff;
}
.queue-quality{
  display:inline-flex;
  padding:3px 8px;
  border-radius:6px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  font-weight:700;
  font-size:12px;
  color:#e8eef7;
  white-space:nowrap;
}
.queue-protocol{
  display:inline-flex;
  padding:3px 8px;
  border-radius:6px;
  font-weight:700;
  font-size:12px;
  color:#0b0e15;
  background:#2bd56f;
  text-transform:lowercase;
  justify-self:start;
}
.queue-protocol.usenet{
  background:#4fb4ff;
  color:#0b0e15;
}
.queue-progress{
  height:16px;
  background:rgba(255,255,255,.08);
  border-radius:8px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
}
.queue-progress > span{
  display:block;
  height:100%;
  background:#5ea2ff;
  width:0%;
}
.queue-empty{
  padding:18px;
  color:var(--plex-muted);
  font-weight:700;
}

.arr-calendar-month-label{
  min-width:152px;
  text-align:center;
  font-size:13px;
  font-weight:800;
  letter-spacing:.04em;
  color:var(--plex-text);
  padding:0 6px;
}

.arr-calendar-title-sep{
  opacity:.72;
}

.arr-calendar-month-label--title{
  min-width:0;
  text-align:left;
  padding:0;
  color:inherit;
  font-size:inherit;
  font-weight:inherit;
  letter-spacing:inherit;
  touch-action:pan-y;
}

.arr-calendar-pane--grid{
  touch-action:pan-y;
}

.arr-calendar-today-btn{
  height:32px;
  padding:0 12px;
  border-radius:6px;
  border:2px solid #0b0e15;
  background:var(--plex-teal);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
  color:var(--plex-ink);
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.arr-calendar-today-btn:hover{
  filter:brightness(1.02);
}

.plex-calendar-mobile-toggle img{
  width:14px;
  height:14px;
  display:block;
  filter:var(--on-brand-icon-filter, brightness(0) saturate(100%));
}

.arr-calendar-panel{
  --arr-calendar-desktop-height: 452px;
  --arr-calendar-row-height: 94px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}

.arr-calendar-layout{
  display:grid;
  grid-template-columns:minmax(290px, .95fr) minmax(0, 1.25fr);
  gap:0;
  align-items:start;
}

.arr-calendar-pane{
  min-width:0;
  border:1px solid rgba(0,0,0,.45);
  border-radius:12px;
  background:var(--plex-panel1);
  padding:10px;
  box-shadow:0 10px 24px rgba(8,14,20,.07);
}

.arr-calendar-weekdays{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:8px;
  align-items:center;
  min-height:17px;
  margin-bottom:8px;
  font-size:9px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(226,236,249,.58);
  text-align:center;
}

.arr-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:8px;
}

.arr-calendar-day{
  min-height:62px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(10,16,24,.62);
  color:var(--plex-text);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:space-between;
  padding:6px 6px 7px;
  text-align:left;
  transition:border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}

button.arr-calendar-day{
  cursor:pointer;
}

button.arr-calendar-day:hover{
  border-color:rgba(var(--brand-rgb),.68);
  background:linear-gradient(180deg, rgba(var(--brand-rgb), .28), rgba(var(--brand-rgb), .22));
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.26);
}

.arr-calendar-day--blank{
  border-color:transparent;
  background:transparent;
  pointer-events:none;
}

.arr-calendar-day--outmonth{
  opacity:.48;
  border-style:dashed;
  border-color:rgba(255,255,255,.08);
  background:rgba(10,16,24,.36);
  cursor:pointer;
}

.arr-calendar-day--outmonth .arr-calendar-day-num{
  color:rgba(229,237,248,.55);
}

button.arr-calendar-day--outmonth:hover{
  opacity:.76;
}

.arr-calendar-day.is-today{
  border-color:rgba(var(--brand-rgb), .62);
  box-shadow:inset 0 0 0 1px rgba(var(--brand-rgb),.45);
}

.arr-calendar-day.is-selected{
  background:rgba(var(--brand-rgb), .5);
  border:3px solid rgba(var(--brand-rgb), .95);
  box-shadow:none;
}

.arr-calendar-day-num{
  font-size:12px;
  font-weight:800;
  line-height:1;
  color:#e5edf8;
  align-self:flex-end;
}

.arr-calendar-day-dots{
  display:flex;
  align-items:center;
  gap:4px;
  min-height:8px;
}

.arr-calendar-day-dots.is-empty{
  opacity:.35;
}

.arr-calendar-dot{
  width:6px;
  height:6px;
  border-radius:50%;
  display:block;
  box-shadow:0 0 0 1px rgba(255,255,255,.24);
}

.arr-calendar-dot--movie{ background:#ffc449; }
.arr-calendar-dot--tv{ background:#57c0ff; }
.arr-calendar-dot--music{ background:#65da87; }
.arr-calendar-dot--book{ background:#ff7d7d; }
.arr-calendar-dot--other{ background:#b8c4d6; }

.arr-calendar-dot-more{
  margin-left:2px;
  font-size:9px;
  line-height:1;
  font-weight:800;
  letter-spacing:.02em;
  color:rgba(235,242,252,.78);
}

.arr-calendar-list-label{
  font-size:9px;
  font-weight:700;
  letter-spacing:.12em;
  line-height:1;
  display:flex;
  align-items:center;
  min-height:17px;
  padding:0;
  margin-bottom:8px;
  color:rgba(226,236,249,.58);
  text-transform:uppercase;
}

.arr-calendar-list{
  display:grid;
  gap:10px;
  max-height:348px;
  overflow:auto;
  padding-right:2px;
}

.arr-calendar-empty{
  border:1px dashed rgba(255,255,255,.24);
  border-radius:12px;
  padding:14px 12px;
  color:var(--plex-muted);
  font-weight:700;
  text-align:center;
  background:rgba(4,8,15,.3);
}

.arr-calendar-item{
  width:100%;
  border:1px solid rgba(255,255,255,.16);
  border-radius:12px;
  background:
    radial-gradient(90% 120% at 0% 0%, rgba(var(--brand-rgb), .16) 0%, rgba(0,0,0,0) 54%),
    linear-gradient(180deg, rgba(22,30,42,.9), rgba(14,20,31,.94));
  color:var(--plex-text);
  padding:9px;
  display:grid;
  grid-template-columns:46px minmax(0, 1fr);
  gap:11px;
  text-align:left;
  cursor:pointer;
}

.arr-calendar-item:hover,
.arr-calendar-item:focus-visible{
  border-color:rgba(var(--brand-rgb),.78);
  background:
    radial-gradient(90% 120% at 0% 0%, rgba(var(--brand-rgb), .24) 0%, rgba(0,0,0,0) 56%),
    linear-gradient(180deg, rgba(27,36,50,.96), rgba(16,24,36,.98));
}

.arr-calendar-item:focus-visible{
  outline:2px solid rgba(var(--brand-rgb),.7);
  outline-offset:1px;
}

.arr-calendar-item-art{
  width:46px;
  height:64px;
  border-radius:8px;
  overflow:hidden;
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.2);
}

.arr-calendar-item-art img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.arr-calendar-item-art-fallback{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  font-weight:900;
  font-size:16px;
  color:rgba(232,238,247,.7);
}

.arr-calendar-item-main{
  min-width:0;
  display:grid;
  gap:4px;
}

.arr-calendar-item-title-row{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}

.arr-calendar-item-type{
  width:14px;
  height:14px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  color:#eef5ff;
}

.arr-calendar-item-type svg{
  width:14px;
  height:14px;
  filter:none;
  opacity:.96;
}

.arr-calendar-item-title{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:13px;
  font-weight:800;
  color:#f1f6fd;
}

.arr-calendar-item-pill{
  margin-left:auto;
  flex:0 0 auto;
  padding:2px 6px;
  border-radius:999px;
  font-size:10px;
  font-weight:800;
  border:1px solid rgba(var(--brand-rgb),.6);
  background:rgba(var(--brand-rgb),.25);
  color:var(--plex-ink);
  display:none;
}

.arr-calendar-item-subtitle,
.arr-calendar-item-meta{
  font-size:11px;
  color:rgba(223,234,246,.78);
  line-height:1.25;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.arr-calendar-overlay{
  position:fixed;
  inset:48px 0 0;
  background:rgba(8,12,20,.58);
  z-index:1060;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:0;
}

.arr-calendar-overlay-card{
  width:100%;
  max-height:72vh;
  border-top-left-radius:14px;
  border-top-right-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  border-bottom:0;
  background:linear-gradient(180deg, #1d2532, #141c28);
  display:grid;
  grid-template-rows:auto minmax(0, 1fr);
  overflow:hidden;
}

.arr-calendar-overlay-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.1);
}

.arr-calendar-overlay-close{
  width:30px;
  height:30px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(12,18,28,.76);
  color:#e8eef7;
  font-weight:900;
  cursor:pointer;
}

body.arr-calendar-overlay-open{
  overflow:hidden;
}

[data-theme="day"] .arr-calendar-weekdays{
  color:#111921;
}

[data-theme="day"] .arr-calendar-day{
  background:linear-gradient(180deg, #e8edf5, #dde4ee);
  color:#1f2b38;
  border-color:rgba(10,20,30,.14);
}

[data-theme="day"] .arr-calendar-pane{
  background:#fbfcfe;
  border-color:rgba(10,20,30,.12);
  box-shadow:0 10px 24px rgba(8,14,20,.06);
}

[data-theme="day"] .arr-calendar-day--blank{
  background:transparent;
  border-color:transparent;
}

[data-theme="day"] .arr-calendar-day--outmonth{
  opacity:.64;
  border-style:dashed;
  border-color:rgba(10,20,30,.12);
  background:linear-gradient(180deg, #eef2f7, #e6ecf4);
}

[data-theme="day"] .arr-calendar-day--outmonth .arr-calendar-day-num{
  color:rgba(47,65,85,.58);
}

[data-theme="day"] .arr-calendar-day.is-selected{
  background:rgba(var(--brand-rgb), .42);
  border:3px solid rgba(var(--brand-rgb), .95);
}

[data-theme="day"] .arr-calendar-day.is-selected .arr-calendar-day-num{
  color:#132b3f;
}

[data-theme="day"] .arr-calendar-day-num{
  color:#304153;
}

[data-theme="day"] .arr-calendar-dot{
  box-shadow:0 0 0 1px rgba(0,0,0,.16);
}

[data-theme="day"] .arr-calendar-dot-more{
  color:#43566d;
}

[data-theme="day"] .arr-calendar-list-label{
  color:#111921;
}

[data-theme="day"] .arr-calendar-empty{
  background:#eef3f8;
  color:#5d6f83;
  border-color:rgba(10,20,30,.2);
}

[data-theme="day"] .arr-calendar-item{
  background:
    radial-gradient(80% 110% at 0% 0%, rgba(var(--brand-rgb), .14) 0%, rgba(0,0,0,0) 52%),
    linear-gradient(180deg, #edf2f8, #e3e9f2);
  color:#1f2b38;
  border-color:rgba(10,20,30,.16);
}

[data-theme="day"] .arr-calendar-item-type{
  color:#2d4156;
}

[data-theme="day"] .arr-calendar-item-type svg{
  filter:brightness(0) saturate(100%);
  opacity:.82;
}

[data-theme="day"] .arr-calendar-item-title{
  color:#1f2b38;
}

[data-theme="day"] .arr-calendar-item-subtitle,
[data-theme="day"] .arr-calendar-item-meta{
  color:#516274;
}

[data-theme="day"] .arr-calendar-overlay{
  background:rgba(10,18,30,.35);
}

[data-theme="day"] .arr-calendar-overlay-card{
  background:#f2f6fb;
  border-color:rgba(10,20,30,.2);
}

@media (max-width: 1100px){ .plex-overview{ --plex-cardW: 189; --plex-posterH: 252; --plex-cardH: 336; } }
@media (max-width: 820px){ .plex-overview{ --plex-cardW: 175; --plex-posterH: 238; --plex-cardH: 322; } }
@media (max-width: 640px){
  .plex-overview{
    --plex-cardW: 240;
    --plex-posterH: 300;
    --plex-cardH: 380;
    --plex-gap: 16;
  }
  #plex-active .plex-carousel-viewport,
  #plex-active .plex-carousel-track{ min-height: calc((var(--plex-cardH) * 1px) + 2px); }
}

.plex-hidden{ display:none !important; }
.plex-modal-backdrop{
  position:fixed; inset:0;
  background: rgba(0,0,0,.55);
  display:flex; align-items:flex-start; justify-content:center;
  padding: 26px 18px;
  z-index: 9999;
}
.plex-modal-backdrop:not(.plex-hidden) .plex-modal{
  animation:plex-modal-pop-in .24s cubic-bezier(.2,.8,.2,1);
}
.plex-modal{
  width: min(1100px, 100%);
  max-height: calc(100vh - 52px);
  background: #2c313d;
  border: 2px solid #0b0e15;
  border-radius: 10px;
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
@keyframes plex-modal-pop-in{
  from{ transform:translateY(14px); opacity:.65; }
  to{ transform:translateY(0); opacity:1; }
}
.plex-modal-close{
  position:absolute; top:12px; right:12px;
  width: 34px; height: 34px;
  border-radius: 8px;
  border: 2px solid rgba(255,255,255,.22);
  background: rgba(20,24,36,.9);
  color: #e8eef7;
  cursor:pointer;
  font-weight: 900;
  z-index: 20;
}
.plex-modal-header{
  padding: 18px 54px 10px 18px;
  background: linear-gradient(180deg, #2c313d, #262b38);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.plex-modal-title{
  font-size: 20px;
  font-weight: 900;
  display:flex;
  align-items:center;
  gap:10px;
}
.plex-mini-icon{ width: 18px; height: 18px; display:inline-grid; place-items:center; }
.plex-mini-icon svg{ width:18px; height:18px; }
.plex-modal-subtitle{
  margin-top: 6px;
  font-size: 12px;
  font-weight: 800;
  color: rgba(232,238,247,.78);
}
.plex-modal-body{
  padding: 0;
  background: #262b38;
  display:flex;
  flex-direction:column;
  min-height:0;
  flex:1;
}
.plex-modal-scroll{
  flex:1;
  min-height:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding: 18px;
}
.plex-modal-hero{
  position:relative;
  border-radius: 10px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.08);
  min-height: 520px;
  background: #141824;
}
.plex-modal-bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  opacity: .58;
  filter: saturate(1.08) contrast(1.05);
  transform: scale(1.03);
}
.plex-modal-hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 500px at 25% 15%, rgba(74,167,164,.35), transparent 60%),
    linear-gradient(90deg, rgba(20,24,36,.92) 0%, rgba(20,24,36,.52) 58%, rgba(20,24,36,.88) 100%);
  z-index:1;
}
.plex-modal-content{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns: 250px 1fr;
  gap: 18px;
  padding: 18px;
}
.plex-modal-meta{color:var(--plex-text)}
.plex-modal-poster{
  position: relative;
  width: 250px;
  border-radius: 10px;
  border: 2px solid rgba(255,255,255,.18);
  overflow:hidden;
  background:#0b0c12;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}
.plex-modal-poster img{ width:100%; height:auto; display:block; }

.plex-pills{ display:flex; flex-wrap:wrap; gap:8px; margin: 10px 0 12px; align-items:center; }
.plex-pill2{
  display:inline-flex; align-items:center; gap:6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  white-space: nowrap;
}
.plex-dot{
  display:inline-block;
  width:8px;
  height:8px;
  border-radius:99px;
  border:1px solid rgba(0,0,0,.25);
}
.plex-section{ margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.10); }
.plex-section h4{ margin:0 0 8px 0; font-size: 14px; font-weight: 900; color: rgba(232,238,247,.92); }
.plex-overview-text{
  color: rgba(232,238,247,.90);
  font-weight: 800;
  line-height: 1.45;
  white-space: pre-wrap;
  max-width: 820px;
  text-shadow: 0 2px 12px rgba(0,0,0,.45);
}
.plex-modal-footer{
  flex:0 0 auto;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  padding: 10px 18px 14px;
  background: linear-gradient(180deg, rgba(38,43,56,.9), rgba(30,35,46,1));
  border-top: 1px solid rgba(255,255,255,.12);
}
.plex-modal-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:74px;
  padding: 6px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.26);
  background: rgba(255,255,255,.08);
  color:#e8eef7;
  font-size:12px;
  font-weight:900;
  text-decoration:none;
}
.plex-modal-link:hover,
.plex-modal-link:focus-visible{
  background: rgba(255,255,255,.16);
}

/* Tautulli watch stats cards */
.tautulli-card{
  padding:10px 10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  color:var(--plex-ink);
  background:var(--plex-teal);
  border-color:#0b0e15;
}

.tautulli-card-content{
  display:grid;
  grid-template-columns:154px minmax(0, 1fr);
  gap:8px;
  align-items:start;
}

.tautulli-card-poster-wrap{
  display:block;
}

.tautulli-card-title{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:8px;
  min-width:0;
}

.tautulli-card-label{
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--plex-ink);
}

.tautulli-card-unit{
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--on-brand-muted);
  font-weight:600;
  margin-left:auto;
  text-align:right;
  white-space:nowrap;
}

.tautulli-card-poster{
  width:100%;
  height:216px;
  border-radius:10px;
  background:#0b0c12;
  border:none;
  box-shadow:inset 0 0 0 4px rgba(0,0,0,.65);
}

.tautulli-card-poster-shell{
  padding:0;
  background:transparent;
}

.tautulli-card-type{
  top:4px;
  left:4px;
  z-index:3;
}

.tautulli-card-rank{
  top:4px;
  right:4px;
  z-index:3;
  font-size:11px;
  padding:4px 8px;
}

.tautulli-card-actions{
  position:absolute;
  right:4px;
  bottom:4px;
  z-index:3;
  display:grid;
  gap:2px;
}

.tautulli-card-action{
  width:26px;
  height:26px;
  border-radius:8px;
  background:rgba(20,24,36,.92);
  border:2px solid rgba(255,255,255,.22);
  display:grid;
  place-items:center;
  padding:0;
  margin:0;
  cursor:pointer;
}

.tautulli-card-action img,
.tautulli-card-action svg{
  width:14px;
  height:14px;
  display:block;
}

.tautulli-card-action svg{
  stroke:#e8eef7;
}

.tautulli-card-selected-title{
  margin-top:6px;
  font-size:10px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:.03em;
  color:var(--plex-ink);
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.tautulli-actions{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
  justify-items:center;
  align-items:center;
}

.tautulli-action{
  position:relative;
  width:32px;
  height:32px;
  border-radius:0;
  border:none;
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  margin:0 auto;
  cursor:pointer;
  color:var(--plex-ink);
  text-decoration:none;
}

.tautulli-action img{
  width:32px;
  height:32px;
  object-fit:contain;
}

.tautulli-action svg{
  width:32px;
  height:32px;
  display:block;
}

.tautulli-card-actions .tautulli-action{
  width:26px;
  height:26px;
  border-radius:8px;
  background:rgba(20,24,36,.92);
  border:2px solid rgba(255,255,255,.22);
  padding:0;
}

.tautulli-card-actions .tautulli-action img,
.tautulli-card-actions .tautulli-action svg{
  width:14px;
  height:14px;
}

.tautulli-action--launch::after{
  content:"";
}

.tautulli-action.is-disabled{
  opacity:.45;
  pointer-events:none;
}

.tautulli-card-body{
  display:grid;
  gap:8px;
}

.tautulli-card-title{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:4px;
}

.tautulli-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:6px;
  font-size:12px;
}

.tautulli-item{
  display:grid;
  grid-template-columns:18px minmax(0, 1fr);
  gap:8px;
  align-items:center;
  color:var(--plex-ink);
  cursor:pointer;
  border-radius:6px;
  padding:2px 4px;
}

.tautulli-item.is-active{
  background:rgba(0,0,0,.12);
}

.tautulli-rank{
  font-size:10px;
  color:var(--on-brand-muted);
  text-align:right;
}

.tautulli-name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.tautulli-name a{
  color:var(--plex-ink);
  text-decoration:none;
}

.tautulli-name a:hover{
  color:var(--plex-ink);
}

.tautulli-count{
  font-weight:700;
  color:var(--plex-ink);
  text-align:right;
}

.tautulli-action--tautulli img,
.tautulli-action--plex img{
  width:24px;
  height:24px;
}

.tautulli-details{
  display:none;
}

.tautulli-details-title{
  font-weight:800;
  font-size:13px;
  color:var(--plex-ink);
}

.tautulli-details-meta{
  font-size:11px;
  color:var(--on-brand-muted);
  font-weight:700;
}

.tautulli-details-overview{
  font-size:11px;
  color:var(--on-brand-muted);
  font-weight:600;
  opacity:.85;
}

.tautulli-wheel-card{
  display:flex;
  flex-direction:column;
}

.tautulli-wheel-card-title{
  margin-top:auto;
  padding:8px 10px 10px;
  font-weight:900;
  color:var(--plex-ink);
  font-size:calc(18px * var(--plex-cardTextScale));
  line-height:1.1;
  text-shadow:0 1px 0 rgba(255,255,255,.12);
  text-transform:none;
  letter-spacing:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.tautulli-wheel-item-title{
  position:absolute;
  left:13px;
  bottom:13px;
  z-index:3;
  max-width:calc(100% - 86px);
  padding:4px 8px;
  border-radius:8px;
  background:rgba(20,24,36,.82);
  border:1px solid rgba(255,255,255,.18);
  font-size:10px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:none;
  color:#e8eef7;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.tautulli-wheel-type{
  top:13px;
  left:13px;
  z-index:3;
}

.tautulli-wheel-rank{
  top:13px;
  right:13px;
  z-index:3;
}

.tautulli-wheel-eye{
  background:rgba(20,24,36,.92);
  right:13px;
  bottom:13px;
  z-index:3;
  padding:0;
  margin:0;
  line-height:0;
  display:grid;
  place-items:center;
}

.tautulli-wheel-eye svg{
  display:block;
  margin:auto;
}

.tautulli-wheel-eye:disabled{
  opacity:.45;
  cursor:not-allowed;
}

.tautulli-thumbwheel-wrap{
  padding:0 10px 2px;
}

.tautulli-thumbwheel{
  width:100%;
  margin:0;
  accent-color:#0f1a1e;
  cursor:pointer;
}

.tautulli-thumbwheel::-webkit-slider-runnable-track{
  height:8px;
  border-radius:999px;
  background:rgba(11,15,21,.38);
  border:1px solid rgba(11,15,21,.28);
}

.tautulli-thumbwheel::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#e8eef7;
  border:2px solid #0b0f15;
  margin-top:-5px;
}

.tautulli-thumbwheel::-moz-range-track{
  height:8px;
  border-radius:999px;
  background:rgba(11,15,21,.38);
  border:1px solid rgba(11,15,21,.28);
}

.tautulli-thumbwheel::-moz-range-thumb{
  width:16px;
  height:16px;
  border-radius:50%;
  background:#e8eef7;
  border:2px solid #0b0f15;
}

#tautulliModalBackdrop .plex-modal{
  max-height:calc(100dvh - 52px);
}

#tautulliModalBackdrop .plex-modal-body{
  display:grid;
  grid-template-rows:minmax(0,1fr) auto;
  min-height:0;
}

#tautulliModalBackdrop .plex-modal-scroll{
  min-height:0;
  overflow-y:auto;
}

#tautulliModalBackdrop .plex-modal-content{
  align-items:start;
}

#tautulliModalBackdrop .plex-modal-poster{
  align-self:start;
}

@media (max-width: 900px){
  .plex-modal-content{ grid-template-columns: 1fr; }
  .plex-modal-poster{ width: 220px; }
  .tautulli-wheel-item-title{ display:none !important; }
  .tautulli-wheel-card .plex-footer{ display:none !important; }
}
@media (max-width: 980px){
  .plex-modal-backdrop{
    inset:48px 0 0;
    padding:0;
    align-items:flex-end;
    z-index:1050;
  }
  .plex-modal{
    width:100%;
    height:100%;
    max-height:100%;
    border-radius:12px 12px 0 0;
    border-left:0;
    border-right:0;
    border-bottom:0;
    display:flex;
    flex-direction:column;
  }
  .plex-modal-backdrop:not(.plex-hidden) .plex-modal{
    animation:plex-modal-slide-up .26s cubic-bezier(.2,.8,.2,1);
  }
  .plex-modal-header{
    flex:0 0 auto;
    position:sticky;
    top:0;
    z-index:15;
  }
  .plex-modal-body{
    flex:1;
    min-height:0;
  }
  .plex-modal-scroll{ padding: 14px; }
  .plex-modal-footer{
    padding: 10px 14px 12px;
    gap:8px;
    justify-content:space-between;
    flex-wrap:wrap;
  }
  .plex-modal-link{
    flex:1 1 calc(50% - 8px);
    min-width:0;
  }
  .plex-modal-hero{
    min-height:0;
  }
}
@keyframes plex-modal-slide-up{
  from{ transform:translateY(100%); opacity:.98; }
  to{ transform:translateY(0); opacity:1; }
}
@media (max-width: 640px){
  .plex-select{ min-width:96px; height:28px; padding:0 28px 0 8px; font-size:11px; }
  .plex-select.plex-xsmall{ min-width:54px; }
  .plex-select.plex-icon{ min-width:90px; padding-left:26px; }
  .plex-iconbtn{ width:28px; height:28px; }
  .arr-calendar-month-label{min-width:106px;font-size:11px;}
  .arr-calendar-month-label--title{min-width:0;font-size:inherit;}
  .arr-calendar-today-btn{height:28px;padding:0 10px;font-size:11px;border-radius:6px;}
  .arr-calendar-day{min-height:48px;padding:5px;}
  .arr-calendar-day-num{font-size:12px;}
  .arr-calendar-day-dots{gap:3px;min-height:7px;}
  .arr-calendar-dot{width:5px;height:5px;}
  .arr-calendar-dot-more{font-size:8px;}
  .arr-calendar-item{grid-template-columns:40px minmax(0,1fr);padding:7px;gap:8px;}
  .arr-calendar-item-art{width:40px;height:56px;}
  .tautulli-wheel-item-title{ display:none !important; }
  .tautulli-wheel-card .plex-footer{ display:none !important; }
  #plexActivePrevBtn,
  #plexActiveNextBtn,
  #plexRecentPrevBtn,
  #plexRecentNextBtn,
  #plexWatchlistedPrevBtn,
  #plexWatchlistedNextBtn{
    display:none;
  }
}

@media (max-width: 980px){
  .arr-calendar-layout{
    grid-template-columns:1fr;
    gap:0;
  }
  .arr-calendar-pane--grid{
    border-bottom-left-radius:0;
    border-bottom-right-radius:0;
  }
  .arr-calendar-pane--list{
    border-top-left-radius:0;
    border-top-right-radius:0;
    border-top:0;
  }
  .arr-calendar-list{
    max-height:280px;
  }
}

@media (min-width: 981px){
  .arr-calendar-layout{
    grid-template-columns:minmax(500px, 1.08fr) minmax(420px, .92fr);
    gap:0;
    align-items:stretch;
    min-height:var(--arr-calendar-desktop-height);
  }
  .arr-calendar-pane--grid{
    border-top-right-radius:0;
    border-bottom-right-radius:0;
  }
  .arr-calendar-pane--list{
    border-top-left-radius:0;
    border-bottom-left-radius:0;
    border-left:0;
  }
  .arr-calendar-pane{
    height:var(--arr-calendar-desktop-height);
  }
  .arr-calendar-pane--grid{
    display:grid;
    grid-template-rows:auto minmax(0, 1fr);
  }
  .arr-calendar-grid{
    height:100%;
    align-content:start;
    grid-auto-rows:minmax(0, calc((100% - 40px) / 6));
  }
  .arr-calendar-day{
    box-sizing:border-box;
    min-height:0;
    height:auto;
  }
  .arr-calendar-pane--list{
    display:grid;
    grid-template-rows:auto minmax(0, 1fr);
  }
  .arr-calendar-list{
    max-height:none;
    height:100%;
    grid-auto-rows:var(--arr-calendar-row-height);
    align-content:start;
    gap:8px;
    padding-right:4px;
    overflow:auto;
  }
  .arr-calendar-item{
    box-sizing:border-box;
    min-height:var(--arr-calendar-row-height);
    height:var(--arr-calendar-row-height);
    padding:8px;
    grid-template-columns:calc((var(--arr-calendar-row-height) - 16px) * .66) minmax(0, 1fr);
    gap:10px;
    overflow:hidden;
  }
  .arr-calendar-item-art{
    width:100%;
    height:calc(var(--arr-calendar-row-height) - 16px);
  }
  .plex-calendar-mobile-toggle{
    display:none;
  }
  .arr-calendar-overlay{
    display:none !important;
  }
}
/* Launch page corner bleed fix */
.dash-body.launch-page .dash-main{
  overflow:hidden;
}

.dash-body.launch-page iframe{
  display:block;
  border:0;
  background:#0b1118 !important;
}
