/* HB RSS Reader — Dark UI + Red Accent
   Pääväri: #d6111e, vaihtoehto: #ddc76d
*/

.hb-rss{
  --primary:#d6111e;
  --alt:#ddc76d;

  --bg:#0b0c10;
  --panel:#10131a;
  --card:#131827;
  --text:#f3f4f6;
  --muted:#a7b0bf;
  --border:rgba(255,255,255,.10);
  --shadow:0 12px 28px rgba(0,0,0,.45);

  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  margin: 1.25rem 0;
}

.hb-rss__header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:.75rem;
}

.hb-rss__title{
  margin:0;
  font-size:clamp(1.2rem, 2.2vw, 1.75rem);
  letter-spacing:-.02em;
}

.hb-rss__subtitle{
  margin:.2rem 0 0;
  color:var(--muted);
  font-size:.95rem;
}

.hb-rss__refresh{
  border:1px solid rgba(214,17,30,.9);
  background: linear-gradient(180deg, rgba(214,17,30,.95), rgba(214,17,30,.72));
  color:#fff;
  padding:.62rem .9rem;
  border-radius:12px;
  font-weight:900;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .2s ease, filter .2s ease;
  white-space:nowrap;
}
.hb-rss__refresh:hover{ transform: translateY(-1px); box-shadow: 0 14px 28px rgba(214,17,30,.18); }
.hb-rss__refresh:active{ transform: translateY(0); filter: brightness(.96); }
.hb-rss__refresh:focus-visible{ outline:none; box-shadow:0 0 0 4px rgba(214,17,30,.25); }
.hb-rss__refresh.is-loading{ opacity:.75; cursor:progress; }

.hb-rss__tabs{
  position:sticky;
  top:0;
  z-index:5;
  display:flex;
  gap:.5rem;
  padding:.55rem;
  margin:.75rem 0 1rem;
  border:1px solid var(--border);
  border-radius:14px;
  background: rgba(16,19,26,.86);
  backdrop-filter: blur(8px);
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}

.hb-rss__tab{
  flex:0 0 auto;
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:.55rem .82rem;
  border-radius:999px;
  font-weight:850;
  font-size:.95rem;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.hb-rss__tab:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(0,0,0,.35);
  border-color: rgba(214,17,30,.55);
}
.hb-rss__tab.is-active{
  background: linear-gradient(180deg, rgba(214,17,30,.95), rgba(214,17,30,.75));
  color:#fff;
  border-color: rgba(214,17,30,.9);
}
.hb-rss__tab:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(214,17,30,.25);
}

.hb-rss__panel{ display:none; }
.hb-rss__panel.is-active{ display:block; }

/* LISTA (ei grid) */
.hb-rss__list{
  display:flex;
  flex-direction:column;
  gap:.85rem;
}

/* Uutiskortti */
.hb-rss__item{
  border:1px solid var(--border);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(19,24,39,.95), rgba(16,19,26,.95));
  padding: 1rem 1rem .95rem;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}

.hb-rss__item::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  background: var(--primary);
  opacity:.95;
}

.hb-rss__item::after{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 20% 20%, rgba(214,17,30,.18), transparent 45%);
  pointer-events:none;
}

.hb-rss__item-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  margin-bottom:.55rem;
}

.hb-rss__source{
  font-weight:900;
  font-size:.78rem;
  letter-spacing:.02em;
  color:#fff;
  background: rgba(214,17,30,.18);
  border:1px solid rgba(214,17,30,.45);
  padding:.2rem .55rem;
  border-radius:999px;
  max-width:70%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.hb-rss__date{
  font-size:.8rem;
  color: var(--muted);
  white-space:nowrap;
}

.hb-rss__headline{
  margin:.1rem 0 .35rem;
  font-size:1.08rem;
  line-height:1.25;
  letter-spacing:-.01em;
}

.hb-rss__headline a{
  color: var(--text);
  text-decoration:none;
}
.hb-rss__headline a:hover{
  text-decoration: underline;
  text-decoration-color: rgba(214,17,30,.9);
}

.hb-rss__excerpt{
  margin:0 0 .75rem;
  color: var(--muted);
  line-height:1.48;
}

.hb-rss__cta{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-weight:900;
  color:#fff;
  text-decoration:none;
  background: rgba(214,17,30,.18);
  border: 1px solid rgba(214,17,30,.55);
  padding: .45rem .65rem;
  border-radius: 12px;
}
.hb-rss__cta:hover{
  background: rgba(214,17,30,.28);
  border-color: rgba(214,17,30,.85);
}

.hb-rss__empty{
  border:1px dashed rgba(255,255,255,.18);
  border-radius:16px;
  padding:1rem;
  color: var(--muted);
  background: rgba(255,255,255,.03);
}

/* Mobiili */
@media (max-width: 640px){
  .hb-rss__refresh{ width:100%; }
  .hb-rss__item-top{ align-items:flex-start; flex-direction:column; }
  .hb-rss__date{ white-space:normal; }
}

/* Toast */
.hb-rss__toast{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:9999;
  background:#0f1117;
  color:#fff;
  padding:.7rem .9rem;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 12px 30px rgba(0,0,0,.5);
  opacity:0;
  transform: translateY(6px);
  pointer-events:none;
  transition: opacity .2s ease, transform .2s ease;
  max-width: min(360px, calc(100vw - 32px));
  font-weight:850;
}
.hb-rss__toast::before{
  content:"";
  display:block;
  height:3px;
  border-radius:999px;
  background: var(--primary);
  margin-bottom:.45rem;
}
.hb-rss__toast.is-show{ opacity:1; transform: translateY(0); }
