@charset "utf-8";
/* ===== Tema di base ===== */
.sfondo { background-color: #261B23; }
.texto { color: #261B23; display: none; }

/* ===== Variabili + reset responsive ===== */
:root {
  --content-max: 1080px;       /* larghezza massima contenitore */
  --gutter: 16px;              /* margine interno laterale */
  --ui-text: 14px;             /* testo form e titoli icone */
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, video, canvas { max-width: 100%; height: auto; display:block; }

/* ===== Layout principale ===== */
.container {
  position: relative !important;  /* necessario per ::before/::after */
  left: auto !important; right: auto !important; top: auto !important;
  margin: 25px auto 0 !important;
  width: 100% !important;
  max-width: var(--content-max);
  padding: 0 var(--gutter);
  border: 0;                      /* niente bordi nativi: li disegniamo “inset” */
  height: auto;
}

/* linee orizzontali allineate al contenuto (NO sbordo) */
.container::before,
.container::after {
  content: "";
  position: absolute;
  left: var(--gutter);
  right: var(--gutter);
  height: 1px;
  background: #FFFFFF;
  pointer-events: none;
}
.container::before { top: 0; }     /* linea superiore */
.container::after  { bottom: 0; }  /* linea inferiore */

/* Blocchi tipici */
.parteAlta, .personalMenu, .espRis, .percorso, .piedipagina { float:none!important; width:100%!important; }

/* ===== Testata ===== */
.parteAlta {
  background-color: #C93;
  border-bottom: 1px solid #FFFFFF;
  min-height: 160px;
  padding: 12px;
  position: relative;
  z-index: 1;
  overflow: hidden;

  /* evita ripetizione di eventuale background image */
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

/* Titoli storici */
.Stile1 { font-size: clamp(24px, 5vw, 56px); font-family: Arial, Helvetica, sans-serif; color:#fff; margin:0; padding-top:5px; text-align:center; }
.tit { font-family:"Arno Pro Display"; }
.Stile3 { padding-top:20px; font-size: clamp(16px, 3.5vw, 36px); font-style: italic; font-weight: bold; text-align:center; margin:0; }
.Stile4 { color:#fff; font-size: clamp(18px, 3vw, 30px); }
.Stile6 { color:#fff; font-size: clamp(14px, 2.5vw, 18px); font-style:italic; margin:0; text-align:center; line-height:1.25; }
/* Avvicina (2 Re 7:9) */
.parteAlta .Stile6 + .Stile2 {
  position: static!important; display:inline-block; margin-top:2px;
  color:#fff; font-size: clamp(12px, 2.2vw, 18px); font-style:italic; font-weight:bold;
  text-align:center; line-height:1.2; text-shadow:0 1px 3px rgba(0,0,0,.35);
}

/* ===== Area contenuti ===== */
.espRis { background:#000; color:#fff; font-family: Arial, Helvetica, sans-serif; font-size:12px; padding:12px var(--gutter); }

/* ---------- LOGIN ---------- */
.login-panel { background:#000; color:#fff; padding:12px 14px; border-radius:6px; border:1px solid #333; }
.login-panel .login-title { margin:0 0 10px; font-size:18px; color:#fff; }
.login-panel label, .login-panel legend, .login-panel b, .login-panel strong { color:#fff!important; }
.login-error { color:#ffb3b3; margin:6px 0 10px; }
.login-form { margin-top:6px; font-size:var(--ui-text); }
.login-form .form-row { display:grid; grid-template-columns:1fr; gap:8px; align-items:center; }
.login-form label { font-weight:600; letter-spacing:.5px; font-size:var(--ui-text); }
.login-form input[type="text"], .login-form input[type="password"] { background:#111; color:#fff; border:1px solid #555; padding:6px 8px; border-radius:4px; width:100%; font-size:var(--ui-text); }
.login-form input::placeholder { color:#bbb; font-size:var(--ui-text); }
.btn-login { background:#222; color:#fff; border:1px solid #555; padding:6px 12px; border-radius:6px; cursor:pointer; font-size:var(--ui-text); }
.btn-login:hover { background:#333; }
.btn-ghost { background:transparent; color:#fff; border:1px solid #777; }
.btn-ghost:hover { background:#111; }
.login-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.login-actions form button { padding:6px 10px; }

/* ===== Footer ===== */
.piedipagina { clear:both; padding:8px var(--gutter); border-top:1px solid #FFFFFF; background:#FF6300; margin:0; font-size:12px; }
#piedpg2 { color:#fff; }

/* ===== Menu ===== */
.personalMenu { background:#FF6300; border-bottom:1px solid #FFFFFF; position:relative; z-index:5; clear:both; }
.personalMenu ul { list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:8px; }
.personalMenu li { margin:0; }
.personalMenu a { display:block; padding:8px 10px; color:#000; text-decoration:none; line-height:1; }

/* ===== Breadcrumb ===== */
.percorso { white-space:normal; overflow-wrap:anywhere; background:#FF7F00; color:#fff; padding:6px; margin:8px 0; }

/* ===== Utility ===== */
.clr-left { clear:left; } .clr-right { clear:right; } .clr-both { clear:both; } .flt-left { float:left; }

/* ===== Pannello admin (strumenti) ===== */
#admin-panel-dark{ background:#000; color:#fff; padding:12px 14px; border-radius:6px; margin:12px 0; clear:both; overflow:auto; border:1px solid #333; }
#admin-panel-dark h2, #admin-panel-dark h3 { margin:6px 0 10px; font-weight:600; }
.admin-form { margin:8px 0; font-size:var(--ui-text); }
.admin-form .form-row { display:grid; grid-template-columns:1fr; gap:8px; align-items:center; }
.admin-form .form-label { color:#fff; font-size:var(--ui-text); }
.admin-form .form-input[type="file"], .admin-form .form-input[type="text"] { width:100%; font-size:var(--ui-text); }
#admin-panel-dark .btn { background:#222; color:#fff; border:1px solid #555; padding:6px 10px; border-radius:4px; cursor:pointer; font-size:var(--ui-text); }
#admin-panel-dark .btn:hover { background:#333; }
.admin-form .form-row.form-rename { grid-template-columns:1fr; }
@media (min-width:640px){
  .admin-form .form-row{ grid-template-columns:auto 1fr auto; }
  .admin-form .form-row .form-label{ white-space:nowrap; }
  .admin-form .form-row.form-rename{ grid-template-columns:auto 1fr 1fr auto; }
}

/* ===== Griglia pubblicazioni (icone/cartelle) ===== */
.griglia-pubblicazioni{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); /* base */
  gap:16px 18px;
  align-items:start;
}
.pub-item { text-align:center; }
.pub-thumb { width:64px; height:64px; margin:0 auto 6px; display:block; }
.pub-title{ color:#fff; font-size:var(--ui-text); line-height:1.25; margin-top:2px; user-select:text; white-space:normal; word-break:break-word; }

/* ===== Breakpoints ===== */

/* <= 1024px */
@media (max-width: 1024px) {
  .griglia-pubblicazioni { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}

/* <= 768px */
@media (max-width: 768px) {
  :root { --gutter: 14px; }
  .griglia-pubblicazioni { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap:14px; }
}

/* <= 480px — 2 colonne fisse */
@media (max-width: 480px) {
  :root { --gutter: 12px; }
  .griglia-pubblicazioni { grid-template-columns: repeat(2, 1fr) !important; gap:12px; }
  .pub-thumb { width:56px; height:56px; }
}

/* >= 1024px — 4 colonne fisse su desktop */
@media (min-width: 1024px) {
  .griglia-pubblicazioni { grid-template-columns: repeat(4, 1fr) !important; }
}
