/* ──────────────────────────────────────────────────────────────────────────────
 *  app.css — Mucciolo · Cervati — pagina-etichetta (poster digitale).
 *  Mobile-first. Palette del sito:
 *    #D2A430 oro · #E1B847 oro 2 · #9D8C2E oliva medio · #5C581C oliva profondo
 *    #333916 verde scuro · #3C4117 verde scuro 2 · #F5F3F1 avorio · #232419 quasi-nero
 *  @author t4k-tools — v1.2.0
 * ────────────────────────────────────────────────────────────────────────────── */
:root{
  --gold:#D2A430; --gold-2:#E1B847; --olive-m:#9D8C2E; --olive-deep:#2A2808;
  --green-d:#333916; --green-2:#3C4117; --ivory:#F5F3F1; --ink:#0A0905;
  --paper:#F5F3F1;
  --ui:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --serif:ui-serif,Georgia,"Times New Roman",serif;
}
*,*::before,*::after{ box-sizing:border-box; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
html,body{ height:100%; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--serif);
  color:var(--ink);
  background:
    radial-gradient(130% 120% at 50% 0%, var(--green-2) 0%, var(--green-d) 42%, var(--ink) 100%)
    fixed;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* Toggle lingua: pill in alto a destra, touch-friendly */
.lang-toggle{
  position:fixed; top:.9rem; right:.9rem; z-index:5;
  min-height:40px; display:inline-flex; align-items:center;
  background:var(--gold); color:#1a1a14; text-decoration:none;
  font-family:var(--ui); font-size:.82rem; font-weight:700;
  letter-spacing:.06em; padding:.4rem .85rem; border-radius:50rem;
  box-shadow:0 2px 8px rgba(0,0,0,.28); transition:background .15s;
}
.lang-toggle:hover,.lang-toggle:focus-visible{ background:var(--gold-2); outline:none; }
.lang-toggle:focus-visible{ box-shadow:0 0 0 3px rgba(225,184,71,.45); }

/* Poster centrato a tutta altezza */
.poster{
  min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.2rem; padding:clamp(1rem,4vw,3rem);
}

/* L'etichetta incorniciata */
.label-frame{
  margin:0;
  background:var(--paper);
  padding:clamp(.4rem,1.6vw,1rem);
  border-radius:6px;
  border:1px solid rgba(35,41,27,.10);
  box-shadow:0 24px 60px rgba(35,41,27,.5), 0 4px 14px rgba(35,41,27,.35);
}
.label-frame img{
  display:block;
  width:auto; height:auto;
  max-height:72svh;
  max-width:min(92vw, 440px);
  border-radius:2px;
}

/* Didascalia */
.caption{
  margin:0;
  color:var(--gold);
  font-style:italic;
  font-size:clamp(.95rem,2.4vw,1.25rem);
  letter-spacing:.06em;
  text-align:center;
  text-shadow:0 1px 6px rgba(0,0,0,.35);
}
/* "Scrigno": l'etichetta è cliccabile e apre /vigna (nessun link visibile) */
.label-link{ display:inline-block; text-decoration:none; cursor:pointer; border-radius:6px; }
.label-link:focus-visible{ outline:2px solid var(--gold); outline-offset:6px; }

@media (prefers-reduced-motion: no-preference){
  .label-frame{ transition:transform .3s ease; }
  .label-frame:hover{ transform:translateY(-4px) rotate(-.4deg); }
}

/* ── Scheda personale ({slug}.mucciolo.it) ─────────────────────────────────── */
.persona-wrap{
  min-height:100svh;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(.8rem,4vw,3rem);
}
.persona-card{
  width:100%; max-width:560px;
  background:var(--paper); color:var(--ink);
  border:1px solid rgba(35,41,27,.10); border-radius:14px;
  box-shadow:0 24px 60px rgba(35,41,27,.5), 0 4px 14px rgba(35,41,27,.35);
  padding:clamp(1.2rem,4vw,2.4rem);
  text-align:center;
}
.persona-avatar{
  width:120px; height:120px; border-radius:50%; object-fit:cover;
  margin:0 auto .9rem; display:flex; align-items:center; justify-content:center;
  border:3px solid var(--gold);
}
.persona-initials{
  background:var(--green-d); color:var(--gold);
  font-family:var(--serif); font-size:2.4rem; font-weight:700; letter-spacing:.04em;
}
.persona-name{ margin:.2rem 0 .15rem; font-size:clamp(1.8rem,6vw,2.2rem); line-height:1.15; font-weight:600; }
.persona-tagline{ margin:0 0 1.2rem; color:var(--olive-deep); font-style:italic; letter-spacing:.03em; font-size:1.22rem; font-weight:500; }
.persona-bio{ margin:0 auto 1.5rem; max-width:50ch; color:var(--ink); text-align:left; font-size:1.22rem; line-height:1.6; font-weight:500; }

.persona-card .contatti{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; text-align:left; }
.persona-card .contatto{
  display:flex; align-items:center; gap:.7rem;
  padding:.75rem .85rem; min-height:48px;
  border:1px solid rgba(35,41,27,.12); border-radius:.55rem;
  background:rgba(157,140,46,.06);
}
.contatto-icon{ font-size:1.35rem; line-height:1; flex:0 0 auto; }
.contatto-label{ flex:0 0 5.5rem; color:var(--olive-deep); font-size:.92rem; font-weight:600; font-family:var(--ui); }
.contatto-val{ font-weight:700; color:var(--ink); text-decoration:none; word-break:break-word; flex:1 1 auto; min-width:0; font-size:1.12rem; }
.contatto-val:hover{ color:var(--green-d); text-decoration:underline; }
/* Separatore tra gruppi di recapiti (tipo "sep") */
.contatto-sep{ list-style:none; text-align:center; margin:.7rem 0 .15rem;
  border-top:1px solid rgba(35,41,27,.18); }
.contatto-sep span{ position:relative; top:-.62em; display:inline-block; padding:0 .6rem;
  background:var(--paper); color:var(--olive-deep);
  font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  font-family:var(--ui); }
.persona-foot{ margin:1.4rem 0 0; }
.persona-foot a{ color:var(--olive-deep); text-decoration:none; font-size:.85rem; letter-spacing:.06em; font-family:var(--ui); }
.persona-foot a:hover{ color:var(--gold-2); }

/* Mobile: card full-bleed, niente cornice */
@media (max-width:480px){
  .persona-wrap{ padding:0; }
  .persona-card{
    border-radius:0; border:0; box-shadow:none; max-width:100%;
    min-height:100svh; padding:1.6rem 1.1rem 2rem;
    display:flex; flex-direction:column; justify-content:flex-start;
  }
  .persona-bio{ text-align:left; }
  .contatto-label{ flex-basis:4.5rem; font-size:.75rem; }
}

/* ── Login / editor scheda ─────────────────────────────────────────────────── */
.edit-card{ text-align:left; max-width:600px; }
.edit-card h1{ font-size:clamp(1.2rem,4.5vw,1.5rem); margin:.1rem 0; font-family:var(--serif); }
.edit-head{ display:flex; align-items:center; justify-content:space-between; gap:.6rem; margin-bottom:.6rem; flex-wrap:wrap; }
.edit-sub{ margin:1.2rem 0 .2rem; color:var(--olive-deep); font-size:1rem; font-family:var(--ui); }
.edit-card label{ display:block; margin:.7rem 0 .2rem; font-size:.85rem; color:var(--olive-deep); font-family:var(--ui); }
.edit-card input[type=text], .edit-card input[type=url], .edit-card input[type=password],
.edit-card textarea, .edit-card select{
  width:100%; padding:.65rem .7rem;
  font-family:var(--ui); font-size:16px; /* >=16px previene auto-zoom iOS */
  color:var(--ink);
  background:#fff; border:1px solid rgba(35,41,27,.20); border-radius:.45rem;
  min-height:44px;
}
.edit-card textarea{ min-height:88px; line-height:1.5; }
.edit-card input:focus, .edit-card textarea:focus, .edit-card select:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 .15rem rgba(210,164,48,.3);
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; } }

/* Tabella contatti: griglia desktop, stack su mobile */
.edit-contatti{ width:100%; border-collapse:collapse; }
.edit-contatti td{ padding:.2rem .15rem; vertical-align:top; }
.edit-contatti td.c-actions{ width:2.4rem; padding-top:.45rem; }
.edit-contatti td:nth-child(2){ width:11rem; }
.c-actions{ display:flex; flex-direction:column; gap:2px; align-items:center; }
.c-move{
  width:28px; height:22px; padding:0; line-height:1;
  border:1px solid rgba(35,41,27,.18); background:#fff; color:var(--olive-deep);
  border-radius:.3rem; cursor:pointer; font-size:.7rem;
  display:inline-flex; align-items:center; justify-content:center;
}
.c-move:hover,.c-move:focus-visible{ background:var(--gold); color:var(--ink); border-color:var(--gold); outline:none; }
@media (max-width:560px){
  .edit-contatti, .edit-contatti tbody, .edit-contatti tr, .edit-contatti td{
    display:block; width:100%;
  }
  .edit-contatti td.c-actions, .edit-contatti td:nth-child(2){ width:auto; }
  .edit-contatti tr{
    margin-bottom:.7rem; padding:.6rem; border:1px solid rgba(35,41,27,.10); border-radius:.5rem;
    background:rgba(157,140,46,.04);
    display:grid; grid-template-columns:auto 1fr; grid-template-areas:"act sel" "act val"; gap:.4rem .6rem;
  }
  .edit-contatti td{ padding:0; }
  .edit-contatti td.c-actions{ grid-area:act; flex-direction:column; }
  .edit-contatti td:nth-child(2){ grid-area:sel; }
  .edit-contatti td:nth-child(3){ grid-area:val; }
  .c-move{ width:36px; height:36px; font-size:.85rem; }
}

/* Sezione impostazioni (cambio password) — ancorata a #settings */
.edit-actions{ display:inline-flex; align-items:center; gap:.4rem; }
.btn-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:50%;
  background:rgba(157,140,46,.10); color:var(--olive-deep);
  border:1px solid rgba(35,41,27,.18); text-decoration:none;
  font-size:1.1rem; line-height:1; cursor:pointer;
  transition:background .2s, color .2s, transform .2s;
}
.btn-icon:hover,.btn-icon:focus-visible{
  background:var(--gold); color:var(--ink); border-color:var(--gold); outline:none;
  transform:rotate(45deg);
}
.edit-settings{
  margin:2rem 0 .5rem; padding:1.2rem 1.1rem 1.3rem;
  border:1px solid rgba(35,41,27,.16); border-radius:.7rem;
  background:rgba(157,140,46,.06);
  scroll-margin-top:1rem;
}
.edit-settings h3{ margin:0 0 .3rem; font-family:var(--ui); font-size:1.05rem; color:var(--olive-deep); }
.edit-settings .form-hint{ margin-bottom:.6rem; }
.form-hint{ color:var(--olive-deep); font-size:.8rem; margin:.1rem 0 .5rem; font-family:var(--ui); }
.form-alert{ padding:.6rem .85rem; border-radius:.45rem; border:1px solid var(--danger,#b3401f);
  color:#8a2d12; background:rgba(179,64,31,.08); margin:.4rem 0; font-family:var(--ui); font-size:.9rem; }
.form-ok{ border-color:var(--green-d); color:var(--green-d); background:rgba(100,112,47,.10); }
.btn-gold{ display:inline-block; margin-top:.7rem; padding:.75rem 1.4rem; border:0; border-radius:.5rem;
  background:var(--gold); color:var(--ink); font-family:var(--ui); font-size:1rem; font-weight:700;
  cursor:pointer; min-height:44px; }
.btn-gold:hover,.btn-gold:focus-visible{ background:var(--gold-2); outline:none; }
.btn-mini{ display:inline-block; padding:.5rem .85rem; border:1px solid rgba(35,41,27,.2); border-radius:.4rem;
  background:transparent; color:var(--olive-deep); font-family:var(--ui); font-size:.85rem; cursor:pointer;
  text-decoration:none; min-height:36px; }
.btn-mini:hover,.btn-mini:focus-visible{ background:rgba(157,140,46,.10); outline:none; }
.logout-form{ margin-top:1.2rem; text-align:right; }

/* ── 404 ── */
.nf-wrap{ min-height:80svh; }
.nf-card{ text-align:center; color:var(--ivory); font-family:var(--ui); max-width:30rem; padding:0 1rem; }
.nf-code{ font-family:var(--serif); font-size:clamp(2.4rem,9vw,3.6rem); color:var(--gold); margin:0 0 .4rem; font-weight:700; }
.nf-title{ font-size:1.15rem; margin:0 0 .5rem; color:var(--gold-2); }
.nf-text{ opacity:.85; margin:0 0 1.6rem; line-height:1.5; }
.nf-back{ text-decoration:none; }
