
:root{
  --green:#214f43;
  --green2:#2b6b57;
  --bg:#f6f8f6;
  --border:#e1e7ed;
  --muted:#6f7b8f;
  --text:#142033;
  --accent:#eaf3ee;
  --shadow:0 18px 48px rgba(16,32,51,.08);
  --soft:0 10px 26px rgba(16,32,51,.055);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
.hidden{display:none!important}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 15% 18%,rgba(33,79,67,.14),transparent 28%),linear-gradient(135deg,#eef7f2,#fff 44%,#f6f8f6)}
.login-card{width:min(1120px,100%);min-height:590px;background:#fff;border:1px solid var(--border);border-radius:30px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.15fr .85fr;overflow:hidden}
.login-brand{padding:46px;border-right:1px solid var(--border)}
.login-logo{width:390px;max-width:100%;height:185px;border:1px solid var(--border);border-radius:26px;display:flex;align-items:center;justify-content:center;padding:18px;box-shadow:var(--soft);background:#fff}
.login-logo img,.side-logo img,.head-logo img,.hero-logo img{width:100%;height:100%;object-fit:contain;display:block}
.kicker{text-transform:uppercase;letter-spacing:.18em;font-weight:900;color:var(--muted);margin:34px 0 8px}
.login-brand h1{font-size:clamp(42px,5vw,62px);line-height:.98;letter-spacing:-.06em;margin:0;color:var(--green)}
.subtitle{font-size:17px;line-height:1.6;color:var(--muted);max-width:520px}
.pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:38px}
.pills span{background:var(--accent);border:1px solid var(--border);color:var(--green);font-weight:900;border-radius:999px;padding:10px 16px}
.login-form{padding:46px;display:flex;flex-direction:column;justify-content:center}
.login-form h2{font-size:34px;color:var(--green);margin:0 0 10px}
.login-form p{color:var(--muted);font-size:17px;line-height:1.55;margin:0 0 28px}
label{display:block;font-weight:900;color:#526071;margin:16px 0 8px}
input,textarea{width:100%;border:1px solid var(--border);border-radius:16px;padding:14px 16px;font:inherit;background:#fff;color:var(--text);outline:none}
input{height:52px}
input:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(33,79,67,.12)}
button,.btn{border:none;border-radius:16px;padding:14px 20px;background:var(--green);color:#fff;font-weight:900;font:inherit;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 12px 24px rgba(33,79,67,.18)}
button:hover,.btn:hover{filter:brightness(1.03)}
.btn.secondary{background:#fff;color:var(--green);border:1px solid var(--border);box-shadow:var(--soft)}
.btn.ghost{background:#f8fbfa;color:var(--green);border:1px solid var(--border);box-shadow:none}
.btn.danger{background:#b42318}
.error{display:none;background:#fff1f2;color:#9f1239;border:1px solid #fecdd3;border-radius:14px;padding:12px 14px;font-weight:800;margin-bottom:12px}
.error.show{display:block}
.app{min-height:100vh}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:250px;background:#fff;border-right:1px solid var(--border);box-shadow:10px 0 34px rgba(16,32,51,.045);padding:24px 18px;display:flex;flex-direction:column;gap:16px;z-index:20}
.side-logo{width:182px;height:122px;margin:0 auto 8px;border:1px solid var(--border);border-radius:24px;display:grid;place-items:center;padding:10px;box-shadow:var(--soft);background:#fff}
.side-title{text-align:center;font-size:19px;font-weight:900;color:var(--green)}
.side-subtitle{text-align:center;font-size:13px;font-weight:800;color:var(--muted);margin-top:-10px}
.toggle{width:42px;height:42px;border:1px solid var(--border);background:#fff;color:var(--green);box-shadow:var(--soft);margin:0 auto;padding:0}
nav{display:grid;gap:7px;margin-top:8px}
nav a{height:48px;border-radius:15px;display:flex;align-items:center;gap:12px;padding:0 14px;font-weight:900;color:#1d2939;text-decoration:none}
nav a.active,nav a:hover{background:var(--accent);color:var(--green)}
.side-info{margin-top:auto;border-radius:20px;background:#f8fbfa;border:1px solid var(--border);padding:14px}
.side-info b{display:block;color:var(--green);font-size:13px}
.side-info small{display:block;color:var(--muted);line-height:1.45;margin-top:5px}
.content{padding-left:250px;min-height:100vh}
.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.96);border-bottom:1px solid var(--border);box-shadow:0 12px 34px rgba(16,32,51,.055);backdrop-filter:blur(12px);padding:18px 26px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.head-brand{display:flex;align-items:center;gap:16px}
.head-logo{width:174px;height:92px;border:1px solid var(--border);border-radius:20px;background:#fff;padding:10px;box-shadow:var(--soft)}
.head-brand h2{margin:0;color:var(--green);font-size:28px}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.hero{margin:28px;display:flex;align-items:center;gap:28px;background:#fff;border:1px solid var(--border);border-radius:26px;box-shadow:var(--shadow);padding:34px}
.hero-logo{width:180px;height:102px;border:1px solid var(--border);border-radius:24px;background:#fff;padding:10px;box-shadow:var(--soft);flex:0 0 auto}
.hero h1{margin:0 0 10px;color:var(--green);font-size:clamp(32px,4vw,48px);letter-spacing:-.05em}
.hero p{color:var(--muted);font-size:17px;margin:0 0 20px}
.toolbar{margin:0 28px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.toolbar input{max-width:560px;background:#fff;box-shadow:var(--soft)}
.counter{font-weight:900;color:var(--green)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin:0 28px 40px}
.recipe-card{background:#fff;border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:20px;cursor:pointer;transition:transform .18s ease}
.recipe-card:hover{transform:translateY(-2px)}
.badge{display:inline-flex;background:var(--accent);color:var(--green);font-weight:900;border-radius:999px;padding:7px 10px;font-size:12px;margin-bottom:14px}
.recipe-card h3{margin:0 0 8px;font-size:22px;color:var(--text)}
.recipe-card p{margin:0;color:var(--muted);line-height:1.45}
.meta{margin-top:14px;color:var(--muted);font-size:13px;font-weight:800}
.empty{grid-column:1/-1;background:#fff;border:1px dashed var(--border);border-radius:22px;padding:34px;text-align:center;color:var(--muted)}
dialog{border:none;border-radius:26px;width:min(860px,94vw);box-shadow:0 24px 80px rgba(16,32,51,.22);padding:0}
dialog::backdrop{background:rgba(15,23,42,.45)}
.dialog-form{padding:26px;max-height:88vh;overflow:auto}
.dialog-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:18px}
.dialog-head h2{margin:0;color:var(--green);font-size:28px}
.icon-btn{width:42px;height:42px;padding:0;border-radius:14px;background:#fff;color:var(--green);border:1px solid var(--border);box-shadow:none;font-size:24px}
.dialog-actions{display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;margin-top:22px}
body.menu-collapsed .sidebar{width:84px;padding-left:12px;padding-right:12px}
body.menu-collapsed .side-logo{width:54px;height:54px;border-radius:18px;padding:4px}
body.menu-collapsed .side-title,body.menu-collapsed .side-subtitle,body.menu-collapsed .side-info,body.menu-collapsed nav span{display:none}
body.menu-collapsed .content{padding-left:84px}
@media(max-width:980px){.login-card{grid-template-columns:1fr}.login-brand{border-right:0;border-bottom:1px solid var(--border)}.sidebar{display:none}.content{padding-left:0}.topbar,.hero,.toolbar{margin-left:16px;margin-right:16px}.grid{margin-left:16px;margin-right:16px}.hero{display:block}.hero-logo{margin-bottom:18px}}
@media(max-width:640px){.login-logo{width:260px;height:124px}.login-brand,.login-form{padding:28px}.topbar{display:block}.actions{margin-top:14px}.head-logo{width:140px;height:76px}.hero h1{font-size:32px}.dialog-actions{grid-template-columns:1fr}.dialog-actions span{display:none}}


/* dashboard-unica-finale-260626
   MODIFICA RICHIESTA: unica area dashboard, non più due sezioni ridondanti. */
.topbar,
.hero {
  display: none !important;
}

.dashboard-unica {
  margin: 28px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 28px;
  box-shadow: var(--shadow);
  padding: 32px 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
}

.dashboard-unica-brand {
  display: flex;
  align-items: center;
  gap: 28px;
  min-width: 0;
}

.dashboard-unica-logo {
  width: 230px;
  height: 128px;
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  padding: 12px;
  display: grid;
  place-items: center;
  box-shadow: var(--soft);
  flex: 0 0 auto;
}

.dashboard-unica-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.dashboard-unica-copy {
  min-width: 0;
}

.dashboard-unica-kicker {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.dashboard-unica h1 {
  margin: 0 0 10px;
  color: var(--green);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.03;
  letter-spacing: -.055em;
}

.dashboard-unica p:not(.dashboard-unica-kicker) {
  margin: 0 0 20px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.45;
}

.dashboard-unica-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  flex: 0 0 auto;
}

.toolbar {
  margin-top: 0;
}

@media(max-width:1100px) {
  .dashboard-unica {
    display: block;
  }
  .dashboard-unica-actions {
    justify-content: flex-start;
    margin-top: 22px;
  }
}

@media(max-width:700px) {
  .dashboard-unica {
    margin: 16px;
    padding: 24px;
  }
  .dashboard-unica-brand {
    display: block;
  }
  .dashboard-unica-logo {
    width: 220px;
    max-width: 100%;
    height: 120px;
    margin-bottom: 18px;
  }
  .dashboard-unica h1 {
    font-size: 32px;
  }
}

/* DASHBOARD-UNICA-FINALE-OK */
