/* =============================================================================
   Strike — Area Clienti
   Coerente con il sito vetrina (palette "Concrete & Citron")
   ========================================================================== */

:root{
  --ink:#14181B;
  --ink2:#1F2629;
  --ink3:#2A3236;
  --cream:#E6E4DD;
  --cream2:#DAD8D0;
  --paper:#F4F2EB;
  --citron:#DAFF3E;
  --citron-soft:#E8FF6B;
  --citron-glow:#B8DD20;
  --gravel:#7A7773;
  --rust:#B5613E;
  --line-light:rgba(20,24,27,.08);
  --line-mid:rgba(20,24,27,.14);
  --line-dark:rgba(230,228,221,.10);

  --serif:'Newsreader',Georgia,serif;
  --sans:'Inter',-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
::selection{background:var(--citron);color:var(--ink)}

em.cit, .cit em{font-style:italic;background:var(--citron);color:var(--ink);padding:0 .1em;box-decoration-break:clone;-webkit-box-decoration-break:clone}

/* =============================================================================
   AUTH (login + error pages)  — sfondo scuro, vibe "cine"
   ========================================================================== */

body.auth{
  background:var(--ink);
  color:var(--cream);
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}

.auth-bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.auth-bg svg{width:100%;height:100%}
.auth-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(218,255,62,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(218,255,62,.05) 1px,transparent 1px);
  background-size:96px 96px;
  mask:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 90%);
  -webkit-mask:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 90%);
}
.auth-vignette{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 30%,rgba(20,24,27,.7) 100%);
}

.auth-nav{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem clamp(1.25rem,4vw,3rem);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
}
.auth-logo{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.1rem;letter-spacing:0;text-transform:none;color:var(--cream)}
.auth-mark{width:24px;height:24px;background:var(--citron);border-radius:50%;position:relative;overflow:hidden}
.auth-mark::after{content:"";position:absolute;inset:6px;background:var(--ink);border-radius:50%}
.auth-back{color:rgba(230,228,221,.55);transition:color .2s}
.auth-back:hover{color:var(--citron)}

.auth-shell{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.85fr);
  gap:clamp(2rem,5vw,5rem);
  max-width:1280px;margin:0 auto;
  padding:clamp(2rem,6vw,5rem) clamp(1.25rem,4vw,3rem);
  align-items:center;
  min-height:calc(100vh - 200px);
}
@media(max-width:880px){.auth-shell{grid-template-columns:1fr}}

.auth-card{
  background:rgba(31,38,41,.6);
  border:1px solid rgba(230,228,221,.08);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:clamp(2rem,4vw,3rem);
  border-radius:18px;
}

.auth-kicker{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--cream);display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;
}
.auth-kicker::before{content:"";width:24px;height:2px;background:var(--citron)}

.auth-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(2.2rem,5vw,3.4rem);line-height:1;letter-spacing:-.03em;
  color:var(--cream);
}
.auth-title em{font-style:italic;background:var(--citron);color:var(--ink);padding:0 .08em;font-weight:300;box-decoration-break:clone;-webkit-box-decoration-break:clone}

.auth-lede{
  margin-top:1.3rem;color:rgba(230,228,221,.7);
  font-size:1.02rem;max-width:42ch;
}

.auth-error{
  margin-top:1.5rem;padding:.85rem 1rem;
  background:rgba(181,97,62,.12);border:1px solid rgba(181,97,62,.4);
  color:#F0C5B0;border-radius:10px;font-size:.92rem;
  display:flex;align-items:center;gap:.7rem;
}
.auth-error-dot{
  width:8px;height:8px;border-radius:50%;background:var(--rust);flex:none;
  box-shadow:0 0 0 4px rgba(181,97,62,.2);
}

.auth-form{margin-top:2rem;display:flex;flex-direction:column;gap:1.1rem}
.auth-field{display:flex;flex-direction:column;gap:.5rem}
.auth-label{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(230,228,221,.5);
}
.auth-field input{
  width:100%;
  background:rgba(20,24,27,.55);
  border:1px solid rgba(230,228,221,.12);
  color:var(--cream);
  padding:.95rem 1rem;border-radius:10px;
  font:inherit;font-size:1rem;
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.auth-field input::placeholder{color:rgba(230,228,221,.3)}
.auth-field input:focus{
  outline:none;
  border-color:var(--citron);
  background:rgba(20,24,27,.75);
  box-shadow:0 0 0 4px rgba(218,255,62,.12);
}

.auth-submit{
  margin-top:.6rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:1rem 1.6rem;border-radius:999px;border:1px solid transparent;
  background:var(--citron);color:var(--ink);
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  transition:all .25s;
}
.auth-submit:hover{background:var(--citron-soft);transform:translateY(-1px)}
.auth-submit--link{background:transparent;color:var(--cream);border-color:rgba(230,228,221,.25);margin-top:1.5rem;align-self:flex-start}
.auth-submit--link:hover{border-color:var(--citron);color:var(--citron)}

.auth-help{
  margin-top:1.6rem;font-size:.85rem;color:rgba(230,228,221,.5);
}
.auth-help a{color:var(--citron);border-bottom:1px solid rgba(218,255,62,.3)}
.auth-help a:hover{border-bottom-color:var(--citron)}

.auth-side{padding:1rem 0;color:rgba(230,228,221,.7)}
@media(max-width:880px){.auth-side{display:none}}
.auth-side-meta{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(230,228,221,.4);margin-bottom:2rem;
}
.auth-quote{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.6rem,2.4vw,2.2rem);line-height:1.15;letter-spacing:-.02em;
  color:var(--cream);
}
.auth-quote em{font-style:italic;background:var(--citron);color:var(--ink);padding:0 .08em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.auth-quote footer{
  margin-top:1.2rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(230,228,221,.45);
}
.auth-side-list{list-style:none;margin-top:2.5rem;display:flex;flex-direction:column;gap:.9rem;font-size:.92rem}
.auth-side-list li{display:flex;align-items:center;gap:.8rem}
.auth-dot{width:6px;height:6px;border-radius:50%;background:var(--citron);flex:none;box-shadow:0 0 0 4px rgba(218,255,62,.12)}

.auth-foot{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem clamp(1.25rem,4vw,3rem);
  font-family:var(--mono);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(230,228,221,.35);
}

/* error page */
.err-shell{grid-template-columns:1fr;justify-items:start;max-width:760px}
.err-card{width:100%}
.err-code em{font-size:1.2em;display:inline-block;padding:0 .12em}

/* =============================================================================
   DASHBOARD — sfondo chiaro (paper), coerente con il sito
   ========================================================================== */

body.dash{
  background:var(--cream);
  color:var(--ink);
  min-height:100vh;
  display:flex;flex-direction:column;
}

.dash-nav{
  position:sticky;top:0;z-index:50;
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem clamp(1.25rem,4vw,3rem);
  background:rgba(20,24,27,.94);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(230,228,221,.08);
  color:var(--cream);
}
.dash-logo{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--serif);font-size:1.1rem;color:var(--cream);
}
.dash-mark{width:22px;height:22px;background:var(--citron);border-radius:50%;position:relative;overflow:hidden}
.dash-mark::after{content:"";position:absolute;inset:5px;background:var(--ink);border-radius:50%}
.dash-logo-sep{color:rgba(230,228,221,.3)}
.dash-logo-tag{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(230,228,221,.6);
}

.dash-nav-right{display:flex;align-items:center;gap:1.3rem}
.dash-who{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}
.dash-who-label{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(230,228,221,.45);
}
.dash-who strong{font-weight:500;font-size:.92rem;color:var(--cream)}
@media(max-width:640px){.dash-who{display:none}}

.dash-logout-form{margin:0}
.dash-logout{
  background:transparent;color:var(--cream);
  border:1px solid rgba(230,228,221,.25);
  padding:.55rem 1rem;border-radius:999px;
  font-size:.82rem;font-weight:500;letter-spacing:.01em;
  transition:all .2s;
}
.dash-logout:hover{border-color:var(--citron);color:var(--citron)}

.dash-main{
  flex:1;
  max-width:1180px;width:100%;
  margin:0 auto;
  padding:clamp(2rem,5vw,4.5rem) clamp(1.25rem,4vw,3rem);
}

.dash-hero{margin-bottom:clamp(3rem,5vw,4.5rem)}
.dash-kicker{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--ink);display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.4rem;
}
.dash-kicker::before{content:"";width:24px;height:2px;background:var(--citron)}
.dash-kicker.dim{color:rgba(20,24,27,.45)}

.dash-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(2.4rem,6vw,4.4rem);line-height:.98;letter-spacing:-.035em;
}
.dash-title em{font-style:italic;background:var(--citron);color:var(--ink);padding:0 .08em;font-weight:300;box-decoration-break:clone;-webkit-box-decoration-break:clone}

.dash-lede{
  margin-top:1.4rem;font-size:1.08rem;color:rgba(20,24,27,.7);max-width:60ch;line-height:1.6;
}

.dash-section{margin-bottom:clamp(2.5rem,4vw,4rem)}
.dash-section-h{margin-bottom:1.6rem}
.dash-section-h h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.6rem,2.5vw,2.2rem);line-height:1.1;letter-spacing:-.02em;
  margin-top:.6rem;
}

.dash-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}

.dash-item{}
.dash-item-link{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:1.2rem;
  padding:1.1rem 1.3rem;
  background:var(--paper);
  border:1px solid var(--line-light);
  border-radius:14px;
  transition:all .2s;
}
.dash-item-link:hover{
  border-color:var(--ink);
  background:#FBF9F2;
  transform:translateX(2px);
}

.dash-item-thumb{
  width:52px;height:52px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg, #FAF8F1 0%, var(--cream) 100%);
  border:1px solid var(--line-light);
  border-radius:12px;
  position:relative;
  overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.dash-item-thumb::after{
  content:"";position:absolute;top:0;left:12px;right:12px;height:2px;
  background:var(--citron);border-radius:0 0 2px 2px;opacity:.9;
}
.dash-item-thumb svg{display:block;width:30px;height:30px}
.dash-item-link:hover .dash-item-thumb{
  border-color:rgba(20,24,27,.25);
  box-shadow:0 4px 14px rgba(20,24,27,.06);
}
.dash-item-thumb--page::after{background:var(--citron)}
.dash-item-thumb--pdf::after{background:#B5613E;opacity:.75}
.dash-item-thumb--sheet::after{background:#2A3236;opacity:.5}
.dash-item-thumb--slides::after{background:#C8612C;opacity:.7}
.dash-item-thumb--archive::after{background:var(--gravel);opacity:.6}

.dash-item-main{display:flex;flex-direction:column;gap:.25rem;min-width:0}
.dash-item-name{
  font-family:var(--serif);font-weight:400;font-size:1.15rem;line-height:1.2;
  color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.dash-item-meta{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.05em;
  color:rgba(20,24,27,.5);
}
.dash-item-arrow{
  font-size:1.2rem;color:rgba(20,24,27,.4);transition:transform .2s, color .2s;
}
.dash-item-link:hover .dash-item-arrow{color:var(--ink);transform:translateX(4px)}

.dash-empty{
  padding:2rem 1.5rem;
  background:var(--paper);
  border:1px dashed var(--line-mid);
  border-radius:14px;
  color:var(--ink);
  text-align:center;
}
.dash-empty .dim{color:rgba(20,24,27,.5);font-size:.92rem;margin-top:.4rem}

.dash-foot{
  background:var(--ink);color:rgba(230,228,221,.4);
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem clamp(1.25rem,4vw,3rem);
  font-family:var(--mono);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
}
@media(max-width:640px){
  .dash-foot{flex-direction:column;gap:.5rem;text-align:center}
}

.dash-manage-link{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--citron);border:1px solid rgba(218,255,62,.35);padding:.5rem .9rem;border-radius:999px;
  transition:all .2s;
}
.dash-manage-link:hover{background:rgba(218,255,62,.12)}

/* =============================================================================
   GESTIONE (pannello admin frontend)
   ========================================================================== */

.manage-nav{display:flex;gap:.35rem;flex-wrap:wrap}
.manage-nav-link{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(230,228,221,.55);padding:.45rem .75rem;border-radius:999px;transition:all .2s;
}
.manage-nav-link:hover,.manage-nav-link.is-active{color:var(--citron);background:rgba(218,255,62,.08)}
@media(max-width:900px){.manage-nav{display:none}}

.manage-messages{max-width:1180px;margin:0 auto;padding:1rem clamp(1.25rem,4vw,3rem) 0}
.manage-msg{
  padding:.85rem 1rem;border-radius:10px;font-size:.92rem;margin-bottom:.5rem;
  background:var(--paper);border:1px solid var(--line-light);
}
.manage-msg--success{border-color:rgba(20,24,27,.2);background:#F0FCE0}
.manage-msg--error{border-color:rgba(181,97,62,.35);background:#FFF5F0;color:var(--rust)}

.manage-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}
.manage-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.manage-card{
  display:flex;flex-direction:column;gap:.6rem;padding:1.6rem;
  background:var(--paper);border:1px solid var(--line-light);border-radius:16px;transition:all .2s;
}
.manage-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.manage-card-num{font-family:var(--serif);font-size:3rem;line-height:1;color:var(--ink)}
.manage-card-title{font-family:var(--serif);font-size:1.4rem;font-weight:400}
.manage-card-desc{color:rgba(20,24,27,.65);font-size:.95rem;flex:1}
.manage-card-cta{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gravel)}

.btn-manage{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--cream);border:1px solid var(--ink);
  padding:.7rem 1.2rem;border-radius:999px;font-size:.85rem;font-weight:500;transition:all .2s;
}
.btn-manage:hover{background:var(--ink2);border-color:var(--citron);color:var(--citron)}
.btn-manage--line{background:transparent;color:var(--ink)}
.btn-manage--line:hover{background:var(--paper)}

.manage-table{list-style:none;display:flex;flex-direction:column;gap:.35rem}
.manage-table-row{
  display:grid;grid-template-columns:1.4fr .9fr .7fr .7fr auto;gap:1rem;align-items:center;
  padding:1rem 1.2rem;background:var(--paper);border:1px solid var(--line-light);border-radius:12px;
}
.manage-table--docs .manage-table-row{grid-template-columns:1.6fr .9fr .5fr .7fr auto}
.manage-table-head{
  background:transparent;border:none;padding:.5rem 1.2rem;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gravel);
}
.manage-sub{display:block;font-size:.72rem;color:var(--gravel);margin-top:.2rem}
.mono{font-family:var(--mono);font-size:.78rem}
.manage-tag{font-family:var(--mono);font-size:.65rem;color:var(--rust);font-style:normal}
.manage-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.manage-actions a{font-size:.85rem;text-decoration:underline;text-underline-offset:3px}
.link-danger{background:none;border:none;padding:0;color:var(--rust);font-size:.85rem;text-decoration:underline;cursor:pointer}
@media(max-width:800px){
  .manage-table-row{grid-template-columns:1fr;gap:.35rem}
  .manage-table-head{display:none}
}

.manage-form{
  max-width:640px;display:flex;flex-direction:column;gap:1.2rem;
  background:var(--paper);border:1px solid var(--line-light);border-radius:16px;padding:1.6rem;
}
.manage-field{display:flex;flex-direction:column;gap:.4rem}
.manage-field--check{flex-direction:row;align-items:center;gap:.65rem}
.manage-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gravel)}
.manage-input{
  width:100%;padding:.75rem .9rem;border:1px solid var(--line-mid);border-radius:10px;
  background:#FBF9F2;font:inherit;color:var(--ink);
}
.manage-input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(218,255,62,.35)}
.manage-hint{font-size:.82rem;color:rgba(20,24,27,.55)}
.manage-error{font-size:.82rem;color:var(--rust)}
.manage-alert{padding:.85rem 1rem;border-radius:10px;background:#FFF5F0;color:var(--rust);border:1px solid rgba(181,97,62,.25)}
.manage-form-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}
.manage-folder-info{
  display:flex;flex-direction:column;gap:.35rem;padding:.9rem 1rem;
  background:#FBF9F2;border:1px dashed var(--line-mid);border-radius:10px;
}
.manage-folder-info code{font-size:.85rem;color:var(--ink)}
.manage-assets{margin-top:.5rem;padding-top:1rem;border-top:1px dashed var(--line-mid)}
.manage-asset-list{list-style:none;margin-top:.6rem;display:flex;flex-direction:column;gap:.5rem}
.manage-asset-list li{display:flex;justify-content:space-between;align-items:center;gap:1rem}
