/* =========================================================
   π — diário · tema CLARO & MINIMALISTA com acentos punk
   fundo claro · tipografia forte · magenta/preto · imagens inteiras
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Special+Elite&family=Spectral:ital,wght@0,400;0,500;1,400&display=swap');

:root{
  --bg:     #f6f3ec;   /* papel claro */
  --bg2:    #efeae0;
  --card:   #ffffff;
  --ink:    #16151a;
  --muted:  #6f6a60;
  --line:   #e2ddd0;
  --pink:   #ff1f7a;
  --yellow: #ffd400;
  --blue:   #1f6bff;
  --orange: #ff6a1a;
  --lime:   #5fcf2e;
  --mint:   #f1e7c4;   /* beige amarelado pastel (barras de topo) */
  --display:'Anton', Impact, sans-serif;
  --type:   'Special Elite', 'Courier New', monospace;
  --serif:  'Spectral', Georgia, serif;
  --maxw:   1080px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; color:var(--ink); background:var(--bg);
  font-family:var(--serif); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
::selection{ background:var(--pink); color:#fff; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
.deco{ display:none; }   /* sem grafismos de fundo — minimalista */

/* topo */
.topbar{ position:sticky; top:0; z-index:200; background:var(--mint); border-bottom:2px solid var(--pink); }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; height:62px; }
.brand{ display:flex; align-items:baseline; gap:10px; }
.brand .pi{ font-family:var(--display); font-size:26px; color:var(--ink); line-height:1; }
.brand .name{ font-family:var(--type); font-size:11px; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; }
nav.menu{ display:flex; gap:2px; }
nav.menu a{ font-family:var(--type); font-size:13px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); padding:6px 11px; border-bottom:2px solid transparent; }
nav.menu a:hover, nav.menu a.active{ border-bottom-color:var(--pink); color:var(--pink); }
nav.menu .moon{ align-self:center; font-size:16px; line-height:1; margin-left:8px; cursor:default; filter:grayscale(.1); }

/* ticker — discreto */
.ticker{ border-bottom:1px solid var(--line); overflow:hidden; white-space:nowrap; }
.ticker__row{ display:inline-block; padding:8px 0; font-family:var(--type); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); animation:slide 34s linear infinite; }
.ticker__row span{ margin:0 16px; } .ticker__row span::before{ content:"·"; color:var(--pink); margin-right:16px; }
@keyframes slide{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* masthead */
.masthead{ padding:60px 0 26px; }
.masthead .kick{ font-family:var(--type); font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.masthead h1{ font-family:var(--display); font-size:clamp(72px,17vw,190px); line-height:.84; margin:10px 0 0; text-transform:uppercase; color:var(--ink); letter-spacing:.005em; }
.masthead h1 .dot{ color:var(--pink); font-family:Georgia,'Times New Roman',serif; }
.masthead .sub{ font-size:20px; max-width:560px; margin-top:18px; color:var(--ink); }
.masthead .rule{ height:3px; width:80px; background:var(--pink); margin-top:24px; }

/* barra de topo única (menta pastel) — sem variação por aba */

/* animação dos dígitos de π (ASCII) */
.pi-stream{ font-family:var(--type); font-size:clamp(14px,2.2vw,20px); line-height:1.5; height:3em; overflow:hidden;
  letter-spacing:.1em; color:var(--ink); margin-top:18px; max-width:none; word-break:break-all; }
.pi-stream::after{ content:"▌"; color:var(--pink); animation:blink 1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

/* barra de anos */
.years{ display:flex; flex-wrap:wrap; gap:6px; padding:14px 0 4px; }
.years a{ font-family:var(--type); font-size:13px; padding:4px 11px; border:1px solid var(--line); cursor:pointer; color:var(--muted); background:var(--card); }
.years a:hover{ border-color:var(--ink); color:var(--ink); }
.years a.active{ background:var(--ink); color:var(--bg); border-color:var(--ink); }

/* barra de meses */
.months{ display:none; flex-wrap:wrap; gap:5px; padding:6px 0 10px; }
.months button{ font-family:var(--type); font-size:11px; padding:3px 9px; border:1px solid var(--line); cursor:pointer; color:var(--muted); background:var(--card); letter-spacing:.04em; }
.months button:hover{ border-color:var(--pink); color:var(--pink); }
.months button.active{ background:var(--pink); color:#fff; border-color:var(--pink); }

/* FEED em mosaico (masonry) — imagens inteiras */
.feed{ padding:22px 0 26px; column-count:2; column-gap:24px; }
.feed.single{ column-count:1; max-width:620px; margin:0 auto; }
@media(max-width:760px){ .feed{ column-count:1; } }

.card{ break-inside:avoid; display:inline-block; width:100%; margin:0 0 24px; vertical-align:top;
  background:var(--card); border:1px solid var(--line); padding:14px; }
.stamp{ display:inline-block; font-family:var(--type); font-size:12px; letter-spacing:.08em; color:var(--ink);
  border-bottom:2px solid var(--pink); padding-bottom:2px; }
/* (carimbos e títulos uniformes — a cor varia só nas barras de topo) */

/* muitas fotos no mesmo dia -> colunas (não uma fila única) */
.shot-grid{ margin:14px 0 4px; column-gap:8px; }
.shot-grid.cols-2{ column-count:2; }
.shot-grid.cols-3{ column-count:3; }
.shot-grid .shot{ margin:0 0 8px; position:relative; cursor:zoom-in; transition:transform .22s ease, box-shadow .22s ease; }
.shot-grid.cols-2 .shot:hover{ transform:scale(1.9); z-index:20; box-shadow:0 12px 34px rgba(0,0,0,.4); }
.shot-grid.cols-3 .shot:hover{ transform:scale(2.7); z-index:20; box-shadow:0 12px 34px rgba(0,0,0,.4); }
.shot img{ cursor:zoom-in; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:1500; display:none; place-items:center; padding:18px; background:rgba(12,11,14,.93); cursor:zoom-out; }
.lightbox.open{ display:grid; }
.lightbox img{ max-width:94vw; max-height:92vh; width:auto; height:auto; box-shadow:0 20px 60px rgba(0,0,0,.6); }

/* imagens inteiras, sem corte */
.shot{ margin:14px 0 4px; }
.shot img{ width:100%; height:auto; display:block; }
.shot.broken{ display:none; }
.shot figcaption{ font-family:var(--type); font-size:13px; color:var(--muted); padding:8px 0 2px; }

/* texto junto das imagens */
.say{ margin:12px 0 4px; }
.say .say-ttl{ font-family:var(--display); font-size:24px; text-transform:uppercase; display:block; margin-bottom:6px; }
.say p{ font-size:18px; line-height:1.6; margin:0; }
.say .more{ display:inline-block; margin-top:10px; font-family:var(--type); font-size:13px; text-transform:uppercase; letter-spacing:.06em; border-bottom:2px solid var(--pink); }
.say .more:hover{ color:var(--pink); }

.vid{ width:100%; margin:14px 0 4px; border:1px solid var(--line); background:#000; display:block; }

/* tags */
.tags{ margin-top:12px; display:flex; flex-wrap:wrap; gap:6px; }
.chip{ font-family:var(--type); font-size:11px; letter-spacing:.04em; text-transform:lowercase; padding:2px 8px; border:1px solid var(--line); color:var(--muted); }
.chip:hover{ border-color:var(--pink); color:var(--pink); }

/* ver mais */
.more-btn{ display:block; margin:6px auto 60px; cursor:pointer; font-family:var(--type); font-size:14px; letter-spacing:.1em; text-transform:uppercase; padding:12px 30px; background:var(--ink); color:var(--bg); border:1px solid var(--ink); }
.more-btn:hover{ background:var(--pink); border-color:var(--pink); }

/* destaque aleatório — imagem inteira */
.random{ display:flex; justify-content:center; padding:6px 0 14px; }
.feature{ width:100%; max-width:440px; background:var(--card); border:1px solid var(--line); padding:13px; cursor:pointer; position:relative; }
.feature .label{ font-family:var(--type); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--pink); }
.feature .sq{ margin-top:8px; }
.feature .sq img{ width:100%; height:auto; display:block; }
.feature .meta{ display:flex; justify-content:space-between; align-items:center; margin-top:10px; font-family:var(--type); font-size:13px; color:var(--muted); }
.feature .meta .roll{ border-bottom:2px solid var(--pink); text-transform:uppercase; font-size:11px; color:var(--ink); }

/* projetos / séries */
.project{ padding:14px 0 30px; border-top:1px solid var(--line); }
.project:first-child{ border-top:none; }
.proj-ttl{ font-family:var(--display); font-size:clamp(28px,5vw,52px); text-transform:uppercase; margin:18px 0 14px; }
.proj-ttl span{ font-family:var(--type); font-size:14px; color:var(--pink); vertical-align:super; margin-left:6px; }
.proj-grid{ column-count:3; column-gap:10px; }
@media(max-width:760px){ .proj-grid{ column-count:2; } }
.proj-grid .shot{ margin:0 0 10px; }
.proj-more{ font-family:var(--type); font-size:13px; color:var(--muted); margin:8px 0 0; }

/* artigo (ensaio) */
.article{ padding:48px 0 72px; }
.article .lead{ font-family:var(--type); font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.article h1{ font-family:var(--display); font-size:clamp(40px,9vw,90px); text-transform:uppercase; line-height:.86; margin:10px 0 26px; }
.article h1 .dot{ color:var(--pink); }
.article .body{ max-width:68ch; font-size:20px; line-height:1.78; }
.article .body p{ margin:0 0 24px; }
.article .body p:first-of-type::first-letter{ font-family:var(--display); float:left; font-size:74px; line-height:.72; padding:8px 12px 2px 0; color:var(--pink); }
.signature{ font-family:var(--display); font-size:30px; color:var(--pink); margin-top:30px; display:inline-block; }
.lyric{ border-left:3px solid var(--pink); padding-left:18px; font-style:italic; margin:24px 0; }

/* sobre */
.about{ display:grid; grid-template-columns:1.4fr 1fr; gap:40px; padding:48px 0 72px; }
.about .body{ font-size:19px; line-height:1.75; }
.factbox{ border:1px solid var(--ink); padding:22px; height:fit-content; }
.factbox h4{ font-family:var(--type); font-size:11px; letter-spacing:.16em; color:var(--pink); margin:0 0 14px; text-transform:uppercase; }
.factbox dl{ margin:0; font-family:var(--type); font-size:14px; }
.factbox dt{ color:var(--muted); margin-top:12px; } .factbox dd{ margin:2px 0 0; }
.factbox a{ border-bottom:1px solid var(--pink); }

/* botão */
.btn{ display:inline-block; font-family:var(--type); font-size:14px; letter-spacing:.08em; text-transform:uppercase; padding:11px 20px; background:var(--ink); color:var(--bg); }
.btn:hover{ background:var(--pink); }

/* rodapé */
footer{ border-top:1px solid var(--ink); margin-top:30px; padding:44px 0 56px; }
footer .wrap{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:28px; align-items:flex-end; }
footer .big{ font-family:var(--display); font-size:clamp(46px,11vw,120px); line-height:.82; text-transform:uppercase; color:var(--ink); }
footer .big .dot{ color:var(--pink); font-family:Georgia,'Times New Roman',serif; }
footer .links{ display:flex; flex-direction:column; gap:6px; font-family:var(--type); font-size:14px; text-transform:uppercase; }
footer .links a:hover{ color:var(--pink); }
footer .daily{ font-family:var(--type); font-size:12px; color:var(--muted); width:100%; padding-top:22px; border-top:1px solid var(--line); }
footer .daily b{ color:var(--ink); }

/* TAROT */
.tarot-trigger{ position:fixed; right:18px; bottom:18px; z-index:500; width:54px; height:54px; border-radius:50%; cursor:pointer; background:var(--ink); color:var(--bg); border:none; display:grid; place-items:center; font-size:24px; box-shadow:0 4px 14px rgba(0,0,0,.25); transition:transform .2s; }
.tarot-trigger:hover{ transform:rotate(12deg) scale(1.06); background:var(--pink); }
.tarot-trigger small{ position:absolute; bottom:-20px; right:0; font-family:var(--type); font-size:9px; color:var(--muted); white-space:nowrap; opacity:0; transition:opacity .2s; }
.tarot-trigger:hover small{ opacity:1; }
.tarot-overlay{ position:fixed; inset:0; z-index:1000; display:none; place-items:center; background:rgba(20,19,24,.7); backdrop-filter:blur(4px); }
.tarot-overlay.open{ display:grid; }
.tcard{ width:280px; perspective:1200px; cursor:pointer; }
.tcard__inner{ position:relative; width:100%; aspect-ratio:3/5; animation:dealflip .8s cubic-bezier(.2,.8,.2,1) both; }
@keyframes dealflip{ from{ transform:rotateY(180deg) rotate(-8deg) scale(.7); opacity:0;} to{ transform:none; opacity:1;} }
.tcard__face{ position:absolute; inset:0; background:var(--card); color:var(--ink); border:1px solid var(--ink); box-shadow:0 14px 40px rgba(0,0,0,.4); display:flex; flex-direction:column; padding:14px; }
.tcard__num{ font-family:var(--type); font-size:14px; color:var(--pink); }
.tcard__art{ flex:1; position:relative; overflow:hidden; display:grid; place-items:center; margin:8px 0; border:1px solid var(--line); background:#fff; }
.tcard__art img{ width:100%; height:100%; object-fit:cover; display:block; }
.tcard__art.cyber img{ filter:contrast(1.08) saturate(1.15); }
.tcard__art.cyber::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.07) 0 1px, transparent 1px 3px); }
.tcard__name{ font-family:var(--display); font-size:22px; text-transform:uppercase; line-height:1; }
.tcard__key{ font-family:var(--type); font-size:13px; margin-top:6px; color:var(--muted); }
.tcard__hint{ font-family:var(--type); font-size:11px; color:#fff; text-align:center; margin-top:16px; letter-spacing:.1em; text-transform:uppercase; }
.void{ position:fixed; inset:0; z-index:1200; display:none; place-items:center; background:var(--ink); color:var(--bg); text-align:center; }
.void.open{ display:grid; animation:fadein .4s ease; }
@keyframes fadein{ from{opacity:0} to{opacity:1} }
.void h2{ font-family:var(--display); font-size:clamp(40px,10vw,110px); text-transform:uppercase; margin:0; }
.void h2 .r{ color:var(--pink); }
.void p{ font-family:var(--type); letter-spacing:.14em; text-transform:uppercase; }
.void small{ font-family:var(--type); font-size:11px; opacity:.6; position:absolute; bottom:30px; left:0; right:0; }

@media(max-width:760px){
  body{ font-size:17px; }
  .about{ grid-template-columns:1fr; }
  .brand .name{ display:none; }
  nav.menu a{ padding:6px 8px; font-size:12px; }
}
@media(prefers-reduced-motion:reduce){ .ticker__row,.tcard__inner{ animation:none; } }
