  :root{
    --bg:#0f1115;
    --surface:#14161b;
    --surface-2:#1a1d23;
    --border:#22252b;
    --text:#ffffff;
    --muted:#8a8f98;
    --accent:#d92323;
    --accent-hover:#ef2f2f;
    --radius:12px;
    --radius-sm:8px;
    --shadow:0 10px 30px rgba(0,0,0,.45);
  }
  *{box-sizing:border-box}
  html,body{margin:0;background:var(--bg);color:var(--text);font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,sans-serif;-webkit-font-smoothing:antialiased}
  a{color:inherit}
  .wrap{max-width:1200px;margin:0 auto;padding:32px 20px 80px}
  .section-title{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:40px 0 14px}
  .demo{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
  .demo + .demo{margin-top:16px}
  .demo-label{display:inline-block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:4px 10px;margin-bottom:18px}

  /* ====== КОМПОНЕНТ №1: панель управления ====== */
  .kp-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
  .kp-btn{
    display:inline-flex;align-items:center;gap:8px;
    height:44px;padding:0 18px;
    background:var(--surface-2);color:var(--text);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    font:600 14px/1 inherit;cursor:pointer;user-select:none;
    transition:background .15s,border-color .15s,color .15s,transform .05s;
  }
  .kp-btn:hover{background:#1f2229;border-color:#2c3038}
  .kp-btn:active{transform:translateY(1px)}
  .kp-btn svg{width:18px;height:18px;flex:0 0 18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

  /* избранное */
  .kp-fav .kp-fav__icon-fill{display:none}
  .kp-fav.is-active{border-color:var(--accent);color:#fff}
  .kp-fav.is-active .kp-fav__icon{display:none}
  .kp-fav.is-active .kp-fav__icon-fill{display:block;fill:var(--accent);stroke:var(--accent)}

  /* дропдаун */
  .kp-dd{position:relative}
  .kp-dd__toggle .kp-dd__chev{transition:transform .2s}
  .kp-dd.is-open .kp-dd__chev{transform:rotate(180deg)}
  .kp-dd.has-value .kp-dd__toggle{border-color:var(--accent);color:#fff}
  .kp-dd__menu{
    position:absolute;top:calc(100% + 8px);left:0;min-width:240px;
    background:#15181e;border:1px solid var(--border);border-radius:var(--radius-sm);
    padding:6px;box-shadow:var(--shadow);
    opacity:0;visibility:hidden;transform:translateY(-4px);
    transition:opacity .15s,transform .15s,visibility .15s;
    z-index:20;
  }
  .kp-dd.is-open .kp-dd__menu{opacity:1;visibility:visible;transform:translateY(0)}
  .kp-dd__item{
    display:flex;align-items:center;gap:10px;width:100%;
    padding:10px 12px;background:transparent;border:0;border-radius:6px;
    color:var(--text);font:500 14px/1.2 inherit;text-align:left;cursor:pointer;
  }
  .kp-dd__item:hover{background:#1f2229}
  .kp-dd__item.is-selected{color:var(--accent)}
  .kp-dd__item svg{width:16px;height:16px;color:var(--muted)}
  .kp-dd__item.is-selected svg{color:var(--accent)}

  /* гостевой баннер */
  .kp-guest{
    background:linear-gradient(180deg,#15181e,#111418);
    border:1px solid var(--border);border-radius:var(--radius);
    padding:18px 20px;max-width:640px;
  }
  .kp-guest__row{display:flex;gap:14px;align-items:flex-start}
  .kp-guest__lock{
    flex:0 0 38px;width:38px;height:38px;display:grid;place-items:center;
    background:#1c1f25;border:1px solid var(--border);border-radius:10px;color:var(--accent);
  }
  .kp-guest__lock svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .kp-guest__text{color:var(--muted);font-size:14px;line-height:1.55}
  .kp-guest__text b{color:var(--text);font-weight:600}
  .kp-link{color:var(--accent);text-decoration:none;font-weight:600;border-bottom:1px dashed transparent}
  .kp-link:hover{border-bottom-color:var(--accent)}
  .kp-guest__more{display:inline-block;margin-top:10px;color:var(--muted);font-size:13px;text-decoration:none;transition:color .15s}
  .kp-guest__more:hover{color:var(--accent)}

  /* ====== КОМПОНЕНТ №2: личный кабинет ====== */
  .kp-lk__top{
    display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;
    margin-bottom:20px;
  }
  .kp-filters{display:flex;flex-wrap:wrap;gap:8px}
  .kp-chip{
    display:inline-flex;align-items:center;gap:8px;
    height:36px;padding:0 14px;border-radius:999px;
    background:var(--surface-2);border:1px solid var(--border);color:var(--text);
    font:500 13px/1 inherit;cursor:pointer;transition:all .15s;
  }
  .kp-chip:hover{border-color:#2c3038;background:#1f2229}
  .kp-chip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
  .kp-chip__count{
    font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px;
    background:rgba(255,255,255,.08);color:var(--muted);
  }
  .kp-chip.is-active .kp-chip__count{background:rgba(0,0,0,.25);color:#fff}

  .kp-sort{
    height:36px;padding:0 32px 0 12px;border-radius:8px;
    background:var(--surface-2) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8f98' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;
    border:1px solid var(--border);color:var(--text);font:500 13px inherit;
    appearance:none;cursor:pointer;
  }

  .kp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
  @media (max-width:1024px){.kp-grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:600px){.kp-grid{grid-template-columns:repeat(2,1fr)}}
  .kp-card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,border-color .2s;
  }
  .kp-card:hover{transform:translateY(-3px);border-color:#2c3038}
  .kp-card__poster{position:relative;aspect-ratio:2/3;background:#1a1d23 center/cover no-repeat}
  .kp-card__status{
    position:absolute;left:8px;top:8px;
    padding:5px 10px;border-radius:999px;
    background:rgba(15,17,21,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    border:1px solid rgba(255,255,255,.08);
    color:#fff;font-size:11px;font-weight:600;letter-spacing:.02em;
    display:inline-flex;align-items:center;gap:6px;
  }
  .kp-card__status::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}
  .kp-card__body{padding:12px 14px 14px}
  .kp-card__title{font-size:14px;font-weight:600;margin:0 0 4px;color:#fff;line-height:1.3}
  .kp-card__meta{font-size:12px;color:var(--muted)}

  /* заглушка для гостя в ЛК */
  .kp-empty{
    min-height:520px;display:grid;place-items:center;text-align:center;
    background:radial-gradient(ellipse at center,#181b21,var(--bg) 70%);
    border:1px solid var(--border);border-radius:var(--radius);padding:40px 20px;
  }
  .kp-empty__inner{max-width:460px}
  .kp-empty__icon{
    width:96px;height:96px;margin:0 auto 24px;border-radius:24px;
    background:linear-gradient(135deg,#1a1d23,#101216);
    border:1px solid var(--border);display:grid;place-items:center;color:var(--accent);
    box-shadow:0 20px 40px -20px rgba(217,35,35,.35);
  }
  .kp-empty__icon svg{width:48px;height:48px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
  .kp-empty__title{font-size:26px;font-weight:700;margin:0 0 10px;letter-spacing:-.01em}
  .kp-empty__sub{color:var(--muted);font-size:15px;line-height:1.55;margin:0 0 24px}
  .kp-btn-primary{
    display:inline-flex;align-items:center;gap:8px;
    height:48px;padding:0 26px;border-radius:10px;
    background:var(--accent);border:0;color:#fff;cursor:pointer;
    font:600 15px/1 inherit;transition:background .15s,transform .05s;
    box-shadow:0 10px 24px -10px rgba(217,35,35,.6);
  }
  .kp-btn-primary:hover{background:var(--accent-hover)}
  .kp-btn-primary:active{transform:translateY(1px)}
