﻿/* ============================================================
   NEW FEATURE STYLES — appended
   ============================================================ */

/* ── Nav More Dropdown ─────────────────────────────────────── */
.nav-more-item{position:relative}
.nav-more-btn{
  background:none;border:none;display:flex;align-items:center;gap:.3rem;
  cursor:pointer;color:var(--text2);font-size:.9rem;font-weight:500;
  padding:.5rem .85rem;border-radius:var(--radius-sm);transition:all var(--transition);
}
.nav-more-btn:hover,.nav-more-btn.active{color:var(--text);background:var(--bg3)}
.nav-more-dropdown{
  position:absolute;top:calc(100% + .4rem);right:0;left:auto;min-width:190px;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:.4rem;list-style:none;margin:0;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all var(--transition);
  z-index:1100;
}
.nav-more-dropdown.open{opacity:1;visibility:visible;transform:none}
.nav-more-dropdown li a{
  display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;
  border-radius:var(--radius-sm);color:var(--text2);font-size:.88rem;
  transition:background var(--transition);
}
.nav-more-dropdown li a:hover,.nav-more-dropdown li a.active{
  background:var(--bg3);color:var(--text);
}

/* Mobile override — must live in features.css (loads after style.css) so it wins */
@media(max-width:768px){
  .nav-more-item{position:static}
  .nav-more-dropdown{
    position:static !important;opacity:1 !important;visibility:visible !important;
    transform:none !important;box-shadow:none;border:none;
    border-top:1px solid var(--border);background:var(--bg3);
    border-radius:0;padding:.25rem 0;min-width:unset;
    display:none;z-index:auto;
  }
  .nav-more-dropdown.open{display:block}
  .nav-more-dropdown li a{padding:.65rem 1.75rem;border-radius:0}
}

/* ── Rank Badge ────────────────────────────────────────────── */
.rank-badge{
  display:flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-size:1rem;font-weight:800;
  box-shadow:0 2px 8px var(--accent-glow);flex-shrink:0;
}
.rank-badge:nth-child(1){background:linear-gradient(135deg,#f59e0b,#fbbf24)} /* gold */

/* ── Countdown Live ────────────────────────────────────────── */
.countdown-live{
  font-size:.78rem;font-weight:700;color:var(--airing);
  display:inline-block;
}
.airing-now{
  color:var(--airing);
  animation:pulse-airing 1.5s ease-in-out infinite;
}
@keyframes pulse-airing{
  0%,100%{opacity:1}
  50%{opacity:.5}
}

/* ── Upcoming Hero (shared with top/watchorder) ────────────── */
.upcoming-hero{
  background:linear-gradient(135deg,#0a0e1a 0%,#1a1040 50%,#0a1428 100%);
  padding:3rem 1.25rem 2rem;text-align:center;border-bottom:1px solid var(--border);
}
.upcoming-hero-inner{max-width:700px;margin:0 auto}

/* ── Upcoming Cards ────────────────────────────────────────── */
.upcoming-card .card-info{position:relative}
.upcoming-premiere-badge{
  display:inline-block;padding:.2rem .55rem;border-radius:4px;font-size:.72rem;font-weight:700;
  background:rgba(99,102,241,.18);color:var(--accent2);border:1px solid rgba(99,102,241,.25);
  margin-bottom:.3rem;
}
.upcoming-premiere-badge.upcoming-soon{
  background:rgba(245,158,11,.12);color:var(--warning);border-color:rgba(245,158,11,.25);
}

/* ── Top Anime Page ────────────────────────────────────────── */
.top-tabs{
  display:flex;gap:.4rem;flex-wrap:wrap;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:.35rem;
}
.top-tab{
  padding:.45rem 1rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;
  color:var(--text2);transition:all var(--transition);
}
.top-tab:hover{color:var(--text);background:var(--bg3)}
.top-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}

.top-list{display:flex;flex-direction:column;gap:.75rem}
.top-row{
  display:flex;align-items:center;gap:1rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:.85rem 1rem;transition:all var(--transition);
}
.top-row:hover{border-color:rgba(99,102,241,.3);box-shadow:var(--shadow)}
.top-cover-link{flex-shrink:0}
.top-cover{width:52px;height:74px;object-fit:cover;border-radius:var(--radius-sm);display:block}
.top-cover-placeholder{width:52px;height:74px;background:var(--bg3);border-radius:var(--radius-sm)}
.top-info{flex:1;min-width:0}
.top-title{font-weight:700;font-size:.95rem;margin-bottom:.35rem}
.top-title a{color:var(--text)}
.top-title a:hover{color:var(--accent2)}
.top-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-bottom:.3rem}
.score-pill{
  display:inline-flex;align-items:center;gap:.25rem;
  background:rgba(245,158,11,.1);color:var(--warning);
  padding:.15rem .5rem;border-radius:4px;font-size:.78rem;font-weight:700;
}
.top-genres{font-size:.78rem;color:var(--text3);margin-bottom:.25rem}
.top-synopsis{font-size:.82rem;color:var(--text2);line-height:1.5;margin:0}

/* Pagination */
.pagination{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:2rem}
.page-btn{
  padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;
  background:var(--bg2);border:1px solid var(--border);color:var(--text2);
  transition:all var(--transition);cursor:pointer;
}
.page-btn:hover{background:var(--bg3);color:var(--text)}
.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ── Watch Order Page ──────────────────────────────────────── */
.wo-search-bar{
  display:flex;align-items:center;gap:.7rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:.65rem 1rem;max-width:480px;
}
.wo-search-bar i{color:var(--text3)}
.wo-search-bar input{flex:1;background:none;border:none;color:var(--text);outline:none;font-size:.95rem}

.wo-franchise{margin-bottom:2.5rem}
.wo-franchise-header{
  display:flex;align-items:flex-start;gap:1rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem 1.25rem;margin-bottom:.5rem;
  border-left:4px solid var(--wo-color, var(--accent));
}
.wo-icon{font-size:1.6rem;line-height:1;flex-shrink:0;margin-top:.1rem}
.wo-franchise-title{flex:1;min-width:0}
.wo-franchise-title h2{font-size:1.2rem;font-weight:800;margin:0 0 .2rem}
.wo-franchise-title p{color:var(--text2);font-size:.87rem;margin:0}
.wo-toggle{align-self:flex-start;flex-shrink:0}

.wo-entries{
  display:flex;flex-direction:column;gap:.5rem;
  padding-left:1rem;border-left:2px solid var(--border);margin-left:1rem;
}
.watch-order-card{
  display:flex;align-items:flex-start;gap:.85rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.85rem 1rem;transition:all var(--transition);
}
.watch-order-card:hover{border-color:rgba(99,102,241,.25);background:var(--bg3)}
.wo-num{
  min-width:28px;height:28px;border-radius:50%;
  background:var(--bg4);color:var(--text2);font-size:.78rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem;
}
.wo-entry-info{flex:1;min-width:0}
.wo-entry-title{font-weight:600;font-size:.9rem;margin-bottom:.25rem}
.wo-entry-title a{color:var(--text)}
.wo-entry-title a:hover{color:var(--accent2)}
.wo-entry-meta{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.3rem}
.wo-entry-synopsis{font-size:.82rem;color:var(--text2);margin:0;line-height:1.5}
.wo-detail-btn{flex-shrink:0;align-self:center}

/* ── Character Page ────────────────────────────────────────── */
.character-banner{
  background:var(--bg2);border-bottom:1px solid var(--border);padding:2.5rem 0;
}
.character-banner-inner{display:flex;gap:2rem;align-items:flex-start;flex-wrap:wrap}
.character-cover-wrap{flex-shrink:0}
.character-cover{
  width:160px;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  border:2px solid var(--border);display:block;
}
.character-cover-placeholder{
  width:160px;height:240px;border-radius:var(--radius);background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--border);color:var(--text3);font-size:3rem;
}
.character-header-info{flex:1;min-width:240px}
.character-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.character-name{font-family:var(--font-display);font-size:clamp(1.4rem,4vw,2rem);font-weight:800;margin:0}
.character-kanji{color:var(--text2);font-size:1rem;margin:.25rem 0 0}
.character-nicknames{color:var(--text2);font-size:.85rem;margin:.4rem 0 0}

.character-content{padding-top:1.5rem;padding-bottom:3rem}
.character-columns{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
@media(max-width:768px){.character-columns{grid-template-columns:1fr}}

.character-va-list{display:flex;flex-direction:column;gap:.5rem}
.character-va-card{
  display:flex;align-items:center;gap:.75rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.65rem .85rem;
}
.va-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.va-avatar-placeholder{
  width:40px;height:40px;border-radius:50%;background:var(--bg3);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:.9rem;
}
.va-info{display:flex;flex-direction:column;gap:.1rem}
.va-name{font-size:.88rem;font-weight:600;color:var(--text)}
.va-lang{font-size:.75rem;color:var(--text2)}

.character-anime-list{display:flex;flex-direction:column;gap:.4rem}
.character-anime-item{
  display:flex;align-items:center;gap:.7rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.55rem .75rem;text-decoration:none;transition:all var(--transition);
}
.character-anime-item:hover{border-color:rgba(99,102,241,.3);background:var(--bg3)}
.character-anime-thumb{width:36px;height:52px;object-fit:cover;border-radius:4px;flex-shrink:0}
.character-anime-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.character-anime-title{font-size:.85rem;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.character-anime-role{font-size:.75rem;color:var(--text2)}

/* ── Season Calendar ───────────────────────────────────────── */
.year-selector{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}
.year-btn{
  padding:.4rem .9rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;
  color:var(--text2);background:var(--bg2);border:1px solid var(--border);
  transition:all var(--transition);
}
.year-btn:hover{color:var(--text);background:var(--bg3)}
.year-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

.calendar-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.25rem;
}
@media(max-width:1024px){.calendar-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.calendar-grid{grid-template-columns:1fr}}

.calendar-column{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;
}
.calendar-col-header{
  background:var(--bg3);padding:.85rem 1rem;border-bottom:1px solid var(--border);
}
.calendar-season-title{font-size:1rem;font-weight:800;margin:0 0 .15rem}
.calendar-months{font-size:.75rem;color:var(--text2)}
.calendar-anime-list{padding:.6rem;display:flex;flex-direction:column;gap:.4rem;max-height:600px;overflow-y:auto}
.calendar-anime-item{
  display:flex;align-items:center;gap:.5rem;
  padding:.35rem .4rem;border-radius:var(--radius-sm);
  text-decoration:none;transition:background var(--transition);
}
.calendar-anime-item:hover{background:var(--bg3)}
.calendar-anime-cover{width:32px;height:46px;object-fit:cover;border-radius:3px;flex-shrink:0}
.calendar-anime-cover-placeholder{width:32px;height:46px;background:var(--bg3);border-radius:3px;flex-shrink:0}
.calendar-anime-title{
  font-size:.78rem;color:var(--text);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.calendar-empty{color:var(--text3);font-size:.85rem;padding:.75rem .6rem;text-align:center}

/* ── Notification Modal ────────────────────────────────────── */
.notify-modal{
  position:fixed;inset:0;z-index:2000;
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:all var(--transition);
}
.notify-modal.open{opacity:1;visibility:visible}
.notify-modal-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);
}
.notify-modal-box{
  position:relative;z-index:1;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  width:min(440px,92vw);max-height:90vh;overflow-y:auto;
  transform:scale(.96);transition:transform var(--transition);
}
.notify-modal.open .notify-modal-box{transform:scale(1)}
.notify-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.25rem;border-bottom:1px solid var(--border);
}
.notify-modal-header h3{font-size:1.05rem;font-weight:700;margin:0}
.notify-modal-close{
  width:30px;height:30px;border-radius:50%;
  background:var(--bg3);color:var(--text2);font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);
}
.notify-modal-close:hover{background:var(--danger);color:#fff}
.notify-modal-body{padding:1.25rem}

/* Progress dots */
.notify-progress{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.75rem 1.25rem 0;
}
.notify-step-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--bg4);transition:all var(--transition);
}
.notify-step-dot.active{background:var(--accent);transform:scale(1.2)}
.notify-step-dot.done{background:var(--accent2)}

/* Anime preview inside modal */
.notify-anime-preview{
  display:flex;align-items:center;gap:.85rem;margin-bottom:1.25rem;
  background:var(--bg3);border-radius:var(--radius-sm);padding:.65rem;
}
.notify-anime-cover{width:42px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}
.notify-anime-title{font-weight:700;font-size:.92rem;margin:0}
.notify-label{font-size:.9rem;color:var(--text2);margin-bottom:.85rem}

/* Channel buttons */
.notify-channel-buttons{display:flex;gap:.75rem;flex-direction:column}
.notify-channel-btn{
  display:flex;align-items:center;gap:.85rem;
  background:var(--bg3);border:2px solid var(--border);border-radius:var(--radius);
  padding:.85rem 1rem;text-align:left;cursor:pointer;
  transition:all var(--transition);
}
.notify-channel-btn:hover{border-color:var(--accent);background:rgba(99,102,241,.08)}
.notify-channel-icon{font-size:1.5rem;line-height:1;flex-shrink:0}
.notify-channel-name{font-weight:700;font-size:.95rem;display:block;color:var(--text)}
.notify-channel-desc{font-size:.78rem;color:var(--text2);display:block;margin-top:.1rem}

/* Input step */
.notify-input-group{margin-bottom:.85rem}
.notify-input{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:.65rem 1rem;color:var(--text);font-size:.95rem;
  outline:none;transition:border-color var(--transition);
}
.notify-input:focus{border-color:var(--accent)}
.notify-error{
  background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);
  color:var(--danger);border-radius:var(--radius-sm);padding:.55rem .85rem;
  font-size:.85rem;margin-bottom:.75rem;
}
.notify-step-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.75rem}

/* Success step */
.notify-success{text-align:center;padding:1rem 0}
.notify-success-icon{font-size:3rem;margin-bottom:.75rem}
.notify-success h4{font-size:1.15rem;font-weight:700;margin:0 0 .5rem}
.notify-success p{color:var(--text2);font-size:.9rem;margin:0}

/* ============================================================
   LAYOUT TOGGLE + WEEK GRID VIEW
   ============================================================ */

/* ── Layout toggle buttons ─────────────────────────────────── */
.layout-toggle{
  display:flex;gap:2px;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:2px;margin-left:.5rem;flex-shrink:0;
}
.layout-btn{
  width:32px;height:32px;border-radius:calc(var(--radius-sm) - 2px);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:.85rem;transition:all var(--transition);
  cursor:pointer;
}
.layout-btn:hover{color:var(--text);background:var(--bg4)}
.layout-btn.active{background:var(--accent);color:#fff;box-shadow:0 1px 4px var(--accent-glow)}

/* ── Week grid container ────────────────────────────────────── */
.week-grid{
  display:flex;
  flex-direction:column;
  gap:0;
  overflow-x:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg2);
}

/* ── Column ─────────────────────────────────────────────────── */
.week-col{
  display:flex;flex-direction:row;
  border-bottom:1px solid var(--border);
  min-height:0;
}
.week-col:last-child{border-bottom:none}

/* ── Row header (left side label) ──────────────────────────── */
.week-col-header{
  position:sticky;left:0;z-index:20;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.1rem;
  padding:.6rem .6rem;
  min-width:72px;width:72px;flex-shrink:0;
  background:var(--bg3);border-right:1px solid var(--border);
  text-align:center;
  user-select:none;
}
.week-col-today .week-col-header{
  background:var(--accent);
  border-right-color:var(--accent2);
}
.week-col-today{
  background:rgba(99,102,241,.04);
}
.week-col-date{
  font-size:.68rem;font-weight:600;text-transform:uppercase;
  color:var(--text3);letter-spacing:.04em;
}
.week-col-today .week-col-date{color:rgba(255,255,255,.75)}
.week-col-day{
  font-size:.92rem;font-weight:800;color:var(--text);
}
.week-col-today .week-col-day{color:#fff}
.week-col-count{
  font-size:.65rem;color:var(--text3);
  background:var(--bg4);padding:.1rem .35rem;border-radius:9999px;margin-top:.15rem;
}
.week-col-today .week-col-count{background:rgba(255,255,255,.2);color:rgba(255,255,255,.85)}

/* ── Row body (horizontal scroll strip) ─────────────────────── */
.week-col-body{
  display:flex;flex-direction:row;
  flex:1;min-width:0;
  overflow-x:auto;overflow-y:hidden;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
  scroll-snap-type:x proximity;
  padding:6px 4px;
  gap:6px;
  align-items:stretch;
}
.week-col-body::-webkit-scrollbar{height:4px}
.week-col-body::-webkit-scrollbar-track{background:transparent}
.week-col-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ── Empty / loading states ─────────────────────────────────── */
.week-col-empty{
  display:flex;flex-direction:row;align-items:center;
  gap:.5rem;padding:.5rem 1rem;color:var(--text3);font-size:.78rem;
  white-space:nowrap;
}
.week-col-empty i{font-size:1rem;opacity:.4}
.week-col-loading{
  display:flex;align-items:center;justify-content:center;padding:.5rem 1.5rem;
}

/* ── Grid card ──────────────────────────────────────────────── */
.grid-card{
  position:relative;
  flex-shrink:0;
  width:130px;
  border:1px solid var(--border);
  border-radius:6px;
  overflow:hidden;
  scroll-snap-align:start;
  transition:background var(--transition),transform var(--transition);
  display:flex;flex-direction:column;
}
.grid-card:hover{background:var(--bg3);transform:translateY(-2px)}

/* Top bar: time + badge + score + actions */
.grid-card-topbar{
  display:flex;align-items:center;gap:.3rem;
  padding:.28rem .4rem;
  background:var(--bg4);border-bottom:1px solid var(--border);
  font-size:.68rem;line-height:1;
  flex-wrap:nowrap;overflow:hidden;
}
.grid-card-time{
  font-weight:700;color:var(--text);white-space:nowrap;flex-shrink:0;
}
.grid-card-badge{
  background:var(--accent);color:#fff;
  padding:.15rem .35rem;border-radius:3px;
  font-size:.6rem;font-weight:700;text-transform:uppercase;flex-shrink:0;
}
.grid-card-badge[data-type="TV"]{background:#6366f1}
.grid-card-score{
  color:var(--warning);font-weight:700;font-size:.65rem;flex-shrink:0;margin-left:auto;
}
.grid-card-actions{
  display:none;gap:.2rem;margin-left:auto;
}
.grid-card:hover .grid-card-actions{display:flex}
.grid-card:hover .grid-card-score{display:none}
.grid-action-btn{
  width:20px;height:20px;border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);color:var(--text2);font-size:.6rem;
  transition:all var(--transition);cursor:pointer;flex-shrink:0;
}
.grid-action-btn:hover{background:var(--accent);color:#fff}

/* Cover image */
.grid-card-cover-link{display:block;position:relative;overflow:hidden}
.grid-card-cover{
  width:100%;aspect-ratio:3/4;object-fit:cover;display:block;
  transition:transform .35s ease;
}
.grid-card:hover .grid-card-cover{transform:scale(1.04)}

/* Title overlay at bottom */
.grid-card-overlay{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent 0%, rgba(0,0,0,.5) 35%, rgba(0,0,0,.88) 100%);
  padding:1.8rem .4rem .45rem;
  pointer-events:none;
}
.grid-card-title{
  display:block;
  font-size:.72rem;font-weight:700;color:#fff;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.grid-card-genre{
  display:block;font-size:.6rem;color:rgba(255,255,255,.6);margin-top:.15rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ── Column grid mode (7 columns, original layout) ──────────── */
.week-grid--cols {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(150px, 1fr));
  flex-direction: unset;
  overflow-x: auto;
}
.week-grid--cols .week-col {
  flex-direction: column;
  border-bottom: none;
  border-right: 1px solid var(--border);
}
.week-grid--cols .week-col:last-child { border-right: none; }
.week-grid--cols .week-col-header {
  position: sticky; top: 0; left: unset;
  flex-direction: column; justify-content: unset;
  min-width: unset; width: auto;
  border-right: none; border-bottom: 1px solid var(--border);
}
.week-grid--cols .week-col-today .week-col-header {
  border-bottom-color: var(--accent2);
}
.week-grid--cols .week-col-body {
  flex-direction: column;
  overflow-x: hidden; overflow-y: auto;
  max-height: 72vh;
  padding: 0; gap: 0;
  scroll-snap-type: unset;
}
.week-grid--cols .week-col-body::-webkit-scrollbar { width: 4px; height: unset; }
.week-grid--cols .grid-card {
  width: auto; border-radius: 0;
  border: none; border-bottom: 1px solid var(--border);
  scroll-snap-align: unset; transform: none;
}
.week-grid--cols .grid-card:last-child { border-bottom: none; }
.week-grid--cols .grid-card:hover { transform: none; }

/* ── Responsive tweaks for row layout ───────────────────────── */
@media(max-width:640px){
  .week-grid--rows .week-col-header {
    min-width:56px; width:56px; padding:.4rem .3rem;
  }
  .week-col-date{font-size:.58rem}
  .week-col-day{font-size:.78rem}
  .week-grid--rows .grid-card{width:110px}
}
@media(max-width:900px){
  .week-grid--cols {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
  }
}
@media(max-width:600px){
  .week-grid--cols {
    grid-template-columns: repeat(2, minmax(140px, 1fr));
  }
}

/* ============================================================
   SEASON BAR + WEEK NAVIGATION + MOBILE ACCORDION
   ============================================================ */

/* ── Season bar (below navbar) ───────────────────────────────── */
.sched-season-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:1.1rem 0;
}
.sched-season-inner{
  display:flex;align-items:center;justify-content:center;gap:.75rem;overflow-x:auto;
  scrollbar-width:none;
}
.sched-season-inner::-webkit-scrollbar{display:none}
.sched-season-arrow{
  flex-shrink:0;width:34px;height:34px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);color:var(--text2);font-size:.8rem;
  transition:all var(--transition);cursor:pointer;
}
.sched-season-arrow:hover{background:var(--accent);color:#fff}
.sched-season-tabs{
  display:flex;gap:.5rem;flex-shrink:0;
}
.sched-season-tab{
  display:flex;align-items:center;gap:.45rem;
  padding:.55rem 1.4rem;border-radius:var(--radius-sm);font-size:.95rem;font-weight:700;
  color:var(--text2);background:transparent;border:1px solid transparent;
  transition:all var(--transition);cursor:pointer;white-space:nowrap;
  font-family:var(--font-display);
}
.sched-season-tab:hover{color:var(--text);background:var(--bg3);border-color:var(--border)}
.sched-season-tab.active{
  background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:0 2px 12px var(--accent-glow);
}
.sched-season-now{
  font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  background:rgba(255,255,255,.25);padding:.1rem .35rem;border-radius:3px;
}
.sched-season-tab:not(.active) .sched-season-now{
  background:rgba(99,102,241,.15);color:var(--accent2);
}

/* ── Week navigation bar ────────────────────────────────────── */
.week-nav-bar{
  background:var(--bg);border-bottom:1px solid var(--border);
  padding:.5rem 0;
}
.week-nav-inner{
  display:flex;align-items:center;justify-content:center;gap:1rem;
}
.week-nav-btn{
  display:flex;align-items:center;gap:.4rem;
  padding:.35rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;
  color:var(--text2);background:var(--bg2);border:1px solid var(--border);
  transition:all var(--transition);cursor:pointer;
}
.week-nav-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--accent)}
.week-nav-label{
  font-size:.9rem;font-weight:700;color:var(--text);min-width:120px;text-align:center;
}

/* ── Mobile accordion ───────────────────────────────────────── */
.week-accordion{
  display:flex;flex-direction:column;
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  background:var(--bg2);
}
.acc-row{border-bottom:1px solid var(--border)}
.acc-row:last-child{border-bottom:none}

.acc-header{
  width:100%;display:flex;align-items:center;gap:.6rem;
  padding:.7rem 1rem;background:var(--bg2);text-align:left;cursor:pointer;
  transition:background var(--transition);
}
.acc-header:hover{background:var(--bg3)}
.acc-today .acc-header{background:rgba(99,102,241,.1)}
.acc-today .acc-day{color:var(--accent2);font-weight:800}

.acc-date{font-size:.7rem;font-weight:600;color:var(--text3);min-width:42px}
.acc-day{font-size:.92rem;font-weight:700;color:var(--text);flex:1}
.acc-count{
  font-size:.7rem;color:var(--text3);background:var(--bg3);
  padding:.1rem .4rem;border-radius:9999px;
}
.acc-chevron{font-size:.7rem;color:var(--text3);transition:transform var(--transition);flex-shrink:0}

.acc-body{padding:.5rem .75rem .75rem}

/* Mobile cards inside accordion */
.acc-cards{display:flex;flex-direction:column;gap:.4rem}
.mob-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
  overflow:hidden;
}
.mob-card-link{display:flex;align-items:center;gap:.65rem;padding:.4rem;text-decoration:none}
.mob-card-cover{width:42px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}
.mob-card-info{flex:1;min-width:0}
.mob-card-title{
  font-size:.82rem;font-weight:700;color:var(--text);line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.2rem;
}
.mob-card-meta{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;margin-bottom:.15rem}
.mob-card-genre{font-size:.7rem;color:var(--text3)}

/* ============================================================
   CHARACTER ECOSYSTEM STYLES
   ============================================================ */

/* ── Dropdown divider ──────────────────────────────────────── */
.nav-dropdown-divider{
  height:1px;background:var(--border);margin:.25rem .4rem;
}

/* ── Characters Browser ────────────────────────────────────── */
.char-hero{
  background:linear-gradient(135deg,#0a0e1a 0%,#1a0a30 50%,#0a1428 100%);
  padding:3.5rem 1.25rem 2.5rem;text-align:center;border-bottom:1px solid var(--border);
}
.char-hero-inner{max-width:680px;margin:0 auto}

.char-search-wrap{margin-top:1.5rem}
.char-search-box{
  display:flex;align-items:center;gap:.75rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:.65rem 1rem;max-width:520px;margin:0 auto;
  transition:border-color var(--transition);
}
.char-search-box:focus-within{border-color:var(--accent)}
.char-search-box i{color:var(--text3);font-size:.95rem}
.char-search-box input{
  background:none;border:none;outline:none;color:var(--text);font-size:1rem;
  flex:1;min-width:0;
}
.char-search-box input::placeholder{color:var(--text3)}
.char-search-clear{
  background:none;border:none;color:var(--text3);cursor:pointer;
  padding:.1rem .2rem;border-radius:50%;transition:color var(--transition);
}
.char-search-clear:hover{color:var(--text)}

.char-stats-strip{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  margin-top:1.5rem;flex-wrap:wrap;
}
.char-stat{display:flex;flex-direction:column;align-items:center;gap:.1rem}
.char-stat-num{font-size:1.4rem;font-weight:800;color:var(--accent2)}
.char-stat-lbl{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.char-stat-sep{width:1px;height:30px;background:var(--border)}

.char-quick-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:.6rem 0;
}
.char-quick-inner{
  display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;padding:.1rem 0;
}
.char-quick-inner::-webkit-scrollbar{display:none}
.char-quick-link{
  display:flex;align-items:center;gap:.4rem;white-space:nowrap;
  padding:.4rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;
  color:var(--text2);transition:all var(--transition);border:1px solid transparent;
}
.char-quick-link:hover,.char-quick-link.active{
  background:var(--bg3);color:var(--text);border-color:var(--border);
}

.char-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem 0 1rem;flex-wrap:wrap;gap:.75rem;
}
.char-section-title{font-size:1.15rem;font-weight:700;display:flex;align-items:center;gap:.5rem;margin:0}
.char-result-count{font-size:.85rem;color:var(--text3)}

/* ── Character Grid ────────────────────────────────────────── */
.char-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:1rem;padding-bottom:2rem;
}

/* ── Character Card ────────────────────────────────────────── */
.char-card{
  display:flex;flex-direction:column;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;
  cursor:pointer;text-decoration:none;
}
.char-card:hover{
  transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent);
}
.char-card-skeleton{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  min-height:250px;animation:shimmer 1.4s ease infinite;
}
@keyframes shimmer{
  0%,100%{opacity:.6} 50%{opacity:.3}
}
.char-card-img-wrap{
  position:relative;aspect-ratio:3/4;background:var(--bg3);overflow:hidden;
}
.char-card-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.char-card:hover .char-card-img{transform:scale(1.04)}
.char-card-img-ph{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--bg3),var(--bg));
  font-size:2rem;font-weight:800;color:var(--accent2);
}
.char-card-overlay{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,.75),transparent);
  padding:.4rem .5rem .4rem;display:flex;align-items:flex-end;justify-content:flex-end;
}
.char-card-fav{
  display:flex;align-items:center;gap:.25rem;font-size:.72rem;color:rgba(255,255,255,.9);font-weight:600;
}
.char-card-fav i{color:#ff6b8a;font-size:.65rem}
.char-card-rank{
  position:absolute;top:.4rem;left:.4rem;
  background:rgba(0,0,0,.75);color:#fff;
  border-radius:4px;font-size:.7rem;font-weight:700;padding:.1rem .35rem;
  backdrop-filter:blur(4px);
}
.char-card-body{
  padding:.65rem .7rem .8rem;display:flex;flex-direction:column;gap:.15rem;
}
.char-card-name{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.char-card-kanji{font-size:.72rem;color:var(--text3)}
.char-card-from{font-size:.72rem;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.char-empty-state{
  grid-column:1/-1;text-align:center;padding:4rem 1rem;color:var(--text3);
}
.char-empty-state i{font-size:2.5rem;margin-bottom:.75rem;display:block}

/* Pagination */
.char-pagination{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  padding:1.5rem 0 3rem;
}
.char-pag-btn{
  min-width:36px;height:36px;padding:0 .5rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text2);cursor:pointer;font-size:.88rem;transition:all var(--transition);
}
.char-pag-btn:hover:not([disabled]){background:var(--bg3);color:var(--text)}
.char-pag-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.char-pag-btn[disabled]{opacity:.35;cursor:not-allowed}

/* ── Character Detail Hero ─────────────────────────────────── */
.page-char-detail{min-height:100vh}
.char-detail-hero{
  position:relative;padding:3rem 0 2.5rem;overflow:hidden;
}
.char-detail-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:top center;filter:blur(24px) saturate(1.3);
  transform:scale(1.08);
}
.char-detail-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(10,14,26,.7) 0%,rgba(10,14,26,.92) 60%,var(--bg) 100%);
}
.char-detail-hero-inner{
  position:relative;display:flex;gap:2rem;align-items:flex-end;flex-wrap:wrap;
  padding:.5rem 0;
}
.char-detail-avatar-wrap{position:relative;flex-shrink:0}
.char-detail-avatar{
  width:180px;height:260px;object-fit:cover;border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.1);
  display:block;
}
.char-detail-avatar-ph{
  width:180px;height:260px;border-radius:var(--radius);
  background:var(--bg3);display:flex;align-items:center;justify-content:center;
  font-size:3rem;color:var(--text3);
}
.char-detail-hero-info{flex:1;min-width:220px}
.char-detail-breadcrumb{
  display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text3);
  margin-bottom:.6rem;
}
.char-detail-breadcrumb a{color:var(--text3);transition:color var(--transition)}
.char-detail-breadcrumb a:hover{color:var(--accent2)}
.char-detail-name{font-size:2rem;font-weight:900;margin:0 0 .2rem;line-height:1.15}
.char-detail-name-jp{font-size:.95rem;color:var(--text3);margin:.15rem 0 .6rem}
.char-detail-nicknames{font-size:.8rem;color:var(--text3);margin:.1rem 0 .7rem}
.char-detail-anime-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.8rem}
.char-detail-anime-pill{
  padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;
  background:rgba(99,102,241,.15);color:var(--accent2);border:1px solid rgba(99,102,241,.25);
  transition:background var(--transition);
}
.char-detail-anime-pill:hover{background:rgba(99,102,241,.25)}
.char-detail-stats{display:flex;flex-wrap:wrap;gap:.75rem}
.char-detail-stat{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text2)}
.char-detail-stat i{color:var(--accent2);font-size:.78rem}

/* ── Char Tabs ─────────────────────────────────────────────── */
.char-tabs-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  position:sticky;top:60px;z-index:50;
}
.char-tabs{display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.char-tabs::-webkit-scrollbar{display:none}
.char-tab{
  background:none;border:none;border-bottom:2px solid transparent;
  padding:.8rem 1.1rem;font-size:.88rem;font-weight:600;color:var(--text3);
  cursor:pointer;white-space:nowrap;transition:all var(--transition);
  display:flex;align-items:center;gap:.35rem;
}
.char-tab:hover{color:var(--text)}
.char-tab.active{color:var(--accent2);border-bottom-color:var(--accent2)}
.char-tab-count{
  background:var(--bg3);border-radius:10px;font-size:.7rem;
  padding:.05rem .4rem;color:var(--text3);
}

/* ── Char Tab Panels ───────────────────────────────────────── */
.char-tab-panel{display:none}
.char-tab-panel.active{display:block}

/* ── Overview layout ───────────────────────────────────────── */
.char-overview-layout{
  display:grid;grid-template-columns:1fr 320px;gap:1.5rem;
}
@media(max-width:768px){.char-overview-layout{grid-template-columns:1fr}}

/* ── Card box (white box card) ─────────────────────────────── */
.char-card-box{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem 1.4rem;
}
.char-box-heading{
  font-size:.92rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;
}
.char-box-heading i{color:var(--accent)}

.char-about-body{
  font-size:.88rem;color:var(--text2);line-height:1.75;
}
.char-read-more-btn{
  display:inline-flex;align-items:center;gap:.3rem;
  background:none;border:none;color:var(--accent2);cursor:pointer;
  font-size:.82rem;font-weight:600;margin-top:.75rem;padding:0;
}

/* ── Quick facts ───────────────────────────────────────────── */
.char-facts{display:flex;flex-direction:column;gap:0}
.char-fact{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.85rem;gap:.5rem;
}
.char-fact:last-child{border-bottom:none}
.char-fact-lbl{color:var(--text3);white-space:nowrap}
.char-fact-val{color:var(--text);font-weight:600;text-align:right}

/* ── VA highlight card ─────────────────────────────────────── */
.char-va-highlight{
  display:flex;align-items:center;gap:.8rem;padding:.5rem;
  border-radius:var(--radius-sm);transition:background var(--transition);cursor:pointer;
}
.char-va-highlight:hover{background:var(--bg3)}
.char-va-hl-img{
  width:52px;height:52px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border);
}
.char-va-hl-name{font-weight:700;font-size:.88rem;display:block}
.char-va-hl-role{font-size:.75rem;color:var(--text3)}

/* ── VA Grid ───────────────────────────────────────────────── */
.char-va-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;
}
.char-va-card2{
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem .75rem;text-align:center;transition:all var(--transition);
}
.char-va-card2:hover{border-color:var(--accent);transform:translateY(-2px)}
.char-va-card2-img{
  width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--border);
}
.char-va-card2-name{font-size:.85rem;font-weight:700;color:var(--text)}
.char-va-card2-lang{font-size:.75rem;color:var(--text3)}

/* ── Appearance List ───────────────────────────────────────── */
.char-appear-list{display:flex;flex-direction:column;gap:.5rem}
.char-appear-row{
  display:flex;align-items:center;gap:.85rem;padding:.6rem .75rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  transition:all var(--transition);
}
.char-appear-row:hover{border-color:var(--accent);background:var(--bg3)}
.char-appear-img{width:44px;height:62px;object-fit:cover;border-radius:4px;flex-shrink:0}
.char-appear-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}
.char-appear-title{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.char-appear-role{font-size:.76rem;color:var(--text3)}
.char-appear-arrow{color:var(--text3);margin-left:auto;font-size:.8rem;flex-shrink:0}

/* ── Voice Actor Detail ────────────────────────────────────── */
.page-va-detail{min-height:100vh}
.va-hero{position:relative;padding:3rem 0 2.5rem;overflow:hidden}
.va-hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:top center;
  filter:blur(20px) saturate(1.2);transform:scale(1.08);
}
.va-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(10,14,26,.75) 0%,rgba(10,14,26,.95) 70%,var(--bg) 100%);
}
.va-hero-inner{position:relative;display:flex;gap:2rem;align-items:flex-end;flex-wrap:wrap;padding:.5rem 0}
.va-photo-wrap{flex-shrink:0}
.va-photo{
  width:160px;height:220px;object-fit:cover;border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.1);display:block;
}
.va-photo-ph{
  width:160px;height:220px;border-radius:var(--radius);background:var(--bg3);
  display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text3);
}
.va-hero-info{flex:1;min-width:220px}
.va-name{font-size:1.9rem;font-weight:900;margin:.4rem 0 .15rem;line-height:1.2}
.va-name-native{font-size:.9rem;color:var(--text3);margin:0 0 .7rem}
.va-meta-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}
.va-chip{
  display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-sm);padding:.25rem .6rem;font-size:.78rem;color:var(--text2);
}
.va-chip i{color:var(--accent2);font-size:.72rem}

/* ── VA Roles Grid ─────────────────────────────────────────── */
.va-roles-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;
}
.va-role-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;
}
.va-role-char{
  display:flex;align-items:center;gap:.75rem;padding:.75rem;
  border-bottom:1px solid var(--border);transition:background var(--transition);
}
.va-role-char:hover{background:var(--bg3)}
.va-role-char-img{
  width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--border);flex-shrink:0;
}
.va-role-char-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.va-role-char-name{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.va-role-type{font-size:.72rem;color:var(--text3)}
.va-role-anime{
  display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;
  transition:background var(--transition);
}
.va-role-anime:hover{background:var(--bg3)}
.va-role-anime-img{width:36px;height:50px;object-fit:cover;border-radius:4px;flex-shrink:0}
.va-role-anime-title{font-size:.8rem;color:var(--text2);line-height:1.35;min-width:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* ── Birthdays Page ────────────────────────────────────────── */
.page-birthdays{min-height:100vh}
.bday-hero{
  background:linear-gradient(135deg,#0f0a20 0%,#1a0840 40%,#0a1820 100%);
  padding:3rem 1.25rem 2.5rem;text-align:center;border-bottom:1px solid var(--border);
}
.bday-hero-inner{max-width:600px;margin:0 auto}
.bday-hero-icon{
  font-size:2.5rem;margin-bottom:.75rem;
  background:linear-gradient(135deg,var(--accent),#f59e0b);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.bday-date-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-sm);padding:.3rem .8rem;font-size:.85rem;color:var(--text2);
  margin-top:.75rem;
}

.bday-view-tabs{background:var(--bg2);border-bottom:1px solid var(--border);padding:.5rem 0}
.bday-view-inner{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}
.bday-view-tab{
  display:flex;align-items:center;gap:.4rem;padding:.4rem 1rem;border-radius:var(--radius);
  font-size:.88rem;font-weight:600;color:var(--text2);border:1px solid transparent;
  transition:all var(--transition);
}
.bday-view-tab:hover{background:var(--bg3);color:var(--text)}
.bday-view-tab.active{background:var(--accent);color:#fff}

.bday-main{padding:2rem 0 3rem}

/* ── Today's birthdays ─────────────────────────────────────── */
.bday-section-header{margin-bottom:1.25rem}
.bday-section-title{
  font-size:1.2rem;font-weight:800;margin:0;display:flex;align-items:center;gap:.6rem;
}
.bday-section-date{
  font-size:.82rem;font-weight:500;color:var(--text3);
  background:var(--bg3);border-radius:var(--radius-sm);padding:.15rem .5rem;
}

.bday-today-cards{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;
}
.bday-char-featured{
  display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--accent);
  border-radius:var(--radius);overflow:hidden;transition:all var(--transition);
  box-shadow:0 0 16px rgba(99,102,241,.15);
}
.bday-char-featured:hover{transform:translateY(-3px);box-shadow:0 4px 24px rgba(99,102,241,.25)}
.bday-char-card{
  display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;transition:all var(--transition);
}
.bday-char-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.bday-char-img-wrap{
  position:relative;aspect-ratio:3/4;background:var(--bg3);overflow:hidden;
}
.bday-char-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.bday-char-featured:hover .bday-char-img,.bday-char-card:hover .bday-char-img{transform:scale(1.04)}
.bday-char-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 60%);
}
.bday-char-info{padding:.65rem .75rem .8rem;display:flex;flex-direction:column;gap:.15rem}
.bday-char-name{font-size:.88rem;font-weight:700;color:var(--text)}
.bday-char-anime{font-size:.75rem;color:var(--text3)}
.bday-char-today-tag{
  display:inline-flex;align-items:center;gap:.25rem;
  font-size:.72rem;font-weight:700;color:#f59e0b;margin-top:.2rem;
}

.bday-empty{
  text-align:center;padding:3rem 1rem;color:var(--text3);
}
.bday-empty i{font-size:2.5rem;margin-bottom:.75rem;display:block}

/* ── Upcoming birthdays ─────────────────────────────────────── */
.bday-upcoming-list{display:flex;flex-direction:column;gap:1rem}
.bday-upcoming-day{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;
}
.bday-upcoming-date{
  padding:.5rem .9rem;background:var(--bg3);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.5rem;
}
.bday-upcoming-date-day{font-weight:700;font-size:.88rem}
.bday-upcoming-chars{display:flex;flex-direction:column;gap:0}
.bday-upcoming-char{
  display:flex;align-items:center;gap:.75rem;padding:.6rem .9rem;
  transition:background var(--transition);border-bottom:1px solid var(--border);
}
.bday-upcoming-char:last-child{border-bottom:none}
.bday-upcoming-char:hover{background:var(--bg3)}
.bday-upcoming-img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border)}
.bday-upcoming-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.bday-upcoming-name{font-size:.85rem;font-weight:700;color:var(--text)}
.bday-upcoming-anime{font-size:.75rem;color:var(--text3)}

/* ── Birthday calendar ─────────────────────────────────────── */
.bday-month-nav{
  display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1rem;
}
.bday-month-title{font-size:1.4rem;font-weight:800;margin:0}
.bday-month-arrow{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;background:var(--bg2);
  border:1px solid var(--border);color:var(--text2);transition:all var(--transition);
}
.bday-month-arrow:hover{background:var(--accent);border-color:var(--accent);color:#fff}

.bday-month-pills{
  display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center;margin-bottom:1.5rem;
}
.bday-month-pill{
  padding:.3rem .7rem;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;
  background:var(--bg2);border:1px solid var(--border);color:var(--text2);
  transition:all var(--transition);
}
.bday-month-pill:hover{background:var(--bg3);color:var(--text)}
.bday-month-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.bday-month-pill.current{border-color:var(--accent2)}

.bday-calendar-grid{display:flex;flex-direction:column;gap:.75rem}
.bday-cal-row{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;display:flex;align-items:stretch;
}
.bday-cal-today{border-color:var(--accent);box-shadow:0 0 12px rgba(99,102,241,.15)}
.bday-cal-date{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:.75rem .9rem;background:var(--bg3);border-right:1px solid var(--border);
  min-width:60px;gap:.1rem;
}
.bday-cal-day-num{font-size:1.4rem;font-weight:900;line-height:1;color:var(--text)}
.bday-cal-month-abbr{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.bday-cal-today-tag{
  font-size:.62rem;font-weight:700;color:#fff;background:var(--accent);
  border-radius:4px;padding:.08rem .3rem;margin-top:.25rem;
}
.bday-cal-chars{flex:1;display:flex;flex-direction:column;gap:0}
.bday-cal-char{
  display:flex;align-items:center;gap:.65rem;padding:.5rem .85rem;
  transition:background var(--transition);border-bottom:1px solid var(--border);
}
.bday-cal-char:last-child{border-bottom:none}
.bday-cal-char:hover{background:var(--bg3)}
.bday-cal-char-img{
  width:36px;height:36px;border-radius:50%;object-fit:cover;
  flex-shrink:0;border:1px solid var(--border);
}
.bday-cal-char-info{display:flex;flex-direction:column;gap:.08rem;min-width:0}
.bday-cal-char-name{font-size:.84rem;font-weight:700;color:var(--text)}
.bday-cal-char-anime{font-size:.73rem;color:var(--text3)}

/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:640px){
  .char-detail-avatar{width:130px;height:190px}
  .char-detail-avatar-ph{width:130px;height:190px}
  .char-detail-name{font-size:1.5rem}
  .va-photo{width:120px;height:165px}
  .char-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .bday-cal-row{flex-direction:column}
  .bday-cal-date{flex-direction:row;justify-content:flex-start;min-width:unset;border-right:none;border-bottom:1px solid var(--border);gap:.5rem;padding:.5rem .85rem}
  .bday-cal-day-num{font-size:1rem}
}

/* ============================================================
   ANIME DETAIL PAGE (page-anime-detail2)
   ============================================================ */

/* Breadcrumb bar */
.ad2-breadcrumb-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:.6rem 0;
}
.ad2-breadcrumb{
  display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text3);
  flex-wrap:wrap;
}
.ad2-breadcrumb a{color:var(--text3);transition:color var(--transition)}
.ad2-breadcrumb a:hover{color:var(--accent)}
.ad2-breadcrumb .fa-chevron-right{font-size:.65rem}
.ad2-breadcrumb span{color:var(--text2)}

/* 3-column layout */
.ad2-layout{
  display:grid;
  grid-template-columns:220px 1fr 260px;
  grid-template-rows:auto;
  gap:1.5rem;
  padding-top:1.5rem;
  padding-bottom:3rem;
  align-items:start;
}
.ad2-left{grid-column:1;display:flex;flex-direction:column;gap:1rem}
.ad2-main{grid-column:2;display:flex;flex-direction:column;gap:1.25rem}
.ad2-right{grid-column:3;display:flex;flex-direction:column;gap:1rem}

/* Cover */
.ad2-cover-wrap{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.ad2-cover{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}
.ad2-airing-badge{
  position:absolute;top:.5rem;left:.5rem;
  background:var(--success,#22c55e);color:#fff;
  font-size:.7rem;font-weight:700;padding:.2rem .55rem;
  border-radius:20px;display:flex;align-items:center;gap:.3rem;
}
.ad2-airing-badge .fa-circle-dot{animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Score block */
.ad2-score-block{
  display:flex;align-items:center;gap:.75rem;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:.85rem 1rem;
}
.ad2-score-circle{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2,#a855f7));
  color:#fff;
}
.ad2-score-num{font-size:1.05rem;font-weight:800;line-height:1}
.ad2-score-lbl{font-size:.6rem;opacity:.8;text-transform:uppercase;letter-spacing:.05em}
.ad2-score-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--text3)}
.ad2-score-stat{display:flex;align-items:center;gap:.35rem}
.ad2-score-stat i{color:var(--accent);width:.9rem;text-align:center}

/* Sidebar card */
.ad2-sidebar-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:.9rem 1rem;
}
.ad2-sidebar-card-title{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--text3);margin:0 0 .6rem;
  display:flex;align-items:center;gap:.4rem;
}
.ad2-sidebar-card-title i{color:var(--accent)}

/* Next episode / countdown */
.ad2-next-ep{margin-bottom:.6rem}
.ad2-next-ep-label{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem}
.ad2-next-ep-day{font-weight:700;color:var(--text);font-size:.95rem}
.ad2-next-ep-time{font-size:.82rem;color:var(--text2)}
.ad2-countdown-wrap{display:flex;align-items:center;justify-content:space-between;font-size:.8rem}
.ad2-countdown-label{color:var(--text3)}
.ad2-countdown{font-weight:700;color:var(--accent);font-size:.95rem;font-variant-numeric:tabular-nums}
.ad2-broadcast-str{font-size:.85rem;color:var(--text2)}

/* Genre / studio tag clouds */
.ad2-tag-cloud{display:flex;flex-wrap:wrap;gap:.35rem}
.ad2-genre-tag{
  font-size:.72rem;padding:.25rem .6rem;border-radius:20px;
  background:var(--bg3);color:var(--text2);border:1px solid var(--border);
  transition:all var(--transition);
}
.ad2-genre-tag:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.ad2-studio-tag{
  font-size:.72rem;padding:.25rem .6rem;border-radius:20px;
  background:var(--bg3);color:var(--text2);border:1px solid var(--border);
}

/* Synonyms */
.ad2-synonyms{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}
.ad2-synonyms li{font-size:.8rem;color:var(--text2);line-height:1.4}

/* Title block */
.ad2-title-block{margin-bottom:.25rem}
.ad2-title{font-size:1.9rem;font-weight:800;line-height:1.2;margin:0 0 .3rem;color:var(--text)}
.ad2-title-jp{font-size:.9rem;color:var(--text3);margin-bottom:.15rem}
.ad2-title-alt{font-size:.85rem;color:var(--text3)}

/* Info bar */
.ad2-info-bar{
  display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:.75rem 1rem;
}
.ad2-info-chip{
  font-size:.75rem;font-weight:700;padding:.3rem .7rem;
  border-radius:20px;border:1px solid var(--border);
  text-transform:uppercase;letter-spacing:.05em;
}
.ad2-chip-type{background:var(--accent);color:#fff;border-color:var(--accent)}
.ad2-chip-season{background:var(--bg3);color:var(--text2)}
.ad2-chip-source{background:var(--bg3);color:var(--text3)}
.ad2-info-pill{
  display:flex;align-items:center;gap:.35rem;font-size:.8rem;
  background:var(--bg3);border:1px solid var(--border);
  padding:.25rem .65rem;border-radius:20px;
}
.ad2-pill-lbl{color:var(--text3);font-weight:600}
.ad2-pill-val{color:var(--text)}
.ad2-status-airing{color:var(--success,#22c55e)!important;font-weight:700}

/* Section */
.ad2-section{display:flex;flex-direction:column;gap:.75rem}
.ad2-section-heading{
  font-size:.85rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text3);
  margin:0;display:flex;align-items:center;gap:.5rem;
  border-bottom:1px solid var(--border);padding-bottom:.5rem;
}
.ad2-section-heading::before{
  content:'';display:block;width:3px;height:1em;
  background:var(--accent);border-radius:2px;
}

/* Synopsis */
.ad2-synopsis{
  font-size:.9rem;line-height:1.75;color:var(--text2);
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem 1.1rem;
}
.ad2-synopsis-collapsed{
  display:-webkit-box;-webkit-box-orient:vertical;
  -webkit-line-clamp:6;overflow:hidden;
}
.ad2-synopsis-toggle{
  background:none;border:1px solid var(--border);
  padding:.4rem 1rem;border-radius:20px;cursor:pointer;
  color:var(--accent);font-size:.82rem;font-weight:600;
  align-self:flex-start;transition:all var(--transition);
}
.ad2-synopsis-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Streaming */
.ad2-stream-grid{display:flex;flex-wrap:wrap;gap:.6rem}
.ad2-stream-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1rem;border-radius:var(--radius);
  font-size:.83rem;font-weight:700;
  background:var(--brand-color,#6366f1);color:#fff;
  transition:opacity var(--transition), transform var(--transition);
  border:none;
}
.ad2-stream-btn:hover{opacity:.85;transform:translateY(-1px)}

/* Info sites */
.ad2-info-sites{display:flex;flex-wrap:wrap;gap:.6rem}
.ad2-info-site-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem .9rem;border-radius:var(--radius);
  font-size:.8rem;font-weight:600;
  background:var(--bg2);color:var(--text2);
  border:1px solid var(--border);
  transition:all var(--transition);
}
.ad2-info-site-btn:hover{
  background:var(--site-color,var(--accent));color:#fff;
  border-color:var(--site-color,var(--accent));
}
.ad2-site-icon{
  font-size:.7rem;font-weight:900;
  background:var(--site-color,var(--accent));color:#fff;
  padding:.1rem .35rem;border-radius:4px;line-height:1.4;
}
.ad2-mal-icon{background:#2e51a2}
.ad2-al-icon{background:#02a9ff}

/* Trailer */
.ad2-trailer-wrap{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9}
.ad2-trailer-frame{width:100%;height:100%;border:none}

/* Background text */
.ad2-background-text{
  font-size:.87rem;line-height:1.7;color:var(--text2);
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem 1.1rem;
}

/* Relations */
.ad2-relations{display:flex;flex-wrap:wrap;gap:.5rem}
.ad2-relation-chip{
  display:inline-flex;flex-direction:column;
  padding:.35rem .75rem;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg2);
  transition:all var(--transition);
}
.ad2-relation-chip:hover{background:var(--bg3);border-color:var(--accent)}
.ad2-relation-type{font-size:.65rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.1rem}
.ad2-relation-chip>span:last-child{font-size:.8rem;color:var(--text2)}

/* ── Right sidebar ──────────────────────────────────────────── */

/* Tracking widget */
.ad2-track-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem;
}
.ad2-track-title{
  font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text3);margin:0 0 .75rem;
  display:flex;align-items:center;gap:.4rem;
}
.ad2-track-title::before{
  content:'';display:block;width:3px;height:1em;
  background:var(--accent);border-radius:2px;
}
.ad2-track-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.ad2-track-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;
  padding:.7rem .5rem;border-radius:var(--radius-sm);
  border:1.5px solid var(--border);background:var(--bg3);
  cursor:pointer;color:var(--text2);font-size:.78rem;font-weight:600;
  transition:all var(--transition);
}
.ad2-track-btn i{font-size:1.1rem;color:var(--track-color)}
.ad2-track-btn:hover,.ad2-track-btn.active{
  background:var(--track-color);color:#fff;border-color:var(--track-color);
}
.ad2-track-btn:hover i,.ad2-track-btn.active i{color:#fff}
.ad2-track-current{
  margin-top:.65rem;font-size:.78rem;color:var(--text3);
  text-align:center;border-top:1px solid var(--border);padding-top:.5rem;
}

/* Similar anime */
.ad2-similar-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem;
}
.ad2-similar-title{
  font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text3);margin:0 0 .75rem;
  display:flex;align-items:center;gap:.4rem;
}
.ad2-similar-title::before{
  content:'';display:block;width:3px;height:1em;
  background:var(--accent);border-radius:2px;
}
.ad2-similar-list{display:flex;flex-direction:column;gap:.5rem}
.ad2-similar-row{
  display:flex;align-items:center;gap:.65rem;
  padding:.4rem;border-radius:var(--radius-sm);
  transition:background var(--transition);
}
.ad2-similar-row:hover{background:var(--bg3)}
.ad2-similar-img{
  width:40px;height:56px;object-fit:cover;
  border-radius:4px;flex-shrink:0;
}
.ad2-similar-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.ad2-similar-name{
  font-size:.8rem;color:var(--text);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ad2-similar-votes{font-size:.7rem;color:var(--text3)}

/* Info card (details) */
.ad2-info-card2{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem;
}
.ad2-info-card2-title{
  font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text3);margin:0 0 .75rem;
  display:flex;align-items:center;gap:.4rem;
}
.ad2-info-card2-title::before{
  content:'';display:block;width:3px;height:1em;
  background:var(--accent);border-radius:2px;
}
.ad2-detail-row{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:.4rem 0;border-bottom:1px solid var(--border);font-size:.8rem;gap:.5rem;
}
.ad2-detail-row:last-child{border-bottom:none}
.ad2-detail-lbl{color:var(--text3);font-weight:600;flex-shrink:0}
.ad2-detail-val{color:var(--text2);text-align:right}

/* Skeleton loader */
.ad2-skeleton-layout{
  display:grid;grid-template-columns:200px 1fr 230px;gap:1.5rem;
  padding-top:1.5rem;padding-bottom:3rem;
}
.ad2-skel-left,.ad2-skel-main,.ad2-skel-right{display:flex;flex-direction:column}
.skel-block{
  background:linear-gradient(90deg,var(--bg3) 25%,var(--bg2) 50%,var(--bg3) 75%);
  background-size:200% 100%;
  animation:skelShimmer 1.5s infinite;
  flex-shrink:0;
}
@keyframes skelShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@media(max-width:900px){
  .ad2-skeleton-layout{grid-template-columns:180px 1fr}
  .ad2-skel-right{display:none}
}
@media(max-width:640px){
  .ad2-skeleton-layout{grid-template-columns:1fr}
  .ad2-skel-left,.ad2-skel-right{display:none}
}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1100px){
  .ad2-layout{grid-template-columns:200px 1fr 230px}
}
@media(max-width:900px){
  .ad2-layout{
    grid-template-columns:180px 1fr;
    grid-template-rows:auto auto;
  }
  .ad2-left{grid-column:1;grid-row:1}
  .ad2-main{grid-column:2;grid-row:1}
  .ad2-right{grid-column:1/-1;grid-row:2;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
}
@media(max-width:640px){
  .ad2-layout{grid-template-columns:1fr}
  .ad2-left{grid-column:1;grid-row:auto}
  .ad2-cover{aspect-ratio:3/4;max-width:200px;margin:0 auto}
  .ad2-cover-wrap{max-width:200px;margin:0 auto}
  .ad2-main{grid-column:1;grid-row:auto}
  .ad2-right{grid-column:1;grid-row:auto;display:flex;flex-direction:column}
  .ad2-title{font-size:1.4rem}
  .ad2-track-grid{grid-template-columns:1fr 1fr}
  .ad2-info-bar{gap:.4rem}
}

/* ── Comments Section ──────────────────────────────────────── */
.comments-section{
  margin:2.5rem 0 3rem;
}
.comments-heading{
  font-family:var(--font-display);font-size:1.25rem;font-weight:700;
  display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;
  padding-bottom:.75rem;border-bottom:1px solid var(--border);
}
.comments-heading i{color:var(--accent2)}

/* Post form */
.comment-form-wrap{
  display:flex;gap:.85rem;margin-bottom:1.75rem;
}
.comment-avatar-col{flex-shrink:0}
.comment-avatar{
  width:38px;height:38px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border);
}
.comment-avatar-init{
  width:38px;height:38px;border-radius:50%;
  background:var(--accent);color:#fff;font-weight:700;font-size:.9rem;
  display:flex;align-items:center;justify-content:center;
}
.comment-input-col{flex:1;display:flex;flex-direction:column;gap:.5rem}
.comment-textarea{
  width:100%;background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text);padding:.75rem 1rem;
  font-size:.9rem;line-height:1.5;resize:vertical;
  transition:border-color var(--transition);outline:none;
}
.comment-textarea:focus{border-color:var(--accent)}
.comment-form-footer{
  display:flex;align-items:center;justify-content:space-between;
}
.comment-char-count{font-size:.78rem;color:var(--text3)}
.comment-login-prompt{
  display:flex;align-items:center;gap:.6rem;
  padding:1rem 1.25rem;background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text2);font-size:.9rem;margin-bottom:1.5rem;
}
.comment-login-prompt i{color:var(--text3)}
.comment-login-prompt a{color:var(--accent2)}

/* Comments list */
.comments-list{display:flex;flex-direction:column;gap:1rem}
.comments-empty{
  text-align:center;padding:2.5rem 1rem;color:var(--text3);
}
.comments-empty i{font-size:2rem;display:block;margin-bottom:.5rem;opacity:.5}
.comments-empty p{font-size:.9rem}

/* Individual comment */
.comment-item{
  display:flex;gap:.85rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem 1.1rem;transition:border-color var(--transition);
}
.comment-item:hover{border-color:rgba(99,102,241,.25)}
.comment-body{flex:1}
.comment-meta{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.comment-user{font-size:.85rem;font-weight:700;color:var(--text)}
.comment-time{font-size:.75rem;color:var(--text3)}
.comment-text{font-size:.9rem;color:var(--text2);line-height:1.6;word-break:break-word}
.comment-actions{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}
.comment-like-btn{
  display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;
  color:var(--text3);transition:color var(--transition);cursor:pointer;background:none;border:none;
  padding:0;font-family:inherit;
}
.comment-like-btn:hover,.comment-like-btn.liked{color:var(--danger)}
.comment-like-btn.liked i{color:var(--danger)}
.comment-delete-btn{
  font-size:.78rem;color:var(--text3);transition:color var(--transition);
  cursor:pointer;background:none;border:none;padding:0;font-family:inherit;
}
.comment-delete-btn:hover{color:var(--danger)}

/* ── Slim footer (container removed) ──────────────────────── */
.site-footer-slim{
  padding:1rem 1.25rem;margin-top:2rem;
}
.site-footer-slim .footer-bottom{
  max-width:1280px;margin:0 auto;
  display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;
  font-size:.8rem;color:var(--text3);
  padding-top:0;border-top:none;
}

/* ── Footer nav row ────────────────────────────────────────── */
.footer-nav-row{
  border-top:1px solid var(--border);
  padding:.85rem 1.25rem;
  max-width:1280px;margin:0 auto;
}
.footer-nav-links{
  display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .1rem;
  justify-content:center;
}
.footer-nav-links a{
  color:var(--text3);font-size:.8rem;padding:.25rem .65rem;
  border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);
  white-space:nowrap;
}
.footer-nav-links a:hover{color:var(--text2);background:var(--bg3)}
.footer-nav-divider{
  width:1px;height:14px;background:var(--border);margin:0 .3rem;
  align-self:center;display:inline-block;
}

/* ── Reply styles ──────────────────────────────────────────── */
.comment-reply{
  margin-left:2.5rem;margin-top:.6rem;
  background:var(--bg3);border-color:rgba(255,255,255,.05);
}
.comment-reply-count{
  font-size:.72rem;color:var(--accent2);background:rgba(99,102,241,.12);
  padding:.1rem .45rem;border-radius:10px;
}
.comment-reply-btn{
  display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;
  color:var(--text3);transition:color var(--transition);cursor:pointer;
  background:none;border:none;padding:0;font-family:inherit;
}
.comment-reply-btn:hover{color:var(--accent2)}
.reply-form-wrap{
  margin-top:.65rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);
  padding:.75rem;
}
.reply-textarea{min-height:60px}
.replies-container{margin-top:.4rem}
.comments-load-more{
  display:flex;margin:1rem auto 0;
}

/* ── Legal / Contact pages ─────────────────────────────────── */
.page-legal{
  max-width:860px;padding-top:2.5rem;padding-bottom:4rem;
}
.legal-hero{
  text-align:center;padding:1.5rem 0 2rem;
}
.legal-hero-icon{
  font-size:2.5rem;color:var(--accent2);margin-bottom:.75rem;display:block;
}
.legal-hero h1{
  font-family:var(--font-display);font-size:2rem;font-weight:800;margin-bottom:.4rem;
}
.legal-hero p{color:var(--text2);font-size:1rem}
.legal-updated{font-size:.82rem;color:var(--text3)!important}

/* TOC */
.legal-toc{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem 1.5rem;margin-bottom:2rem;
}
.legal-toc h2{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:.75rem}
.legal-toc ol{padding-left:1.25rem;display:flex;flex-direction:column;gap:.3rem}
.legal-toc li{font-size:.88rem}
.legal-toc a{color:var(--text2);transition:color var(--transition)}
.legal-toc a:hover{color:var(--accent2)}

/* Body */
.legal-body{display:flex;flex-direction:column;gap:0}
.legal-body h2{
  font-family:var(--font-display);font-size:1.2rem;font-weight:700;
  margin:2rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);
  color:var(--text);
}
.legal-body h3{font-size:1rem;font-weight:700;margin:1.25rem 0 .5rem;color:var(--text)}
.legal-body h4{font-size:.92rem;font-weight:700;margin:1rem 0 .4rem;color:var(--text2)}
.legal-body p{color:var(--text2);font-size:.93rem;line-height:1.8;margin-bottom:.75rem}
.legal-body ul,.legal-body ol{
  color:var(--text2);font-size:.93rem;line-height:1.8;
  padding-left:1.5rem;margin-bottom:.75rem;display:flex;flex-direction:column;gap:.25rem;
}
.legal-body a{color:var(--accent2)}
.legal-body a:hover{color:var(--accent)}
.legal-caps{font-size:.82rem!important;color:var(--text3)!important;line-height:1.7!important}
.legal-contact-box{
  margin-top:2rem;padding:1rem 1.25rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  text-align:center;font-size:.9rem;color:var(--text2);
}

/* Contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.contact-grid{grid-template-columns:1fr}}
.contact-form{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.5rem;margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem;
}
.contact-textarea{min-height:140px;resize:vertical}
.contact-msg-meta{display:flex;justify-content:flex-end;margin-top:.25rem}
.contact-char{font-size:.75rem;color:var(--text3)}
.req{color:var(--danger)}

/* Robot checkbox */
.robot-row{margin:0}
.robot-label{
  display:inline-flex;align-items:center;gap:.75rem;cursor:pointer;
  user-select:none;
}
.robot-label input[type=checkbox]{display:none}
.robot-box{
  width:22px;height:22px;border-radius:5px;
  border:2px solid var(--border);background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);flex-shrink:0;
}
.robot-check-icon{color:#fff;font-size:.7rem;opacity:0;transition:opacity var(--transition)}
.robot-label input:checked ~ .robot-box{background:var(--accent);border-color:var(--accent)}
.robot-label input:checked ~ .robot-box .robot-check-icon{opacity:1}
.robot-text{font-size:.92rem;color:var(--text2)}
.robot-icon{font-size:1.1rem;color:var(--text3);margin-left:.25rem}

.contact-form-footer{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.contact-note{font-size:.78rem;color:var(--text3);display:flex;align-items:center;gap:.4rem}
.contact-note i{color:var(--accent2)}
.contact-submit{min-width:140px;justify-content:center}

/* Success / Error states */
.contact-success{
  display:flex;align-items:flex-start;gap:1rem;
  background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25);
  border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.5rem;
}
.contact-success i{color:var(--success);font-size:1.5rem;flex-shrink:0;margin-top:.1rem}
.contact-success strong{display:block;margin-bottom:.25rem;color:var(--success)}
.contact-success p{color:var(--text2);font-size:.9rem;margin:0}
.contact-errors{
  display:flex;align-items:flex-start;gap:1rem;
  background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);
  border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.25rem;
}
.contact-errors i{color:var(--danger);font-size:1.2rem;flex-shrink:0;margin-top:.1rem}
.contact-errors ul{color:var(--text2);font-size:.88rem;padding-left:1rem;margin:0}

/* Alt contact cards */
.contact-alt{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;
}
.contact-alt-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;text-align:center;
}
.contact-alt-card i{font-size:1.6rem;color:var(--accent2);display:block;margin-bottom:.5rem}
.contact-alt-card h3{font-size:.95rem;font-weight:700;margin-bottom:.3rem}
.contact-alt-card p,.contact-alt-card a{font-size:.88rem;color:var(--text2)}
.contact-alt-card a:hover{color:var(--accent2)}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-mission{
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start;
  margin-bottom:2.5rem;
}
@media(max-width:700px){.about-mission{grid-template-columns:1fr}}
.about-mission-text h2{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:.75rem}
.about-mission-text p{color:var(--text2);font-size:.93rem;line-height:1.8;margin-bottom:.6rem}

.about-stat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:.75rem;flex-shrink:0;min-width:220px;
}
.about-stat{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem .9rem;text-align:center;display:flex;flex-direction:column;gap:.15rem;
}
.about-stat-num{font-size:1.4rem;font-weight:900;color:var(--accent2);line-height:1}
.about-stat-label{font-size:.72rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}

.about-section-title{
  font-family:var(--font-display);font-size:1.25rem;font-weight:800;
  margin:0 0 1.25rem;display:flex;align-items:center;gap:.5rem;
}
.about-section-title::before{
  content:"";display:block;width:4px;height:1.1em;
  background:linear-gradient(to bottom,var(--accent),var(--accent2));border-radius:2px;
}

.about-features{margin-bottom:2.5rem}
.about-feature-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;
}
.about-feature-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem 1.1rem;transition:border-color var(--transition),transform .2s;
}
.about-feature-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.about-feature-card>i{font-size:1.4rem;color:var(--accent2);display:block;margin-bottom:.65rem}
.about-feature-card h3{font-size:.95rem;font-weight:700;margin-bottom:.35rem}
.about-feature-card p{font-size:.85rem;color:var(--text2);line-height:1.65;margin:0}

.about-data{margin-bottom:2.5rem}
.about-data-intro{color:var(--text2);font-size:.93rem;line-height:1.75;margin-bottom:1.25rem}
.about-source-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
@media(max-width:500px){.about-source-grid{grid-template-columns:1fr}}
.about-source-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;display:flex;flex-direction:column;gap:.6rem;
}
.about-source-logo{
  width:42px;height:42px;border-radius:var(--radius-sm);
  background:var(--accent);color:#fff;font-weight:900;font-size:.85rem;
  display:flex;align-items:center;justify-content:center;
}
.about-source-card h3{font-size:.95rem;font-weight:700;margin:0}
.about-source-card p{font-size:.85rem;color:var(--text2);line-height:1.65;margin:0}
.about-source-card a{font-size:.85rem;color:var(--accent2)}
.about-data-note{
  font-size:.82rem;color:var(--text3);
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.65rem 1rem;display:flex;align-items:flex-start;gap:.5rem;
}
.about-data-note i{color:var(--warning);flex-shrink:0;margin-top:.1rem}

.about-cta{
  display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(168,85,247,.08));
  border:1px solid rgba(99,102,241,.25);border-radius:var(--radius);
  padding:1.5rem;margin:2rem 0;
}
.about-cta>i{font-size:1.75rem;color:var(--accent2);flex-shrink:0}
.about-cta>div{flex:1}
.about-cta h3{font-size:1rem;font-weight:700;margin-bottom:.2rem}
.about-cta p{font-size:.88rem;color:var(--text2);margin:0}
.about-cta .btn{flex-shrink:0}

/* ============================================================
   ADVERTISE PAGE
   ============================================================ */
.adv-stats-row{
  display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;
  margin:1.5rem 0 2.5rem;
}
.adv-stat{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.1rem 1.5rem;text-align:center;flex:1;min-width:120px;
}
.adv-stat-num{display:block;font-size:1.7rem;font-weight:900;color:var(--accent2);line-height:1}
.adv-stat-label{display:block;font-size:.72rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}

.adv-section{margin-bottom:2.5rem}
.adv-why-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem;
}
.adv-why-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;transition:border-color var(--transition),transform .2s;
}
.adv-why-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.adv-why-card>i{font-size:1.4rem;color:var(--accent2);display:block;margin-bottom:.6rem}
.adv-why-card h3{font-size:.95rem;font-weight:700;margin-bottom:.35rem}
.adv-why-card p{font-size:.85rem;color:var(--text2);line-height:1.65;margin:0}

.adv-formats{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.adv-format-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;display:flex;flex-direction:column;gap:.6rem;
}
.adv-format-tag{
  display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;background:rgba(99,102,241,.15);color:var(--accent2);
  border-radius:4px;padding:.15rem .55rem;align-self:flex-start;
}
.adv-format-card h3{font-size:.95rem;font-weight:700;margin:0}
.adv-format-card p{font-size:.85rem;color:var(--text2);line-height:1.65;margin:0}
.adv-format-card ul{font-size:.85rem;color:var(--text3);padding-left:1.1rem;margin:0;display:flex;flex-direction:column;gap:.2rem}

.adv-fit-list{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem;
}
.adv-fit-item{
  display:flex;align-items:center;gap:.65rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.65rem .9rem;font-size:.88rem;color:var(--text2);
}
.adv-fit-item i{color:var(--accent);width:1rem;text-align:center;flex-shrink:0}

.adv-note{
  font-size:.8rem;color:var(--text3);text-align:center;
  margin-top:1.5rem;padding:.75rem 1rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
}

/* ============================================================
   API DOCS PAGE
   ============================================================ */
.api-notice{
  display:flex;align-items:flex-start;gap:.85rem;
  background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.25);
  border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:2rem;
  color:var(--text2);font-size:.9rem;
}
.api-notice>i{color:var(--warning);font-size:1.1rem;flex-shrink:0;margin-top:.1rem}

.api-section{margin-bottom:2.5rem}
.api-section>h2{
  font-family:var(--font-display);font-size:1.2rem;font-weight:800;
  margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);
}
.api-section>p{font-size:.9rem;color:var(--text2);line-height:1.7;margin:.5rem 0}

.api-code-block{
  background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:.75rem 1rem;margin:.5rem 0;font-family:monospace;font-size:.88rem;
  color:var(--accent2);overflow-x:auto;
}
.api-json{color:var(--text2)}
.api-json pre{margin:0;white-space:pre;font-size:.82rem;line-height:1.6}

.api-endpoint{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:1.25rem;overflow:hidden;
}
.api-endpoint-header{
  display:flex;align-items:center;gap:.75rem;
  background:var(--bg3);border-bottom:1px solid var(--border);
  padding:.75rem 1rem;flex-wrap:wrap;
}
.api-method{
  font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:.25rem .55rem;border-radius:4px;flex-shrink:0;
}
.api-method.get{background:rgba(34,197,94,.15);color:#22c55e;border:1px solid rgba(34,197,94,.25)}
.api-path{font-family:monospace;font-size:.92rem;color:var(--text);font-weight:700}
.api-desc-short{font-size:.85rem;color:var(--text3);margin-left:auto}
.api-endpoint-body{padding:1rem 1.1rem}
.api-endpoint-body h4{
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);margin:1rem 0 .5rem;
}
.api-endpoint-body h4:first-child{margin-top:0}

.api-params{display:flex;flex-direction:column;gap:0;margin:.25rem 0}
.api-param-row{
  display:grid;grid-template-columns:120px 80px 1fr;gap:.75rem;align-items:start;
  padding:.55rem 0;border-bottom:1px solid var(--border);font-size:.85rem;
}
.api-param-row:last-child{border-bottom:none}
.api-param-row>code{font-family:monospace;color:var(--accent2);background:rgba(99,102,241,.1);padding:.1rem .35rem;border-radius:3px}
.api-param-req{
  font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:#ef4444;background:rgba(239,68,68,.1);padding:.15rem .4rem;border-radius:4px;
  align-self:center;
}
.api-param-opt{
  font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--text3);background:var(--bg3);padding:.15rem .4rem;border-radius:4px;
  align-self:center;
}
.api-param-row>span:last-child{color:var(--text2);line-height:1.6}

.api-limits-table{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);
  margin:.5rem 0;overflow:hidden;
}
.api-limits-row{
  display:grid;grid-template-columns:2fr 1.5fr 1.5fr;
  padding:.7rem 1rem;border-bottom:1px solid var(--border);font-size:.88rem;gap:1rem;
}
.api-limits-row:last-child{border-bottom:none}
.api-limits-header{
  background:var(--bg3);font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--text3);
}

/* ============================================================
   RSS PAGE
   ============================================================ */
.rss-feeds-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1rem;margin:1.5rem 0 2.5rem;
}
.rss-feed-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;display:flex;gap:1rem;align-items:flex-start;
  transition:border-color var(--transition),transform .2s;
}
.rss-feed-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.rss-feed-icon{
  width:42px;height:42px;border-radius:var(--radius-sm);flex-shrink:0;
  background:rgba(242,101,34,.15);color:#f26522;
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;
}
.rss-feed-info{flex:1}
.rss-feed-info h3{font-size:.95rem;font-weight:700;margin-bottom:.3rem}
.rss-feed-info p{font-size:.85rem;color:var(--text2);line-height:1.6;margin-bottom:.65rem}
.rss-feed-url{
  display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;
}
.rss-feed-url code{font-size:.75rem;color:var(--text3);background:var(--bg3);padding:.2rem .5rem;border-radius:4px;word-break:break-all}
.rss-sub-btn{font-size:.78rem!important;padding:.25rem .65rem!important}

.rss-howto{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.5rem;margin-bottom:2rem;
}
.rss-howto h2{font-family:var(--font-display);font-size:1.1rem;font-weight:800;margin-bottom:.5rem}
.rss-howto p{font-size:.9rem;color:var(--text2);margin-bottom:1rem}
.rss-readers-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;
}
.rss-reader{
  display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text2);
  padding:.4rem .6rem;background:var(--bg3);border-radius:var(--radius-sm);
}
.rss-reader i{color:var(--accent2);font-size:.75rem}

/* ============================================================
   COPYRIGHT PAGE
   ============================================================ */
.copyright-contact-box{
  display:flex;align-items:flex-start;gap:1.1rem;
  background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(168,85,247,.06));
  border:1px solid rgba(99,102,241,.25);border-radius:var(--radius);
  padding:1.25rem 1.5rem;margin:1.5rem 0;
}
.copyright-contact-box>i{font-size:1.5rem;color:var(--accent2);flex-shrink:0;margin-top:.15rem}
.copyright-contact-box h3{font-size:1rem;font-weight:700;margin-bottom:.25rem}
.copyright-contact-box p{font-size:.88rem;color:var(--text2);margin:.2rem 0}
.copyright-email{
  display:inline-block;font-size:1rem;font-weight:700;color:var(--accent2);
  margin:.2rem 0;
}
.copyright-alt-note{font-size:.82rem!important;color:var(--text3)!important}

/* ============================================================
   ADVANCED FILTER PANEL
   ============================================================ */

/* Filter button next to layout toggle */
.adv-filter-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.35rem .8rem;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;
  background:var(--bg2);border:1px solid var(--border);color:var(--text2);
  transition:all var(--transition);cursor:pointer;white-space:nowrap;flex-shrink:0;
  position:relative;
}
.adv-filter-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--accent)}
.adv-filter-btn[aria-expanded="true"]{background:var(--accent);color:#fff;border-color:var(--accent)}
.adv-filter-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:16px;height:16px;padding:0 4px;
  background:#ef4444;color:#fff;border-radius:9999px;font-size:.65rem;font-weight:700;
}

/* Overlay */
.adv-filter-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);
  z-index:1100;backdrop-filter:blur(2px);
  transition:opacity .2s;
}
.adv-filter-overlay.open{display:block}

/* Panel */
.adv-filter-panel{
  position:fixed;right:0;top:0;bottom:0;
  width:min(860px, 95vw);
  background:var(--bg2);border-left:1px solid var(--border);
  z-index:1101;overflow-y:auto;
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
}
.adv-filter-panel.open{transform:translateX(0)}

.adv-filter-close{
  position:absolute;top:.75rem;right:.9rem;
  width:32px;height:32px;border-radius:50%;
  background:var(--bg3);border:1px solid var(--border);
  color:var(--text2);font-size:.9rem;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);cursor:pointer;z-index:2;
}
.adv-filter-close:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

.adv-filter-body{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;flex:1;min-height:0;
}
@media(max-width:640px){.adv-filter-body{grid-template-columns:1fr}}

/* Left column */
.adv-filter-left{
  padding:1.5rem 1.25rem 1.5rem 1.5rem;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:1.1rem;
  overflow-y:auto;
}

/* Right column */
.adv-filter-right{
  padding:1.5rem 1.5rem 1.5rem 1.25rem;
  display:flex;flex-direction:column;gap:1.1rem;
  overflow-y:auto;
}
.adv-filter-section-title{
  font-size:1rem;font-weight:800;color:var(--accent2);
  font-family:var(--font-display);padding-bottom:.5rem;
  border-bottom:2px solid var(--accent);
  margin-bottom:.1rem;
}

/* Groups */
.adv-filter-group{display:flex;flex-direction:column;gap:.45rem}
.adv-filter-group-label{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--text3);
}

/* 3-column row */
.adv-filter-row-3{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;
}

/* Chips */
.adv-filter-chips{display:flex;flex-wrap:wrap;gap:.4rem}
.adv-chip{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.3rem .7rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;
  background:var(--bg3);border:1.5px solid var(--border);color:var(--text2);
  transition:all var(--transition);cursor:pointer;
}
.adv-chip:hover{border-color:var(--accent);color:var(--text)}
.adv-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* Actions */
.adv-filter-actions{
  display:flex;gap:.6rem;margin-top:auto;padding-top:.75rem;
  border-top:1px solid var(--border);
}
.adv-filter-clear{background:var(--bg3);border:1px solid var(--border);color:var(--text2)}
.adv-filter-clear:hover{background:#ef4444;border-color:#ef4444;color:#fff}
.adv-filter-reset{background:var(--bg3);border:1px solid var(--accent);color:var(--accent2)}
.adv-filter-reset:hover{background:var(--accent);color:#fff}

/* Episode slider */
.adv-filter-episodes{display:flex;flex-direction:column;gap:.4rem}
.adv-ep-labels{
  display:flex;justify-content:space-between;
  font-size:.8rem;font-weight:700;color:var(--text2);
}
.adv-ep-slider-wrap{position:relative;height:28px;display:flex;align-items:center}
.adv-ep-slider{
  width:100%;-webkit-appearance:none;appearance:none;
  height:4px;border-radius:2px;background:var(--accent);outline:none;
  position:absolute;pointer-events:none;
}
.adv-ep-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:16px;height:16px;border-radius:50%;
  background:var(--accent2);border:2px solid var(--bg2);
  cursor:pointer;pointer-events:all;
}
.adv-ep-slider-max{background:transparent}

/* Platform logo inside chip */
.platform-logo{
  width:16px;height:16px;object-fit:contain;border-radius:3px;flex-shrink:0;
}

/* ── Donghua badges ──────────────────────────────────────── */
.donghua-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(220,38,38,.85);
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  padding: .2rem .45rem;
  border-radius: 4px;
  letter-spacing: .04em;
  z-index: 2;
  backdrop-filter: blur(4px);
  pointer-events: none;
}
.grid-donghua-badge,
.mob-donghua-badge {
  display: inline-flex;
  align-items: center;
  background: rgba(220,38,38,.2);
  color: #f87171;
  font-size: .6rem;
  font-weight: 700;
  padding: .1rem .3rem;
  border-radius: 3px;
  border: 1px solid rgba(220,38,38,.4);
  letter-spacing: .04em;
  flex-shrink: 0;
}
.donghua-card {
  border-color: rgba(220,38,38,.25);
}

/* SEO visually-hidden H1 — readable by Google, invisible to users */
.seo-h1 {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── Episode badge on grid cards ─────────────────────────── */
.grid-ep-badge {
  display: block;
  text-align: center;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .04em;
  padding: 2px 6px;
  margin: 2px 4px 0;
  border-radius: 4px;
  background: rgba(99,102,241,.22);
  color: #a5b4fc;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.grid-ep-badge.ep-final {
  background: rgba(239,68,68,.22);
  color: #fca5a5;
}
.grid-ep-badge.ep-new {
  background: rgba(16,185,129,.22);
  color: #6ee7b7;
  animation: pulse-new 1.8s ease-in-out infinite;
}
@keyframes pulse-new {
  0%,100% { opacity: 1; }
  50%      { opacity: .6; }
}

/* ── Timezone label next to time ─────────────────────────── */
.tz-label {
  font-size: .58rem;
  color: var(--text3, #94a3b8);
  margin-left: 2px;
}

/* ── Native title (JP/CN) under English title on cards ───── */
.grid-native-title {
  display: block;
  font-size: .6rem;
  color: rgba(255,255,255,.55);
  font-style: italic;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mob-native-title {
  font-size: .63rem;
  color: var(--text3, #94a3b8);
  font-style: italic;
  margin-bottom: 2px;
}
.mob-ep-badge {
  font-size: .6rem;
  font-weight: 700;
  color: #6ee7b7;
  background: rgba(16,185,129,.15);
  padding: 1px 5px;
  border-radius: 3px;
}
