:root {
    --grad-a:#1aa0ff; --grad-b:#0c73f6; --white:#fff; --dim:#e7f0ffcc;
  }
  
  /* Evita barra de rolagem horizontal */
  html,body{width:100%;max-width:100%;overflow-x:hidden;}
  body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}
  
  /* ====== MOBILE INTRO ====== */
  .mobile-intro{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--grad-a),var(--grad-b));padding:16px 16px 46px;}
  .phone{width:100%;max-width:640px;color:#fff;border-radius:0;box-shadow:none;}
  .brand{display:block;gap:14px;margin-bottom:14px;text-align:center;}
  .brand h1{margin:0;font-weight:800;font-size:1.6rem}
  .brand h1 span{font-weight:600;opacity:.9}
  
  .grid-mobile{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 10px;margin-top:8px;padding-left: 20px !important;padding-right: 20px !important;}
  .tile{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px !important;text-align:center;color:#fff;text-decoration:none;background:linear-gradient(180deg,#ffffff1c,#ffffff10);border:1px solid #ffffff2b;border-radius:16px;aspect-ratio:1/1;min-height:60px;padding:1px !important;transition:transform .12s ease,background .2s,border-color .2s;min-width:0;}
  .tile:hover{transform:translateY(-2px);background:linear-gradient(180deg,#ffffff26,#ffffff12);border-color:#ffffff66}
  .tile i{font-size:28px;filter:drop-shadow(0 1px 4px #072a7d55)}
  .tile span{font-size:.78rem;color:var(--dim);line-height:1.15;white-space:normal;overflow-wrap:anywhere;word-break:break-word;}

  
  
  .scroll-hint{display:flex;justify-content:center;margin-top:14px;opacity:.9}
  .scroll-hint a{color:#fff;text-decoration:none;display:flex;align-items:center;gap:6px}
  .scroll-hint i{font-size:22px}
  
  /* ====== HEADER / SITE NORMAL ====== */
  .hero{background:linear-gradient(100deg,var(--grad-a),var(--grad-b));color:#fff}
  .logo-min{width:48px;height:48px;border:2px solid #fff;border-radius:12px;display:grid;place-items:center;font-weight:800}
  .sec-title{font-weight:800;margin-bottom:18px}
  .icon-card{height:100%;border:1px solid #00000012;border-radius:16px;padding:18px;background:#fff;transition:.15s}
  .icon-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0f3e8a14}
  .icon-card i{font-size:28px;color:#0c73f6}
  
  /* Secretaria */
  .card-secretaria{border-radius:16px;border:1px solid #00000012;background:#fff}
  
  /* Eventos fixos */
  .event-fixed{border:1px solid #00000012;border-radius:16px;background:#fff;overflow:hidden;height:100%}
  .event-fixed .thumb{width:80px;height:80px;object-fit:cover;border-radius:12px}
  .event-fixed .icon-round{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:#eef4ff;color:#0c73f6}
  
  /* Thumbs figurativos */
  .event-fixed .thumb-fig{width:80px;height:80px;border-radius:12px;display:grid;place-items:center;flex:0 0 80px;color:#0c73f6;border:1px solid #e1e9ff;background:linear-gradient(135deg,#eef4ff,#d7e6ff);}
  .event-fixed .thumb-fig i{font-size:34px;line-height:1;}
  .thumb-fig.g1{background:linear-gradient(135deg,#e9f2ff,#dbe9ff);}
  .thumb-fig.g2{background:linear-gradient(135deg,#eaf7ff,#d8efff);}
  .thumb-fig.g3{background:linear-gradient(135deg,#f0eeff,#e0ddff);}
  .thumb-fig.g4{background:linear-gradient(135deg,#fff1f1,#ffe3e3);}
  .thumb-fig.g5{background:linear-gradient(135deg,#eafff4,#d7ffef);}
  .thumb-fig.g6{background:linear-gradient(135deg,#fff6e6,#ffe9c9);}
  
  /* Carousel imagens */
  .carousel-caption{background:linear-gradient(180deg,#00000066,#00000033);border-radius:12px;padding:14px}
  .carousel-item img{display:block;width:100%;height:auto;object-fit:cover;}
  @media (min-width:1400px){.carousel-item img{max-height:520px}}
  
  /* Navbar: evitar nowrap */
  .navbar .nav-link{white-space:normal}
  
  /* ====== RESPONSIVIDADE ====== */
  @media (min-width:768px){
    .mobile-intro{display:none !important;}
    .grid-mobile{grid-template-columns:repeat(6,1fr);padding:12px 0}
    .tile{aspect-ratio:auto;min-height:82px}
  }
  
  /* ====== SLIDERS — base ====== */
  #banners{padding-top:30px;}
  #banners .banner-slider{--gap:16px;--per-page:1;}
  @media (min-width:768px){#banners .banner-slider{--per-page:1;}}
  
  .banner-viewport{overflow:hidden;}
  .banner-track{display:flex;gap:var(--gap);transition:transform .4s ease;will-change:transform;padding:6px 0;touch-action:pan-y;}
  .banner-track.dragging{transition:none;}
  .banner-card{flex:0 0 calc((100% - (var(--gap) * (var(--per-page) - 1))) / var(--per-page));border-radius:16px;overflow:hidden;background:#e9eef9;min-width:0;}
  .banner-card .banner-img{display:block;width:100%;height:auto;}
  
  /* Card de texto (Avisos) */
  .banner-card.banner-text{color:#fff;padding:16px 18px;display:flex;flex-direction:column;justify-content:space-between;min-height:160px;background:linear-gradient(135deg,#0c73f6,#1aa0ff);}
  .banner-card.banner-text h5{margin:4px 0 6px;font-weight:800;}
  .banner-card.banner-text p{margin:0;opacity:.95;line-height:1.3;}
  .banner-card.banner-text .meta{font-size:.85rem;opacity:.95;}
  .banner-card.banner-text .btn{align-self:flex-end;}
  
  /* Controles / indicadores */
  .banner-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;}
  .banner-controls .left-right{display:none;gap:8px;}
  .btn-nav{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d9dfeb;background:#fff;border-radius:10px;}
  .btn-nav i{font-size:18px;}
  .banner-indicators{display:flex;gap:6px;justify-content:center;flex:1;}
  .banner-indicators button{width:30px;height:8px;border-radius:5px;border:none;background:#cfd6e6;display:inline-block;}
  .banner-indicators button.active{background:#fff;box-shadow:0 0 0 5px #212529 inset;}
  
  /* ====== STACK (EMPILHADO) — usado em Eventos/Avisos/Banners ====== */
  .banner-slider.stacked .banner-viewport{overflow:hidden;}
  .banner-slider.stacked .banner-track{display:flex;gap:0;transition:transform .4s ease;}
  .banner-slider.stacked .stack-page{flex:0 0 100%;display:flex;flex-direction:column;gap:16px;padding:6px 2px;}
  .banner-slider.stacked .stack-page > .banner-card{flex:0 0 auto !important;width:100% !important;}
  .banner-slider.stacked .banner-card{flex:0 0 100%;}
  
  /* ====== Hero ====== */
  .welcome-hero{color:#fff;border-radius:16px;}
  .welcome-hero h2{font-weight:700;font-size:2.5em;}
  .welcome-hero .lead{opacity:.98}
  .lit-azul{background:linear-gradient(135deg,#0d6efd,#1546a0);padding:2.25rem 1.5rem;}
  #welcomeHero .lead{line-height:1.3;font-size:2.25em;}
  #welcomeHero .lead small{display:block;}
  .lit-branco{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#212529;}
  .lit-verde{background:linear-gradient(135deg,#198754,#11693f);}
  .lit-vermelho{background:linear-gradient(135deg,#dc3545,#a22330);}
  .lit-roxo{background:linear-gradient(135deg,#6f42c1,#533497);}
  @media (max-width:767.98px){#welcomeHero{zoom:.85;}}
  
  /* Banner “Destaques”: 1 por página */
  #bannerCol.banner-slider{--per-page:1;}
  #bannerCol .banner-viewport{overflow:hidden;}
  #bannerCol .banner-track{display:flex;gap:16px;transition:transform .4s ease;}
  #bannerCol .banner-card{flex:0 0 100%;}
  
  /* Força 1 por página no cálculo do container (não empilhado) — não necessário, mas mantém compatível */
  #sliderEventos.banner-slider{--per-page:1;}
  
  /* ====== Texto do Evangelho (quebra suave) ====== */
  .hero-line{display:block;flex-wrap:wrap;align-items:baseline;gap:.5rem;}
  #evangelhoRef{white-space:nowrap;}
  .evt{border-left:4px solid #0c73f6;background:linear-gradient(90deg,#eef4ff,#ffffff);padding:14px 16px;border-radius:12px;transition:background .2s,transform .12s ease;display:flex;align-items:center;justify-content:space-between;gap:12px;}
  .evt:hover{background:linear-gradient(90deg,#e6efff,#ffffff);transform:translateY(-1px);}
  .evt .evt-main{flex:1 1 auto;min-width:0;}
  .evt h5{margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
  /* compatibilidade: adiciona a propriedade padrão */
  .evt h5{line-clamp: 2;}
  .date-badge{width:64px;min-width:64px;height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0c73f6;color:#fff;border-radius:12px;line-height:1;}
  /* Limites/rolagens ocasionais */
  .list-scroll{max-height:420px;overflow:auto;}
  
  /* Redes sociais (mobile/pc) */
  .social-icons a{display:inline-flex;align-items:center;justify-content:center;width:45px;height:39px;border-radius:10px;border:1px solid #e1e6f0;background:#fff;margin:0 4px;text-decoration:none;color:#77bcd8;padding-top:5px;}
  .social-icons a:hover{background:#f3f7ff;}
  .social-icons i{font-size:25px;}
  
  .info-card,.pastoral-card{border:1px solid #00000012;border-radius:16px;background:#fff;overflow:hidden;display:flex;flex-direction:column;height:100%;}
  .thumb-cover{max-height:100px;display:grid;place-items:center;/*background:linear-gradient(135deg,#e9f2ff,#dbe9ff);*/position:relative;overflow:hidden;min-height:100px;border-bottom:1px solid #eef1f6;}
  .thumb-cover .thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;}
  .thumb-cover i {    font-size: 40px;    color: #0c73f6;}
  .info-card .card-body,.pastoral-card .card-body{padding:14px;display:flex;flex-direction:column;gap:8px;flex:1 1 auto;}
  .info-card h6,.pastoral-card h6{font-weight:700;margin-bottom:6px;}
  .info-card p,.pastoral-card p{margin:0 0 8px;color:#6b7480;}
  .info-card .card-body .btn,.pastoral-card .card-body .btn{margin-top:auto;align-self:flex-start;}
  
  /* Menu PC */
  @media (min-width:768px){
    .menu-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;}
    .btn-menu{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid #e3e8f6;background:#fff;color:#24324a;text-decoration:none;font-weight:600;font-size:.95rem;transition:background .15s,border-color .15s,transform .12s ease;}
    .btn-menu:hover{background:#f4f7ff;border-color:#d6def4;transform:translateY(-1px);}
    .social-grid-pc{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-items:center;margin:6px;}
    .tile-social-pc{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0px;text-align:center;text-decoration:none;border-radius:14px;border:1px solid #dbe5ff;padding:10px;aspect-ratio:1/1;min-height:64px;color:#123 !important;transition:transform .12s ease,box-shadow .2s,background .2s,border-color .2s;}
    .tile-social-pc:hover{transform:translateY(-2px);background:#f3f7ff;border-color:#c8d6ff;box-shadow:0 10px 24px rgba(15,62,138,.08);}
    .tile-social-pc i{font-size:26px;color:#385c6f;filter:none;}
    .tile-social-pc span{font-size:.68rem;color:#2a3a55;line-height:1.1;}
  }
  
  /* Collapse mobile */
  @media (max-width:767.98px){
    .navbar-collapse{max-height:calc(100vh - var(--navH,64px));overflow-y:auto;}
    .collapse#navMain{max-height:calc(100vh - var(--navH,64px));overflow-y:auto;}
  }
  
  /* Barra de menu PC */
  .menu-pc{background:#e9ecef;padding:8px 0;}
  .site-header{--bs-navbar-toggler-icon-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(36,50,74,0.9)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");}
  .site-header .navbar-toggler{border-color:#d0d7e2;}
  .site-header .navbar-toggler:focus{box-shadow:0 0 0 .15rem rgba(12,115,246,.25);}
  
  /* Redes sociais — mobile tiles menores */
  
  .tile-social{min-height:72px;aspect-ratio:1/1;padding:6px;gap:0;border-radius:14px;background:linear-gradient(180deg,#ffffff22,#ffffff10);}
  .tile-social:hover{background:linear-gradient(180deg,#ffffff2e,#ffffff16);}
  .tile-social i{font-size:26px;}
  .tile-social span{font-size:.68rem;}
  
  /* Ajustes utilitários */
  #bannerCol .banner-indicators button,
  #sliderEventos .banner-indicators button,
  #sliderAvisos .banner-indicators button{display:inline-block;}
  
  .pl-0{ padding-left: 0px !important;}
  .pr-0{ padding-right: 0px !important;}

  /*.icone-redes-mobile{
    margin: 6px auto 12px;
    padding-bottom: 30px;
    grid-template-columns: repeat(5, 1fr);
  }*/

  /* container dos ícones (uma linha, até 5 “vagas”) */
.icone-redes-mobile{
    --cols: 5;          /* quantas vagas por linha */
    --gap: 10px;        /* mesmo espaçamento que você usa */
    display: flex;
    flex-wrap: wrap;    /* permite quebrar linha se houver mais de 5 itens */
    justify-content: center; /* centraliza quando tiver menos itens */
    gap: var(--gap);
  
    margin: 6px auto 12px;
    padding-bottom: 30px;
  }
  
  /* cada item ocupa 1/5 da largura (com gap já descontado) */
  .icone-redes-mobile .icone-item{
    box-sizing: border-box; /* inclui borda no cálculo de largura */
    /* subtrai uma fração de pixel para evitar quebra por arredondamento em celulares */
    flex: 0 0 calc((100% - (var(--gap) * (var(--cols) - 1))) / var(--cols) - 0.5px);
    max-width: calc((100% - (var(--gap) * (var(--cols) - 1))) / var(--cols) - 0.5px);
    aspect-ratio: 1 / 1; 
    min-height: auto;
    padding: 1px !important; /* restaura respiro padrão da .tile */
    border-radius: 12px;      /* mantém o visual arredondado */
    border: 1px solid #ffffff2b; /* borda clarinha como na .tile */
    background: linear-gradient(180deg,#ffffff1c,#ffffff10); /* fundo suave */
    display: flex; align-items: center; justify-content: center; flex-direction: column;
    gap: 0px !important;
  }

  .icone-redes-mobile .icone-item span{
    display: block;            /* volta a exibir o texto */
    font-size: 0.70rem;        /* menorzinho para caber bem */
    color: var(--dim);         /* mesma cor suave usada no tema */
    line-height: 1.15;
  }

  /* tamanho do ícone menor e centralizado */
  .icone-redes-mobile .icone-item i{
    display: block;            
    font-size: 18px;           /* levemente menor que a .tile padrão */
    line-height: 1;
  }

/* Largura da modal universal */
.modal-dialog.modal-conteudo{
    width: 80vw;
    max-width: min(1200px, 80vw);
  }
  
  /* Altura comportada: cresce conforme o conteúdo, mas não passa da viewport */
  #modalConteudo .modal-body{
    max-height: calc(100vh - 7rem); /* header+footer ~ 7rem */
    overflow: auto;
  }
  
  /* Tablet/Mobile: 100% largura */
  @media (max-width: 991.98px){
    .modal-dialog.modal-conteudo{
      width: 100vw;
      max-width: 100vw;
      margin: 0;               /* encosta nas bordas */
    }
    #modalConteudo .modal-content{
      border-radius: 0;        /* look full-screen */
    }
  }