:root{
  --bg: #0e2a45;
  --line: rgba(255,255,255,0.9);
  --lineSoft: rgba(255,255,255,0.25);
  --lineFaint: rgba(255,255,255,0.12);
  --text: rgba(255,255,255,0.92);
  --textSoft: rgba(255,255,255,0.75);
  --textFaint: rgba(255,255,255,0.55);
}

*{ box-sizing: border-box; }

body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: #071a2a;
  color: var(--text);
}

.frame{
  min-height: 100vh;
  display:flex;
  align-items: stretch;
}

.hero{ flex:1; display:flex; }

.blueprint{
  position: relative;
  width:100%;
  min-height:100vh;
  background: var(--bg);
  overflow:hidden;
}

/* faint grid */
.grid{
  position:absolute;
  inset:0;
  background:
    linear-gradient(to right, var(--lineFaint) 1px, transparent 1px),
    linear-gradient(to bottom, var(--lineFaint) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: 0.35;
  pointer-events:none;
}

/* Icons row */
.icons{
  position:absolute;
  left: 6vw;
  right: 6vw;
  bottom: 22vh;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2.2vw;
  align-items: start;
}

.iconlink{
  text-decoration:none;
  color: var(--text);
  display:flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.icon.box{
  width: 110px;
  height: 110px;
  border: 2px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
}

.icon svg{
  width: 70px;
  height: 70px;
  stroke: var(--line);
  stroke-width: 2;
  fill: none;
}

.label{
  letter-spacing: 0.18em;
  font-size: 12px;
  color: var(--textSoft);
  text-transform: uppercase;
}

/* Thought of the day */
.thought{
  position:absolute;
  left: 6vw;
  top: 10vh;
  width: min(560px, 86vw);
  border: 2px solid var(--line);
  padding: 18px 18px 14px;
  background: rgba(0,0,0,0.06);
}

.thought-title{
  letter-spacing: 0.22em;
  font-size: 12px;
  color: var(--textSoft);
  margin-bottom: 10px;
}

.thought-text{
  font-size: 18px;
  line-height: 1.35;
  color: var(--text);
  margin-bottom: 10px;
}

.thought-attrib{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--textFaint);
  margin-bottom: 12px;
}

/* brighten attribution on hover/focus (but it's still always there) */
.thought:hover .thought-attrib,
.thought:focus-within .thought-attrib{
  color: var(--textSoft);
}

.votes{
  display:flex;
  align-items:center;
  gap: 10px;
  margin-bottom: 10px;
}

.voteBtn{
  border: 2px solid var(--line);
  background: transparent;
  color: var(--text);
  padding: 8px 10px;
  font-size: 14px;
  cursor: pointer;
}

.voteBtn:active{ transform: translateY(1px); }

.voteMsg{
  margin-left: 6px;
  color: var(--textSoft);
  font-size: 13px;
}

.utcNote{
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--textFaint);
}

/* Title block bottom right */
.titleblock{
  position:absolute;
  right: 4vw;
  bottom: 5vh;
  display:flex;
  align-items:center;
  gap: 14px;
}

.gCircle{
  width: 70px;
  height: 70px;
  border: 2px solid var(--line);
  border-radius: 50%;
  position: relative;
  display:flex;
  align-items:center;
  justify-content:center;
}

.gBar{
  position:absolute;
  right: 10px;
  top: 50%;
  width: 18px;
  border-top: 2px solid var(--line);
  transform: translateY(-50%);
}

.jm{
  letter-spacing: 0.14em;
  font-weight: 700;
}

.tbName{
  letter-spacing: 0.22em;
  font-size: 12px;
  color: var(--text);
  text-transform: uppercase;
}
.tbLine{
  letter-spacing: 0.12em;
  font-size: 12px;
  color: var(--textSoft);
}

/* Mobile tweaks */
@media (max-width: 820px){
  .icons{
    grid-template-columns: repeat(2, 1fr);
    bottom: 8vh;
  }
  .icon.box{ width: 96px; height: 96px; }
  .icon svg{ width: 62px; height: 62px; }
  .titleblock{ right: 6vw; bottom: 3vh; }
}