/* =========================================================
   VARIABILI GLOBALI
   ========================================================= */
:root{
  --ps-blue:#0b5ed7;
  --ps-blue-dark:#084298;
  --ps-soft:#f2f6fc;
  --ps-text:#0b1220;
  --ps-muted:#5a6a82;
  --ps-border:#e6edf7;
}

/* =========================================================
   BASE
   ========================================================= */
body{
  color:var(--ps-text);
}

/* Anchor offset per navbar sticky */
section{
  scroll-margin-top: 90px;
}

.ps-muted{
  color:var(--ps-muted);
}

/* =========================================================
   TOP BAR
   ========================================================= */
.ps-topbar{
  background: var(--ps-blue-dark);
  color:#fff;
  font-size:.95rem;
}
.ps-topbar a{
  color:#fff;
  text-decoration:none;
}
.ps-topbar a:hover{
  text-decoration:underline;
}

/* =========================================================
   NAVBAR
   ========================================================= */
.ps-navbar{
  background:#fff;
  border-bottom:1px solid var(--ps-border);
}
.ps-brand-logo{
  height:56px;
  width:auto;
}

/* =========================================================
   HERO
   ========================================================= */
.ps-hero{
  position: relative;
  overflow: hidden;
  background: #ffffff;
  padding: 24px 0 56px;
}

.ps-hero h1{
  letter-spacing:-0.5px;
}

.ps-hero h1,
.ps-hero h2{
  margin-top: 0;
}

.ps-lead{
  color:var(--ps-muted);
}

/* =========================================================
   HERO IMAGE (immagine integrata)
   ========================================================= */
.ps-hero-image{
  position: relative;
}

.ps-hero-image{
  position: relative;
}

.ps-hero-image img{
  width: 100%;
  height: auto;
  display: block;

  /* RESET effetti indesiderati */
  border-radius: 0;
  box-shadow: none;
}


/* Sfumatura elegante di integrazione */
.ps-hero-image::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:30%;
  height:100%;
  pointer-events:none;
  background: linear-gradient(
    90deg,
    #ffffff 0%,
    rgba(255,255,255,.85) 40%,
    rgba(255,255,255,.4) 65%,
    rgba(255,255,255,0) 100%
  );
}


/* Nascondiamo l’immagine su mobile */
@media (max-width: 992px){
  .ps-hero-image{
    display:none;
  }
}

/* =========================================================
   SEZIONI
   ========================================================= */
.ps-section{
  padding: 32px 0;
}

h2.ps-section-title{
  font-weight: 600;
  letter-spacing: -0.3px;
  color: var(--ps-blue-dark);
}


/* =========================================================
   CARD
   ========================================================= */
.ps-card{
  background:#fff;
  border:1px solid var(--ps-border);
  border-radius:16px;
  box-shadow: 0 10px 26px rgba(11,18,32,.06);
  transition: transform .25s ease, box-shadow .25s ease;
}

.ps-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(11,18,32,.12);
}

.ps-card p{
  line-height:1.7;
  margin-bottom:1.1rem;
}

/* =========================================================
   LISTE
   ========================================================= */
.ps-list li{
  margin-bottom:.5rem;
  color:var(--ps-muted);
}

/* =========================================================
   BADGE
   ========================================================= */
.ps-badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.45rem .75rem;
  border-radius:999px;
  background: rgba(11,94,215,.08);
  color: var(--ps-blue-dark);
  border: 1px solid rgba(11,94,215,.18);
  font-weight:600;
  font-size:.92rem;
}

/* =========================================================
   BOTTONI
   ========================================================= */
.btn-primary{
  background: var(--ps-blue-dark);
  border-color: var(--ps-blue-dark);
  border-radius:12px;
  padding:10px 16px;
  font-weight:700;
}

.btn-outline-primary{
  border-radius:12px;
  padding:10px 16px;
  font-weight:700;
}

/* =========================================================
   EVIDENZIAZIONE <strong> (sobria e istituzionale)
   ========================================================= */
.ps-card strong,
.ps-section strong{
  font-weight:600;
  color:#0b3c74;
}

/* =========================================================
   SEZIONE CHI SIAMO
   ========================================================= */
#chi-siamo{
  background:#f9fbff;
}
#chi-siamo .ps-card p{
  font-size: 1.05rem;
}


/* =========================================================
   FOOTER
   ========================================================= */
.ps-footer{
  background:#0b1220;
  color:#cbd5e1;
  padding:28px 0;
  border-top:4px solid var(--ps-blue);
}

.ps-footer a{
  color:#cbd5e1;
  text-decoration:none;
}
.ps-footer a:hover{
  text-decoration:underline;
}

/* =========================================================
   ANIMAZIONI ON SCROLL (sobrie, PA-style)
   ========================================================= */

.reveal{
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity .6s ease,
    transform .6s ease;
  will-change: opacity, transform;
}

.reveal-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Variante più leggera per card */
.reveal-card{
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity .5s ease,
    transform .5s ease;
}

.reveal-card.reveal-visible{
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .reveal,
  .reveal-card{
    transition: none;
    transform: none;
    opacity: 1;
  }
}

/* =========================================================
   ANIMAZIONE LOGO NAVBAR – sobria e istituzionale
   ========================================================= */

/* Contenitore logo */
.ps-navbar .navbar-brand{
  position: relative;
  display: inline-block;
  overflow: hidden;
}

/* Immagine logo */
.ps-navbar .navbar-brand img{
  transform: scale(1);
  transition: transform .5s ease-out;
}

/* Hover: pulse leggerissimo */
.ps-navbar .navbar-brand:hover img{
  animation: pulseLogo 3s ease-in-out infinite;
}

/* Pulse molto leggero */
@keyframes pulseLogo{
  0%   { transform: scale(1.00); }
  50%  { transform: scale(1.02); }
  100% { transform: scale(1.00); }
}

/* Effetto shine continuo (discreto) */
.ps-navbar .navbar-brand::after{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:50%;
  height:100%;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.35) 50%,
    rgba(255,255,255,0) 100%
  );
  transform: skewX(-25deg);
  animation: shineLogo 4s ease-in-out infinite;
  pointer-events:none;
}

/* Shine loop */
@keyframes shineLogo{
  0%   { left:-100%; }
  60%  { left:130%; }
  100% { left:130%; }
}

/* =========================================================
   ACCESSIBILITÀ – riduzione animazioni
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  .ps-navbar .navbar-brand img,
  .ps-navbar .navbar-brand::after{
    animation: none !important;
    transition: none !important;
  }
}

/* ================================
   Menu top – hover elegante
   ================================ */

.ps-navbar .nav-link{
  position: relative;
  color: var(--ps-text);
  font-weight: 500;
  padding: .5rem .75rem;
  transition: color .25s ease;
}

/* underline animata */
.ps-navbar .nav-link::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 2px;
  background: var(--ps-blue);
  border-radius: 2px;
  transform: translateX(-50%);
  transition: width .25s ease;
}

/* hover */
.ps-navbar .nav-link:hover{
  color: var(--ps-blue-dark);
}

.ps-navbar .nav-link:hover::after{
  width: 60%;
}

/* voce attiva */
.ps-navbar .nav-link.active{
  color: var(--ps-blue-dark);
  font-weight: 600;
}

.ps-navbar .nav-link.active::after{
  width: 60%;
}


/* ================================
   Contatti – icone
   ================================ */

.ps-contact-icon{
  font-size: 1.2rem;
  color: var(--ps-blue-dark);
  margin-right: 12px;
  margin-top: 2px;
  flex-shrink: 0;
}

/* ========================================================================================
   Per visualizzare su mobile il titolo della sezione quando clicco sul menu
   ======================================================================================== */
#chi-siamo,
#protocollo-pa,
#contatti{
  scroll-margin-top: 200px;
}
