/* PIRANOT V9 — Portal Inovador
 * 15+ layouts diferentes, nada repetido
 * Slider + Magazine + Timeline + Overlaps + Bento + Flip + 3D + Expand + Masonry + Pilhas
 */

:root {
    --glass-bg: rgba(255, 255, 255, 0.7);
    --glass-border: rgba(255, 255, 255, 0.3);
    --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.05);
    --glass-blur: blur(12px);
    --pira-blue: #0b3b8f;
    --pira-blue-dark: #072a66;
    --pira-blue-light: #1a5bc4;
    --pira-gold: #ffd200;
    --pira-red: #E60000;
    --dark: #1a1a2e;
    --gray-100: #f7fafc;
    --gray-200: #edf2f7;
    --gray-300: #e2e8f0;
    --gray-500: #718096;
    --gray-700: #2d3748;
    --white: #fff;
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow: 0 4px 6px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 25px rgba(0,0,0,0.15);
    --shadow-xl: 0 25px 50px rgba(0,0,0,0.2);
    --radius: 10px;
    --radius-lg: 16px;
    --radius-xl: 24px;
}

.piranot-v9 { background: var(--gray-100); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; }
.v9-container { max-width: 1280px; margin: 0 auto; padding: 0 20px; }

/* ============================================
   SLIDER HERO
   ============================================ */
.v9-slider { margin: 20px 0 40px; }
.slider-wrapper { position: relative; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-xl); height: 500px; }
.slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.6s ease; z-index: 1; }
.slide.active { opacity: 1; z-index: 2; }
.slide > a { display: block; position: relative; height: 100%; text-decoration: none; color: var(--white); }
.slide-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.05); transition: transform 6s ease; }
.slide.active .slide-bg { transform: scale(1); }
.slide-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(11,59,143,0.8) 70%, var(--pira-blue-dark) 100%); }
.slide-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 50px; }
.slide-cat { display: inline-block; background: var(--pira-gold); color: var(--dark); font-size: 11px; font-weight: 800; text-transform: uppercase; padding: 6px 14px; border-radius: 4px; margin-bottom: 16px; }
.slide-content h2 { font-size: 36px; font-weight: 800; line-height: 1.2; margin: 0 0 12px; text-shadow: 0 2px 20px rgba(0,0,0,0.3); }
.slide-content p { font-size: 16px; opacity: 0.9; margin: 0; max-width: 600px; }

.slider-nav { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 16px; z-index: 10; }
.nav-prev, .nav-next { width: 44px; height: 44px; border-radius: 50%; border: none; background: rgba(255,255,255,0.9); color: var(--pira-blue); font-size: 24px; cursor: pointer; transition: all 0.2s; display: flex; align-items: center; justify-content: center; }
.nav-prev:hover, .nav-next:hover { background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); transform: scale(1.1); }
.nav-dots { display: flex; gap: 8px; }
.dot { width: 12px; height: 12px; border-radius: 50%; background: rgba(255,255,255,0.4); cursor: pointer; transition: all 0.3s; }
.dot.active { background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); transform: scale(1.2); }

/* ============================================
   DESTAQUES RÁPIDOS (Cards Horizontais)
   ============================================ */
.v9-destaques-rapidos { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 48px; }
.card-horizontal { display: flex; flex-direction: column; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; color: var(--dark); box-shadow: var(--shadow-sm); transition: all 0.25s ease; }
.card-horizontal:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.ch-thumb { height: 140px; background-size: cover; background-position: center; }
.ch-content { padding: 16px; }
.ch-cat { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--pira-blue); letter-spacing: 0.5px; }
.ch-content h4 { font-size: 15px; font-weight: 600; line-height: 1.4; margin: 8px 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ch-content time { font-size: 12px; color: var(--gray-500); }

/* ============================================
   SEÇÃO HEADER (reutilizado)
   ============================================ */
.v9-secao { margin-bottom: 56px; }
.secao-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; padding-bottom: 12px; border-bottom: 3px solid var(--pira-blue); }
.secao-header.minimal { border-bottom: 2px solid var(--gray-300); }
.header-titulo { display: flex; align-items: center; gap: 12px; }
.header-icone { font-size: 24px; }
.secao-header h2 { font-size: 22px; font-weight: 800; color: var(--pira-blue); margin: 0; }
.header-sub { font-size: 13px; color: var(--gray-500); margin-left: 8px; }
.header-link { font-size: 13px; font-weight: 600; color: var(--pira-blue); text-decoration: none; }
.header-link:hover { color: var(--pira-blue-light); }

/* ============================================
   MAGAZINE ASIMÉTRICO (Piracicaba)
   ============================================ */
.layout-magazine { display: grid; grid-template-columns: 2fr 1fr; grid-template-rows: repeat(3, 160px); gap: 16px; }
.mag-principal { grid-row: 1 / 4; position: relative; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); }
.mag-principal > a { display: block; position: relative; height: 100%; text-decoration: none; color: var(--white); }
.mag-p-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.4s ease; }
.mag-principal:hover .mag-p-img { transform: scale(1.02); }
.mag-p-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(11,59,143,0.9) 100%); }
.mag-p-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px; }
.mag-badge { display: inline-block; background: var(--pira-gold); color: var(--dark); font-size: 11px; font-weight: 800; padding: 5px 12px; border-radius: 4px; margin-bottom: 10px; }
.mag-p-content h3 { font-size: 26px; font-weight: 700; line-height: 1.2; margin: 0 0 10px; }
.mag-p-content p { font-size: 14px; opacity: 0.9; margin: 0; }
.mag-secundario { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.mag-secundario > a { display: block; position: relative; height: 100%; text-decoration: none; color: var(--white); }
.mag-s-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.3s; }
.mag-secundario:hover .mag-s-img { transform: scale(1.05); }
.mag-secundario h4 { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px; margin: 0; font-size: 15px; font-weight: 600; background: linear-gradient(transparent, rgba(0,0,0,0.7)); }
.mag-lista { display: flex; align-items: center; gap: 12px; padding: 16px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius); text-decoration: none; color: var(--dark); box-shadow: var(--shadow-sm); transition: all 0.2s; }
.mag-lista:hover { transform: translateX(4px); box-shadow: var(--shadow); }
.mag-dot { color: var(--pira-blue); font-size: 8px; }
.mag-titulo { flex: 1; font-size: 14px; font-weight: 500; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mag-hora { font-size: 12px; color: var(--gray-500); }

/* ============================================
   TIMELINE VERTICAL (Região)
   ============================================ */
.layout-timeline { display: flex; flex-direction: column; gap: 0; position: relative; padding-left: 40px; }
.timeline-item { position: relative; padding: 20px 0; }
.timeline-marker { position: absolute; left: -40px; width: 32px; height: 32px; background: var(--pira-blue); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; z-index: 2; }
.timeline-line { position: absolute; left: -24px; top: 0; bottom: 0; width: 2px; background: var(--gray-300); }
.timeline-item:last-child .timeline-line { display: none; }
.timeline-card { background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: all 0.3s; }
.timeline-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.timeline-card > a { display: flex; text-decoration: none; color: var(--dark); }
.timeline-img { width: 180px; height: 120px; background-size: cover; background-position: center; flex-shrink: 0; }
.timeline-content { padding: 20px; display: flex; flex-direction: column; justify-content: center; }
.timeline-content h4 { font-size: 17px; font-weight: 600; line-height: 1.4; margin: 0 0 8px; }
.timeline-content span { font-size: 13px; color: var(--gray-500); }

/* ============================================
   DUAS COLUNAS
   ============================================ */
.v9-duas-colunas { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 56px; }

/* OVERLAPS (Estado) */
.layout-overlaps { position: relative; height: 400px; }
.overlap-card { position: absolute; width: 70%; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); transition: all 0.3s; }
.overlap-card.pos-1 { top: 0; left: 0; z-index: 3; }
.overlap-card.pos-2 { top: 100px; left: 60px; z-index: 2; }
.overlap-card.pos-3 { top: 200px; left: 120px; z-index: 1; }
.overlap-card:hover { z-index: 10; transform: scale(1.02); }
.overlap-img { height: 200px; background-size: cover; background-position: center; }
.overlap-content { padding: 16px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); }
.overlap-content h4 { font-size: 15px; font-weight: 600; margin: 0; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* STACK (Política) */
.layout-stack { display: flex; flex-direction: column; gap: 12px; }
.stack-item { display: flex; align-items: center; gap: 16px; padding: 20px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius); text-decoration: none; color: var(--dark); box-shadow: var(--shadow-sm); border-left: 4px solid var(--pira-blue); transition: all 0.2s; }
.stack-item:hover { transform: translateX(8px); box-shadow: var(--shadow); }
.stack-icon { font-size: 24px; }
.stack-text { flex: 1; font-size: 15px; font-weight: 500; line-height: 1.4; }
.stack-arrow { font-size: 20px; color: var(--pira-blue); opacity: 0; transition: opacity 0.2s; }
.stack-item:hover .stack-arrow { opacity: 1; }

/* ============================================
   BENTO GRID (Economia)
   ============================================ */
.layout-bento { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(2, 200px); gap: 16px; }
.bento-item { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); text-decoration: none; color: var(--white); }
.bento-item:hover { box-shadow: var(--shadow-lg); }
.bento-item.size-1 { grid-column: 1 / 3; grid-row: 1 / 3; }
.bento-item.size-2 { grid-column: 3 / 5; }
.bento-item.size-4 { grid-column: 3 / 4; }
.bento-item.size-5 { grid-column: 4 / 5; }
.bento-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.4s; }
.bento-item:hover .bento-img { transform: scale(1.05); }
.bento-overlay { position: absolute; inset: 0; background: linear-gradient(transparent 40%, rgba(0,0,0,0.8)); }
.bento-item h4 { position: absolute; bottom: 0; left: 0; right: 0; padding: 20px; margin: 0; font-size: 16px; font-weight: 600; line-height: 1.3; }
.bento-item.size-1 h4 { font-size: 22px; }

/* ============================================
   FLIP CARDS (Entretenimento)
   ============================================ */
.layout-flip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; perspective: 1000px; }
.flip-card { height: 280px; }
.flip-inner { position: relative; width: 100%; height: 100%; transition: transform 0.6s; transform-style: preserve-3d; }
.flip-card:hover .flip-inner { transform: rotateY(180deg); }
.flip-front, .flip-back { position: absolute; inset: 0; backface-visibility: hidden; border-radius: var(--radius-lg); overflow: hidden; }
.flip-front { background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); box-shadow: var(--shadow-sm); }
.flip-img { height: 200px; background-size: cover; background-position: center; }
.flip-front h4 { padding: 16px; margin: 0; font-size: 15px; font-weight: 600; }
.flip-back { background: var(--pira-blue); color: var(--white); transform: rotateY(180deg); display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 24px; text-align: center; }
.flip-back p { font-size: 14px; line-height: 1.5; margin: 0 0 20px; }
.flip-btn { display: inline-block; padding: 10px 24px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); color: var(--pira-blue); font-weight: 600; border-radius: var(--radius); text-decoration: none; }

/* ============================================
   CARROSSEL 3D (Esportes)
   ============================================ */
.carrossel-3d-wrapper { perspective: 1200px; padding: 40px 0; }
.carrossel-3d { display: flex; justify-content: center; align-items: center; gap: -50px; transform-style: preserve-3d; }
.c3d-card { width: 280px; height: 350px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); text-decoration: none; color: var(--dark); transition: all 0.5s; position: relative; }
.c3d-card.pos-1 { transform: translateX(0) translateZ(100px); z-index: 5; }
.c3d-card.pos-2 { transform: translateX(-120px) translateZ(-50px) rotateY(15deg); z-index: 4; opacity: 0.9; }
.c3d-card.pos-3 { transform: translateX(120px) translateZ(-50px) rotateY(-15deg); z-index: 4; opacity: 0.9; }
.c3d-card.pos-4 { transform: translateX(-200px) translateZ(-100px) rotateY(25deg); z-index: 3; opacity: 0.7; }
.c3d-card.pos-5 { transform: translateX(200px) translateZ(-100px) rotateY(-25deg); z-index: 3; opacity: 0.7; }
.c3d-card:hover { transform: translateZ(150px) scale(1.05); z-index: 10; opacity: 1; }
.c3d-img { height: 220px; background-size: cover; background-position: center; }
.c3d-card h4 { padding: 16px; margin: 0; font-size: 15px; font-weight: 600; line-height: 1.4; }

/* ============================================
   CARDS EXPANSÍVEIS (Meio Ambiente)
   ============================================ */
.layout-expand { display: flex; gap: 16px; height: 350px; }
.expand-card { flex: 1; position: relative; border-radius: var(--radius-xl); overflow: hidden; cursor: pointer; transition: flex 0.5s ease; }
.expand-card.expanded { flex: 3; }
.expand-card:hover { flex: 2; }
.expand-card.expanded:hover { flex: 3; }
.expand-img { position: absolute; inset: 0; background-size: cover; background-position: center; }
.expand-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px; background: linear-gradient(transparent, rgba(0,0,0,0.8)); color: var(--white); }
.expand-content h4 { font-size: 18px; font-weight: 600; margin: 0 0 12px; }
.expand-link { display: inline-block; padding: 8px 16px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); color: var(--dark); font-size: 13px; font-weight: 600; border-radius: 6px; text-decoration: none; opacity: 0; transform: translateY(10px); transition: all 0.3s; }
.expand-card.expanded .expand-link, .expand-card:hover .expand-link { opacity: 1; transform: translateY(0); }

/* ============================================
   MASONRY COM HOVER ZOOM (Tecnologia)
   ============================================ */
.layout-masonry { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 180px; gap: 16px; }
.masonry-item { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); text-decoration: none; color: var(--white); }
.masonry-item:hover { box-shadow: var(--shadow-lg); }
.masonry-item.tall { grid-row: span 2; }
.masonry-item.wide { grid-column: span 2; }
.masonry-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.5s; }
.masonry-item:hover .masonry-img { transform: scale(1.1); }
.masonry-overlay { position: absolute; inset: 0; background: linear-gradient(transparent 30%, rgba(0,0,0,0.7)); opacity: 0.7; transition: opacity 0.3s; }
.masonry-item:hover .masonry-overlay { opacity: 1; }
.masonry-item h4 { position: absolute; bottom: 0; left: 0; right: 0; padding: 20px; margin: 0; font-size: 15px; font-weight: 600; line-height: 1.4; }

/* ============================================
   GRID NUMÉRICO (Loterias)
   ============================================ */
.layout-loto-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.loto-card { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius-lg); text-decoration: none; box-shadow: var(--shadow-sm); border-top: 4px solid var(--loto-color, var(--pira-blue)); transition: all 0.3s; }
.loto-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.loto-icon { font-size: 40px; margin-bottom: 12px; }
.loto-name { font-size: 14px; font-weight: 600; color: var(--dark); text-align: center; margin-bottom: 8px; }
.loto-more { font-size: 12px; color: var(--pira-blue); font-weight: 600; opacity: 0; transition: opacity 0.2s; }
.loto-card:hover .loto-more { opacity: 1; }

/* ============================================
   PILHAS (Mais Lidas)
   ============================================ */
.layout-pilhas { display: flex; flex-direction: column; gap: 16px; }
.pilha-card { display: flex; align-items: center; gap: 20px; padding: 20px; background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border); border-radius: var(--radius-lg); text-decoration: none; color: var(--dark); box-shadow: var(--shadow-sm); transition: all 0.3s; position: relative; }
.pilha-card:hover { box-shadow: var(--shadow-lg); transform: translateX(10px); }
.pilha-rank { font-size: 48px; font-weight: 800; color: var(--pira-blue); opacity: 0.15; line-height: 1; min-width: 60px; text-align: center; }
.pilha-card.rank-1 .pilha-rank, .pilha-card.rank-2 .pilha-rank, .pilha-card.rank-3 .pilha-rank { opacity: 0.5; color: var(--pira-gold); }
.pilha-img { width: 100px; height: 70px; border-radius: var(--radius); background-size: cover; background-position: center; }
.pilha-content { flex: 1; }
.pilha-content h4 { font-size: 16px; font-weight: 600; line-height: 1.4; margin: 0 0 8px; }
.pilha-views { font-size: 13px; color: var(--gray-500); }

/* ============================================
   RESPONSIVO
   ============================================ */
@media (max-width: 1024px) {
    .slider-wrapper { height: 400px; }
    .slide-content { padding: 30px; }
    .slide-content h2 { font-size: 26px; }
    .v9-destaques-rapidos { grid-template-columns: repeat(2, 1fr); }
    .layout-magazine { grid-template-columns: 1fr; grid-template-rows: auto; }
    .mag-principal { grid-row: auto; min-height: 300px; }
    .layout-timeline { padding-left: 0; }
    .timeline-marker { display: none; }
    .timeline-line { display: none; }
    .timeline-card > a { flex-direction: column; }
    .timeline-img { width: 100%; height: 180px; }
    .v9-duas-colunas { grid-template-columns: 1fr; }
    .layout-overlaps { height: auto; display: flex; flex-direction: column; gap: 16px; }
    .overlap-card { position: relative; width: 100%; }
    .layout-bento { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(4, 180px); }
    .bento-item.size-1 { grid-column: 1 / 3; grid-row: 1 / 3; }
    .layout-flip { grid-template-columns: repeat(2, 1fr); }
    .carrossel-3d { flex-direction: column; gap: 20px; }
    .c3d-card { width: 100%; max-width: 300px; transform: none !important; }
    .layout-expand { flex-direction: column; height: auto; }
    .expand-card { height: 200px; }
    .layout-masonry { grid-template-columns: repeat(2, 1fr); }
    .masonry-item.wide, .masonry-item.tall { grid-column: span 1; grid-row: span 1; }
    .layout-loto-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 640px) {
    .slider-wrapper { height: 350px; }
    .slide-content h2 { font-size: 20px; }
    .v9-destaques-rapidos { grid-template-columns: 1fr; }
    .layout-bento { grid-template-columns: 1fr; }
    .bento-item.size-1 { grid-column: 1; }
    .layout-flip { grid-template-columns: 1fr; }
    .layout-loto-grid { grid-template-columns: repeat(2, 1fr); }
    .pilha-img { display: none; }
}

/* FIX RESPONSIVENESS */
@media (max-width: 768px) {
    .layout-magazine { grid-template-columns: 1fr; grid-template-rows: auto; }
    .mag-principal { grid-row: auto; }
    .v9-duas-colunas { display: flex; flex-direction: column; }
    .layout-bento { grid-template-columns: 1fr; grid-template-rows: auto; }
    .bento-item { grid-column: auto !important; grid-row: auto !important; height: 200px; }
    .layout-flip { grid-template-columns: 1fr; }
    .carrossel-3d { gap: 10px; }
    .c3d-card { transform: none !important; position: static !important; margin: 0 auto; }
}
