/* TrumpNews.Info Archive — dark editorial "wire feed"
   Spectral (headlines) · Outfit (UI) · Fira Code (metadata) */

:root{
  --ink:        #0c0b0e;
  --ink-2:      #131217;
  --surface:    #16151b;
  --surface-2:  #1c1b22;
  --line:       #2a2832;
  --line-soft:  #211f28;
  --text:       #ece7df;
  --text-dim:   #9a958d;
  --text-faint: #6b6760;
  --accent:     #ef4a27;
  --accent-2:   #ff6a3d;
  --accent-dim: rgba(239,74,39,.14);
  --paper:      #e9e3d6;
  --radius:     13px;
  --maxw:       980px;
  --mast-h:     auto;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, #1a1620 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 0%, #19131a 0%, transparent 55%),
    var(--ink);
  color:var(--text);
  font-family:"Outfit", system-ui, sans-serif;
  font-size:16px;
  line-height:1.5;
  min-height:100vh;
  overflow-x:hidden;
}

/* film grain */
.grain{
  position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- masthead ---------- */
.masthead{
  position:sticky; top:0; z-index:20;
  background:linear-gradient(180deg, rgba(12,11,14,.96) 0%, rgba(12,11,14,.88) 100%);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
  box-shadow:0 12px 30px -22px #000;
}
.masthead-inner{
  max-width:var(--maxw); margin:0 auto; padding:16px 22px 12px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:22px; flex-wrap:wrap;
}
.brand{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.wordmark{ display:flex; align-items:baseline; gap:10px; text-decoration:none; line-height:1; }
.wordmark-main{
  font-family:"Outfit",sans-serif; font-weight:700; letter-spacing:-.02em;
  font-size:clamp(22px,4vw,30px); color:var(--text);
}
.wordmark-main .dot{ color:var(--accent); }
.wordmark-tag{
  font-family:"Fira Code",monospace; font-size:11px; font-weight:500;
  letter-spacing:.34em; color:var(--ink); background:var(--accent);
  padding:3px 8px 2px; border-radius:4px; transform:translateY(-2px);
}
.wordmark:hover .wordmark-main{ color:#fff; }
.dateline{
  display:flex; align-items:center; gap:8px;
  font-family:"Fira Code",monospace; font-size:11.5px; color:var(--text-faint);
  letter-spacing:.02em;
}
.pulse{
  width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 0 var(--accent); animation:pulse 2.6s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(239,74,39,.5); }
  70%{ box-shadow:0 0 0 7px rgba(239,74,39,0); }
  100%{ box-shadow:0 0 0 0 rgba(239,74,39,0); }
}

/* controls */
.controls{ display:flex; gap:10px; align-items:center; flex:1 1 340px; max-width:520px; min-width:240px; }
.search-wrap{ position:relative; flex:1 1 auto; }
.search-ico{
  position:absolute; left:13px; top:50%; transform:translateY(-50%);
  width:17px; height:17px; fill:none; stroke:var(--text-faint); stroke-width:2;
  stroke-linecap:round; pointer-events:none;
}
#search{
  width:100%; padding:11px 14px 11px 38px;
  background:var(--surface); border:1px solid var(--line);
  border-radius:10px; color:var(--text); font-family:"Outfit",sans-serif; font-size:14.5px;
  outline:none; transition:border-color .18s, background .18s, box-shadow .18s;
}
#search::placeholder{ color:var(--text-faint); }
#search:focus{ border-color:var(--accent); background:var(--ink-2); box-shadow:0 0 0 3px var(--accent-dim); }

.month-wrap{ position:relative; flex:0 0 auto; }
.cal-ico{
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  width:16px; height:16px; fill:none; stroke:var(--accent-2); stroke-width:1.9;
  stroke-linecap:round; stroke-linejoin:round; pointer-events:none;
}
#month-switch{
  appearance:none; -webkit-appearance:none;
  padding:11px 32px 11px 36px; max-width:210px;
  background:var(--surface); border:1px solid var(--line); border-radius:10px;
  color:var(--text); font-family:"Fira Code",monospace; font-size:13px; font-weight:500;
  letter-spacing:.01em; outline:none; cursor:pointer;
  transition:border-color .18s, box-shadow .18s; text-overflow:ellipsis;
}
#month-switch:focus{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
#month-switch:hover{ border-color:var(--accent); }
#month-switch option{ background:var(--ink-2); color:var(--text); font-weight:400; }
#month-switch optgroup{ background:var(--ink); color:var(--accent-2); font-family:"Fira Code",monospace; }
.chev{
  position:absolute; right:11px; top:50%; transform:translateY(-50%);
  width:15px; height:15px; fill:none; stroke:var(--text-faint); stroke-width:2;
  stroke-linecap:round; pointer-events:none;
}

/* status bar */
.statusbar{
  max-width:var(--maxw); margin:0 auto; padding:0 22px 12px;
  display:flex; align-items:baseline; gap:9px; flex-wrap:wrap;
  font-family:"Fira Code",monospace; font-size:12px; color:var(--text-faint);
}
.month-now{ color:var(--accent-2); font-weight:500; letter-spacing:.02em; }
.month-count{ color:var(--text-dim); }
.stat{ color:var(--text); font-weight:500; }
.stat-label{ color:var(--text-dim); }
.sep{ opacity:.4; }
.updated{ margin-left:auto; color:var(--text-faint); }

/* ---------- feed ---------- */
.feed{
  position:relative; z-index:1;
  max-width:var(--maxw); margin:0 auto; padding:8px 22px 90px;
}

.day-divider{
  position:sticky; top:0; z-index:5;
  display:flex; align-items:center; gap:14px;
  margin:26px 0 4px; padding:9px 0 7px;
  background:linear-gradient(180deg, var(--ink) 55%, transparent);
}
.day-divider span{
  font-family:"Fira Code",monospace; font-size:12px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--accent-2);
  white-space:nowrap;
}
.day-divider::after{
  content:""; flex:1 1 auto; height:1px;
  background:linear-gradient(90deg, var(--line), transparent);
}

.row{ position:relative; }
.row-link{
  display:flex; align-items:baseline; justify-content:space-between; gap:18px;
  padding:13px 16px 13px 18px; text-decoration:none; color:inherit;
  border-radius:10px; border:1px solid transparent;
  position:relative; transition:background .15s ease, border-color .15s ease, transform .12s ease;
}
.row-link::before{
  content:""; position:absolute; left:0; top:14%; bottom:14%; width:2px;
  background:var(--accent); border-radius:2px; transform:scaleY(0);
  transform-origin:center; transition:transform .18s ease;
}
.row-link:hover{
  background:var(--surface); border-color:var(--line-soft);
}
.row-link:hover::before{ transform:scaleY(1); }
.row-link:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }

.row-title{
  font-family:"Spectral", Georgia, serif; font-weight:400;
  font-size:17.5px; line-height:1.32; color:var(--text);
  letter-spacing:.002em; flex:1 1 auto; min-width:0;
  transition:color .15s ease;
}
.row-link:hover .row-title{ color:#fff; }
.row-link:visited .row-title{ color:var(--text-dim); }

.row-meta{ flex:0 0 auto; display:flex; align-items:center; gap:8px; padding-top:3px; }
.row-meta .src{
  font-family:"Fira Code",monospace; font-size:11.5px; color:var(--text-faint);
  letter-spacing:.01em; white-space:nowrap;
}
.row-link:hover .src{ color:var(--accent-2); }

/* sentinel / loader */
#sentinel{ height:1px; }
.loading{
  text-align:center; padding:22px 0; color:var(--text-faint);
  font-family:"Fira Code",monospace; font-size:12px; letter-spacing:.05em;
}
.no-results{
  padding:48px 6px; text-align:center; color:var(--text-dim);
  font-family:"Spectral",serif; font-size:18px; font-style:italic;
}
.empty, .nojs{
  padding:28px 6px; color:var(--text-dim); font-size:15px;
}
.empty code, .nojs code{
  font-family:"Fira Code",monospace; font-size:13px; color:var(--accent-2);
  background:var(--surface); padding:2px 6px; border-radius:5px;
}

/* highlight matched text */
mark{
  background:transparent; color:var(--accent-2); font-weight:600;
  text-shadow:0 0 16px rgba(255,106,61,.35);
}

/* ---------- back to top ---------- */
.totop{
  position:fixed; right:22px; bottom:22px; z-index:30;
  width:46px; height:46px; border-radius:50%;
  background:var(--accent); border:none; cursor:pointer;
  display:grid; place-items:center;
  box-shadow:0 10px 26px -8px rgba(239,74,39,.6);
  opacity:0; transform:translateY(14px) scale(.85); pointer-events:none;
  transition:opacity .25s, transform .25s, background .15s;
}
.totop.show{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.totop:hover{ background:var(--accent-2); }
.totop svg{ width:20px; height:20px; fill:none; stroke:#0c0b0e; stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; }

/* ---------- footer ---------- */
.foot{
  position:relative; z-index:1;
  max-width:var(--maxw); margin:0 auto; padding:26px 22px 40px;
  display:flex; align-items:center; gap:10px;
  font-family:"Fira Code",monospace; font-size:11.5px; color:var(--text-faint);
  letter-spacing:.04em; border-top:1px solid var(--line-soft);
}
.foot-sep{ opacity:.45; }

/* staggered entrance */
.row.reveal{ animation:rise .42s ease both; }
@keyframes rise{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }

/* ---------- mobile ---------- */
@media (max-width:640px){
  body{ font-size:15px; }
  .masthead-inner{ padding:13px 15px 10px; gap:12px; }
  .controls{ flex:1 1 100%; max-width:none; flex-wrap:wrap; }
  .month-wrap{ flex:1 1 100%; }
  #month-switch{ max-width:none; width:100%; }
  .search-wrap{ flex:1 1 100%; }
  .statusbar{ padding:0 15px 11px; }
  .updated{ margin-left:0; width:100%; }
  .feed{ padding:4px 12px 80px; }
  .row-link{
    flex-direction:column; align-items:flex-start; gap:5px;
    padding:12px 12px 12px 15px;
  }
  .row-meta{ padding-top:0; }
  .row-title{ font-size:16.5px; }
  .day-divider{ margin:20px 0 2px; }
  .totop{ right:14px; bottom:14px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
}
