.af-watchlist-page{
  padding:28px 0 60px;
}

.af-watchlist-shell{
  display:grid;
  gap:22px;
}

.af-watchlist-hero{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(300px,.9fr);
  gap:22px;
  padding:30px 32px;
  border-radius:36px;
  border:1px solid rgba(255,255,255,.88);
  background:linear-gradient(135deg,#fff 0%,#fff8ff 42%,#f4efff 100%);
  box-shadow:var(--afn-shadow-magenta);
}

.af-watchlist-hero:before,
.af-watchlist-hero:after{
  content:"";
  position:absolute;
  border-radius:999px;
  filter:blur(70px);
  pointer-events:none;
}

.af-watchlist-hero:before{
  right:-60px;
  top:-60px;
  width:200px;
  height:200px;
  background:rgba(217,70,239,.14);
}

.af-watchlist-hero:after{
  left:30%;
  bottom:-70px;
  width:220px;
  height:220px;
  background:rgba(139,92,246,.12);
}

.af-watchlist-hero__content,
.af-watchlist-hero__stats{
  position:relative;
  z-index:1;
}

.af-watchlist-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 14px;
  border-radius:999px;
  font-weight:800;
  background:rgba(255,255,255,.85);
  border:1px solid var(--afn-border);
  color:var(--afn-fuchsia-strong);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.af-watchlist-hero__title{
  margin:18px 0 0;
  font-size:clamp(2rem,4vw,3.9rem);
  line-height:1.02;
  letter-spacing:-.05em;
  color:var(--afn-slate-950);
}

.af-watchlist-hero__text{
  margin:18px 0 0;
  max-width:760px;
  color:var(--afn-text-soft);
  font-size:1rem;
  line-height:1.8;
}

.af-watchlist-hero__stats{
  display:grid;
  gap:14px;
  align-content:start;
}

.af-watch-stat{
  padding:18px 18px 16px;
  border-radius:22px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(217,70,239,.10);
  box-shadow:var(--afn-shadow-soft);
}

.af-watch-stat__value{
  display:block;
  font-size:1.8rem;
  line-height:1;
  font-weight:900;
  color:var(--afn-slate-950);
  letter-spacing:-.04em;
}

.af-watch-stat__label{
  display:block;
  margin-top:8px;
  color:var(--afn-text-soft);
  font-size:.85rem;
  line-height:1.55;
  font-weight:700;
}

.af-watchlist-toolbar{
  padding:22px;
  border-radius:28px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--afn-shadow);
}

.af-watchlist-toolbar__form{
  display:grid;
  gap:16px;
}

.af-watchlist-toolbar__top{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  justify-content:space-between;
}

.af-watchlist-search{
  flex:1 1 320px;
}

.af-watchlist-search input,
.af-watchlist-selects select{
  width:100%;
  min-height:48px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--afn-border);
  background:rgba(255,255,255,.82);
  color:var(--afn-text);
  box-shadow:0 10px 28px -24px rgba(15,23,42,.18);
  outline:0;
}

.af-watchlist-selects{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.af-watchlist-selects select{
  min-width:180px;
}

.af-watchlist-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border:0;
  border-radius:16px;
  background:linear-gradient(135deg,var(--afn-fuchsia) 0%,var(--afn-pink) 100%);
  color:#fff;
  font-size:.9rem;
  font-weight:800;
  box-shadow:0 20px 40px -22px rgba(192,38,211,.4);
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.af-watchlist-submit:hover{
  transform:translateY(-2px);
  filter:saturate(1.04);
}

.af-watchlist-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.af-watchlist-tab{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.84);
  border:1px solid rgba(192,38,211,.10);
  color:#0f172a;
  text-decoration:none;
  font-size:.88rem;
  font-weight:700;
  box-shadow:0 12px 28px -24px rgba(15,23,42,.18);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, color .18s ease, background .18s ease;
}

.af-watchlist-tab:hover{
  transform:translateY(-2px);
  color:#a21caf;
  border-color:rgba(192,38,211,.18);
}

.af-watchlist-tab.is-active{
  background:linear-gradient(135deg,#fdf4ff,#f5f3ff);
  color:#a21caf;
  border-color:rgba(192,38,211,.18);
}

.af-watchlist-tab__count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  height:24px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(139,92,246,.10);
  color:inherit;
  font-size:.76rem;
  line-height:1;
  font-weight:800;
}

.af-watchlist-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
}

.af-watch-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  overflow:hidden;
  border-radius:32px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(217,70,239,.08);
  box-shadow:0 22px 60px -34px rgba(15,23,42,.16);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
}

.af-watch-card:hover{
  transform:translateY(-3px);
  box-shadow:0 26px 60px -34px rgba(139,92,246,.24);
  border-color:rgba(192,38,211,.14);
}

.af-watch-card__top{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:24px 24px 0;
}

.af-watch-card__badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.af-watch-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 12px;
  border-radius:999px;
  font-size:.76rem;
  font-weight:800;
  line-height:1;
}

.af-watch-badge__icon{
  font-size:.8rem;
  line-height:1;
}

.af-watch-badge--type{
  background:rgba(255,255,255,.82);
  border:1px solid var(--afn-border);
  color:var(--afn-fuchsia-strong);
  box-shadow:0 10px 24px -22px rgba(15,23,42,.25);
}

.af-watch-badge--status{
  border:1px solid transparent;
}

.af-watch-badge--active{
  background:rgba(5,150,105,.10);
  color:var(--afn-green);
  border-color:rgba(5,150,105,.16);
}

.af-watch-badge--updated{
  background:var(--afn-violet-soft);
  color:#6d28d9;
  border-color:rgba(139,92,246,.10);
}

.af-watch-badge--alert{
  background:rgba(236,72,153,.10);
  color:#be185d;
  border-color:rgba(236,72,153,.14);
}

.af-watch-badge--new{
  background:var(--afn-fuchsia-50);
  color:var(--afn-fuchsia-strong);
  border-color:rgba(192,38,211,.12);
}

.af-watch-badge--archived,
.af-watch-badge--neutral{
  background:#f8fafc;
  color:var(--afn-slate-500);
  border-color:rgba(148,163,184,.18);
}

.af-watch-card__remove{
  width:42px;
  height:42px;
  border:1px solid rgba(217,70,239,.10);
  border-radius:16px;
  background:rgba(255,255,255,.78);
  color:var(--afn-slate-600);
  font-size:1.25rem;
  line-height:1;
  box-shadow:0 10px 24px -22px rgba(15,23,42,.16);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, color .2s ease, border-color .2s ease;
}

.af-watch-card__remove:hover{
  transform:translateY(-2px);
  color:var(--afn-fuchsia-strong);
  border-color:rgba(192,38,211,.18);
  box-shadow:0 18px 34px -24px rgba(192,38,211,.16);
}

.af-watch-card__body{
  display:grid;
  gap:14px;
  padding:18px 24px 0;
}

.af-watch-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 10px;
  align-items:center;
}

.af-watch-card__meta-item{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.74);
  border:1px solid var(--afn-border);
  color:var(--afn-text-soft);
  font-size:.8rem;
  font-weight:700;
  box-shadow:0 10px 24px -22px rgba(15,23,42,.25);
}

.af-watch-card__meta-item--soft{
  background:var(--afn-violet-soft);
  color:#6d28d9;
}

.af-watch-card__title{
  margin:0;
  font-size:clamp(1.28rem,1.7vw,1.7rem);
  line-height:1.12;
  letter-spacing:-.03em;
  font-weight:900;
}

.af-watch-card__title a{
  color:var(--afn-slate-950);
}

.af-watch-card__title a:hover{
  color:var(--afn-fuchsia-strong);
}

.af-watch-card__excerpt{
  margin:0;
  color:var(--afn-text-soft);
  font-size:.96rem;
  line-height:1.75;
}

.af-watch-card__footer{
  margin-top:auto;
  padding:20px 24px 24px;
}

.af-watch-card__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:800;
  color:var(--afn-fuchsia-strong);
}

.af-watch-card__link:hover{
  color:var(--afn-fuchsia);
}

.af-watch-card__link::after{
  content:"→";
  transition:transform .22s ease;
}

.af-watch-card__link:hover::after{
  transform:translateX(3px);
}

.af-watch-card--briefing{
  background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(253,244,255,.86) 100%);
}

.af-watch-card--rss_search{
  background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(245,243,255,.88) 100%);
}

.af-watchlist-panel,
.af-watchlist-empty{
  padding:26px;
  border-radius:28px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--afn-shadow);
}

.af-watchlist-empty__title,
.af-watchlist-panel__title{
  margin:14px 0 12px;
  font-size:1.45rem;
  line-height:1.12;
  letter-spacing:-.03em;
  color:var(--afn-slate-950);
}

.af-watchlist-empty__text,
.af-watchlist-panel__text{
  margin:0;
  color:var(--afn-text-soft);
  line-height:1.8;
}

.af-watchlist-empty__actions{
  margin-top:18px;
}

.af-watchlist-empty__button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--afn-fuchsia) 0%,var(--afn-pink) 100%);
  color:#fff;
  font-size:.9rem;
  font-weight:800;
  box-shadow:0 20px 40px -22px rgba(192,38,211,.4);
  transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.af-watchlist-empty__button:hover{
  transform:translateY(-2px);
  filter:saturate(1.04);
}

.af-watchlist-future-grid{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}

.af-watch-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.85);
  border:1px solid var(--afn-border);
  color:var(--afn-text);
  font-size:.88rem;
  font-weight:800;
  box-shadow:0 12px 26px -24px rgba(15,23,42,.16);
}

.af-watch-chip:hover{
  background:linear-gradient(135deg,var(--afn-fuchsia) 0%,var(--afn-pink) 100%);
  color:#fff;
  border-color:transparent;
}

@media (max-width:1199px){
  .af-watchlist-hero{
    grid-template-columns:1fr;
  }
}

@media (max-width:991px){
  .af-watchlist-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:767px){
  .af-watchlist-page{
    padding:22px 0 40px;
  }

  .af-watchlist-hero,
  .af-watchlist-toolbar,
  .af-watchlist-panel,
  .af-watchlist-empty{
    border-radius:24px;
  }

  .af-watch-card{
    border-radius:28px;
  }

  .af-watchlist-hero{
    padding:24px;
  }

  .af-watchlist-toolbar{
    padding:18px;
  }

  .af-watchlist-tabs{
    flex-wrap:nowrap;
    overflow-x:auto;
    padding-bottom:4px;
  }

  .af-watchlist-tab{
    white-space:nowrap;
  }

  .af-watchlist-selects{
    width:100%;
  }

  .af-watchlist-selects select,
  .af-watchlist-submit{
    width:100%;
    flex:1 1 100%;
  }

  .af-watch-card__top{
    padding:20px 20px 0;
  }

  .af-watch-card__body{
    padding:18px 20px 0;
  }

  .af-watch-card__footer{
    padding:20px 20px 20px;
  }
}