/*
Theme Name: Zona de Investigação
Theme URI: https://zonadeinvestigacao.example
Author: OpenAI
Description: Tema WordPress para catálogo e venda de casos investigativos digitais.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: zi-theme
*/

:root{
  --zi-bg:#07111a;
  --zi-bg-soft:#0c1824;
  --zi-panel:#101c28;
  --zi-panel-2:#132332;
  --zi-border:rgba(255,255,255,.08);
  --zi-text:#f4f6f8;
  --zi-muted:#b9c3cc;
  --zi-accent:#f2a93b;
  --zi-accent-2:#ffbe5a;
  --zi-shadow:0 18px 48px rgba(0,0,0,.32);
  --zi-shadow-soft:0 10px 28px rgba(0,0,0,.22);
  --zi-radius:18px;
  --zi-radius-sm:14px;
  --zi-container:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:15px;
  line-height:1.6;
  background:linear-gradient(180deg,#061019 0%,#0b1621 100%);
  color:var(--zi-text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

p,li,span,label,input,textarea,select,button{
  font-size:15px;
  line-height:1.55;
}

h1{
  font-size:clamp(36px,4.2vw,56px);
  line-height:1.02;
  margin:0 0 16px;
  font-weight:900;
  letter-spacing:-.03em;
}

h2{
  font-size:clamp(24px,2.5vw,36px);
  line-height:1.08;
  margin:0 0 16px;
  font-weight:900;
  letter-spacing:-.02em;
}

h3{
  font-size:clamp(18px,1.5vw,24px);
  line-height:1.2;
  margin:0 0 8px;
  font-weight:800;
}

h4{
  font-size:16px;
  line-height:1.25;
  margin:0 0 6px;
  font-weight:700;
}

.zi-container{
  width:min(var(--zi-container),calc(100% - 48px));
  margin:0 auto;
}

.site-main{min-height:40vh}
.screen-reader-text{position:absolute;left:-9999px}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(5,12,19,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.site-header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  min-height:76px;
}

.site-branding{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
}

.site-branding__mark{
  width:42px;
  height:42px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--zi-accent-2),var(--zi-accent));
  color:#111;
  display:grid;
  place-items:center;
  font-weight:900;
  font-size:16px;
}

.site-branding__text{
  line-height:1.02;
  font-size:14px;
}

.site-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:26px;
  align-items:center;
}

.site-nav a{
  color:#edf0f3;
  font-size:15px;
  font-weight:700;
  opacity:.92;
}

.site-nav .current-menu-item>a,
.site-nav a:hover{
  color:var(--zi-accent);
}

.site-header__cta{
  padding:12px 20px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:14px;
  font-size:15px;
  font-weight:700;
}

.site-header__cta:hover{
  border-color:rgba(255,255,255,.32);
}

.menu-toggle{display:none}

/* Buttons */
.zi-button,
.button,
.wp-block-button__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  padding:0 20px;
  border:0;
  border-radius:12px;
  background:linear-gradient(180deg,var(--zi-accent-2),var(--zi-accent));
  color:#111;
  font-size:14px;
  font-weight:800;
  box-shadow:0 10px 24px rgba(242,169,59,.22);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.zi-button:hover,
.button:hover,
.wp-block-button__link:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(242,169,59,.28);
}

.zi-button--hero{
  min-width:200px;
  min-height:44px;
  font-size:14px;
}

.zi-button--ghost{
  background:transparent;
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:none;
}

/* Hero */
.zi-hero{
  position:relative;
  min-height:540px;
  overflow:hidden;
  display:flex;
  align-items:center;
  isolation:isolate;
}

.zi-hero__bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center 38%;
  z-index:0;
}

.zi-hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(
    90deg,
    rgba(6,16,25,.86) 0%,
    rgba(6,16,25,.64) 24%,
    rgba(6,16,25,.30) 48%,
    rgba(6,16,25,.10) 68%,
    rgba(6,16,25,0) 100%
  );
  z-index:1;
  pointer-events:none;
}

.zi-hero__inner{
  position:relative;
  z-index:2;
  min-height:540px;
  display:flex;
  align-items:center;
}

.zi-hero__content{
  max-width:420px;
  padding:60px 0;
}

.zi-hero__content h1{
  font-size:clamp(32px,4vw,50px);
  line-height:1.02;
  margin:0 0 14px;
  color:#f3f5f7;
}

.zi-lead,
.zi-hero__lead{
  font-size:15px;
  line-height:1.5;
  margin:0 0 20px;
  color:#eef2f6;
  max-width:380px;
}

/* Layout */
.zi-section{padding:28px 0}
.zi-main-panels{padding:24px 0 34px}

.zi-main-panels__grid{
  display:grid;
  grid-template-columns:minmax(0,1.06fr) minmax(0,.94fr);
  gap:24px;
  align-items:start;
}

.zi-panel{
  display:flex;
  flex-direction:column;
  gap:22px;
  min-width:0;
}

.zi-panel--left,
.zi-panel--right{
  min-width:0;
}

.zi-panel h2,
.zi-section-title,
.zi-catalog-home h2{
  font-size:clamp(22px,2.2vw,34px);
  margin:0 0 14px;
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.02em;
}

.centered{text-align:center}

/* About */
.zi-about-list{
  display:grid;
  gap:16px;
  margin-bottom:18px;
}

.zi-about-item{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:12px;
  align-items:start;
}

.zi-about-item__icon{
  width:46px;
  height:46px;
  border-radius:12px;
  background:rgba(242,169,59,.08);
  display:grid;
  place-items:center;
  font-size:20px;
}

.zi-about-item h3{
  margin:0 0 4px;
  font-size:16px;
}

.zi-about-item p{
  margin:0;
  color:var(--zi-muted);
  line-height:1.6;
  font-size:14px;
}

/* Idea cards */
.zi-idea-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.zi-mini-card{
  min-height:90px;
  border:1px solid var(--zi-border);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),#0d1823;
  box-shadow:var(--zi-shadow-soft);
  padding:14px;
  font-size:clamp(15px,1.3vw,20px);
  font-weight:800;
  line-height:1.12;
  display:flex;
  align-items:flex-end;
}

.zi-mini-card--highlight{
  font-size:clamp(17px,1.5vw,23px);
}

/* Slogans */
.zi-slogans{
  padding-top:4px;
}

.zi-slogans .zi-section-title,
.zi-slogans h2{
  margin-bottom:12px;
}

.zi-slogans__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px 20px;
  text-align:center;
}

.zi-slogans__grid p{
  margin:0;
  font-size:14px;
  line-height:1.28;
  font-weight:700;
}

/* Generic card */
.zi-case-card{
  background:linear-gradient(180deg,#13202d 0%,#101a25 100%);
  border:1px solid var(--zi-border);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--zi-shadow-soft);
  display:flex;
  flex-direction:column;
  height:100%;
  min-width:0;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.zi-case-card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 36px rgba(0,0,0,.3);
  border-color:rgba(255,255,255,.12);
}

.zi-case-card__thumb{
  aspect-ratio:10/12;
  overflow:hidden;
  background:#0a141d;
}

.zi-case-card__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .35s ease;
}

.zi-case-card:hover .zi-case-card__thumb img{
  transform:scale(1.03);
}

.zi-case-card__content{
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1;
  min-width:0;
}

.zi-case-card h3{
  font-size:15px;
  line-height:1.2;
  margin:0;
  word-break:break-word;
}

.zi-case-card__badge{
  display:inline-flex;
  align-self:flex-start;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(242,169,59,.12);
  color:var(--zi-accent);
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.zi-case-summary{
  font-size:12px;
  line-height:1.45;
  color:var(--zi-muted);
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.zi-case-card__meta{
  font-size:12px;
  line-height:1.45;
  color:var(--zi-muted);
}

.zi-case-card__actions{
  padding:10px 12px 12px;
  margin-top:auto;
}

.zi-case-card__actions .zi-button{
  width:100%;
  min-height:38px;
  font-size:13px;
}

/* HOME catalog - isolated */
.zi-catalog-home{
  min-width:0;
}

.zi-catalog-home .zi-catalog-grid,
.zi-catalog-home .zi-cases-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  align-items:start;
}

.zi-catalog-home .zi-case-card{
  min-width:0;
}

.zi-catalog-home .zi-case-card__thumb{
  aspect-ratio:10/12;
}

.zi-catalog-home .zi-case-card__content{
  padding:12px;
  gap:6px;
}

.zi-catalog-home .zi-case-card h3{
  font-size:15px;
  line-height:1.2;
}

.zi-catalog-home .zi-case-summary{
  font-size:12px;
  line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.zi-catalog-home .zi-case-card__meta{
  font-size:11px;
  line-height:1.45;
}

.zi-catalog-home .zi-case-card__actions{
  padding:10px 12px 12px;
}

.zi-catalog-home .zi-button{
  font-size:12px;
  min-height:34px;
}

/* Archive / catalog page */
.zi-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}

.zi-archive-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:20px;
  margin-bottom:20px;
}

.zi-archive-description{
  color:var(--zi-muted);
  max-width:720px;
  font-size:15px;
}

.zi-filters{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr auto;
  gap:12px;
  margin-bottom:22px;
}

.zi-field,
.zi-select{
  width:100%;
  min-height:44px;
  border-radius:12px;
  background:#101a25;
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  padding:0 14px;
  font-size:14px;
}

/* Single */
.zi-single{
  padding:38px 0 56px;
}

.zi-single__grid{
  display:grid;
  grid-template-columns:minmax(300px,390px) 1fr;
  gap:30px;
  align-items:start;
}

.zi-single__cover{
  background:linear-gradient(180deg,#13202d,#101a25);
  border:1px solid var(--zi-border);
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--zi-shadow);
}

.zi-single__panel{
  background:linear-gradient(180deg,#11202d,#0e1823);
  border:1px solid var(--zi-border);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--zi-shadow);
}

.zi-single__panel h1{
  font-size:clamp(28px,3vw,42px);
  line-height:1.05;
  margin:0 0 10px;
  letter-spacing:-.03em;
}

.zi-single__subtitle{
  font-size:16px;
  color:var(--zi-accent);
  font-weight:700;
  margin:0 0 14px;
}

.zi-pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:14px 0 18px;
}

.zi-pill{
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  font-size:13px;
  color:#fff;
}

.zi-single__summary{
  font-size:15px;
  line-height:1.72;
  color:var(--zi-muted);
  margin-bottom:18px;
}

.zi-single__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:16px;
}

.zi-case-stats{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  padding-top:6px;
  color:var(--zi-muted);
  font-size:14px;
}

.zi-related{padding-top:18px}

/* How it works */
.zi-how-it-works{
  padding-top:0;
}

.zi-how-it-works h2{
  margin-bottom:12px;
}

.zi-steps{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  text-align:center;
}

.zi-step{
  position:relative;
  padding:6px 4px;
}

.zi-step__icon{
  display:block;
  font-size:28px;
  margin-bottom:6px;
}

.zi-step strong{
  display:block;
  font-size:15px;
  margin-bottom:4px;
}

.zi-step p{
  margin:0;
  color:#fff;
  font-size:13px;
}

.zi-step:not(:last-child)::after{
  content:"→";
  position:absolute;
  right:-6px;
  top:10px;
  font-size:18px;
  color:rgba(255,255,255,.62);
}

/* Pitch */
.zi-pitch{
  padding-top:0;
}

.zi-pitch-card{
  border:2px solid rgba(242,169,59,.5);
  border-radius:16px;
  padding:20px 22px;
  text-align:center;
  background:rgba(255,255,255,.015);
}

.zi-pitch-card h2{
  font-size:clamp(20px,1.8vw,28px);
  margin-bottom:10px;
}

.zi-pitch-card p{
  font-size:14px;
  line-height:1.65;
  color:var(--zi-muted);
  max-width:620px;
  margin:0 auto 10px;
}

.zi-pitch-card p:last-child{
  margin-bottom:0;
}

/* Footer */
.site-footer{
  margin-top:8px;
  border-top:1px solid rgba(255,255,255,.06);
  padding:20px 0 28px;
  text-align:center;
  font-size:13px;
  color:var(--zi-muted);
}

.site-footer__nav{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  justify-content:center;
  margin-bottom:12px;
}

.site-footer__copy{
  text-align:center;
  font-size:13px;
}

/* Utilities */
.zi-muted{color:var(--zi-muted)}
.zi-empty{
  padding:24px;
  border:1px dashed rgba(255,255,255,.16);
  border-radius:16px;
  background:rgba(255,255,255,.02);
}

/* Responsive */
@media (max-width:1200px){
  .zi-container{
    width:min(var(--zi-container),calc(100% - 36px));
  }

  .zi-main-panels__grid{
    grid-template-columns:1fr;
  }

  .zi-catalog-home .zi-catalog-grid,
  .zi-catalog-home .zi-cases-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }

  .zi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:1100px){
  .zi-single__grid{
    grid-template-columns:1fr;
  }

  .zi-steps{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .zi-step:not(:last-child)::after{
    display:none;
  }

  .zi-filters{
    grid-template-columns:1fr 1fr;
  }
}

/* =================================
LOGIN DETETIVE
================================= */

.login-detective {
    max-width: 420px;
    margin: 80px auto;
    padding: 40px;
    background: #111;
    border-radius: 10px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
    color: #fff;
}

.login-detective h1{
    text-align:center;
    margin-bottom:25px;
}

.login-detective input{
    width:100%;
    padding:12px;
    margin-bottom:15px;
    border-radius:6px;
    border:none;
}

.login-detective input[type=submit]{
    background:#d4af37;
    color:#000;
    font-weight:bold;
    cursor:pointer;
}

@media (max-width:768px){
  body,
  p,
  li,
  span,
  label,
  input,
  textarea,
  select,
  button{
    font-size:14px;
  }

  h1{font-size:32px}
  h2{font-size:24px}
  h3{font-size:17px}

  .site-header__inner{
    min-height:68px;
    flex-wrap:wrap;
    padding:10px 0;
  }

  .site-nav{
    width:100%;
    overflow:auto;
  }

  .site-nav ul{
    gap:18px;
    padding-bottom:6px;
  }

  .site-header__cta{
    display:none;
  }

  .zi-hero,
  .zi-hero__inner{
    min-height:460px;
  }

  .zi-hero__content{
    padding:44px 0;
    max-width:100%;
  }

  .zi-hero__content h1{
    font-size:30px;
  }

  .zi-hero__lead{
    font-size:14px;
  }

  .zi-hero__bg{
    background-position:62% center;
  }

  .zi-grid,
  .zi-idea-grid,
  .zi-slogans__grid,
  .zi-steps,
  .zi-filters,
  .zi-catalog-home .zi-catalog-grid,
  .zi-catalog-home .zi-cases-grid{
    grid-template-columns:1fr;
  }

  .zi-mini-card,
  .zi-mini-card--highlight{
    font-size:18px;
    min-height:96px;
  }

  .zi-slogans__grid p{
    font-size:15px;
  }

  .zi-single__actions .zi-button,
  .zi-button,
  .button{
    width:100%;
  }
}