/* ============================================================
   Jam Catalogo - stile ispirato a jamonita.it
   Palette: ocra/rosso scuro come prosciutto + crema
   ============================================================ */

:root{
  --bg:           #faf6f0;
  --card:         #ffffff;
  --border:       #ebe2d3;
  --text:         #2b211c;
  --muted:        #76675d;
  --primary:      #8b1c1c;   /* rosso prosciutto */
  --primary-dark: #6e1414;
  --accent:       #c8821a;   /* ocra */
  --accent-dark:  #a26713;
  --ok:           #2f7d3a;
  --warn:         #b9750a;
  --danger:       #a52121;
  --shadow:       0 2px 6px rgba(43,33,28,.06), 0 12px 32px rgba(43,33,28,.05);
  --radius:       12px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark);text-decoration:underline}

.container{max-width:1120px;margin:0 auto;padding:0 24px}
.container.narrow{max-width:540px}

/* ---------- Header ---------- */
.site-header{
  background:#fff;
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.brand{
  display:flex;align-items:center;gap:12px;
  color:var(--text);text-decoration:none;font-weight:700;
}
.brand:hover{text-decoration:none;color:var(--primary)}
.brand-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:8px;
  background:var(--primary);color:#fff;font-weight:800;
  letter-spacing:.5px;font-size:14px;
}
.brand-logo{height:44px;width:auto;display:block}
.brand-name{font-size:18px;letter-spacing:.3px}
.site-nav{display:flex;align-items:center;gap:8px}
.site-nav a{
  color:var(--text);padding:8px 14px;border-radius:6px;
  font-size:14px;font-weight:500;
}
.site-nav a:hover{background:#f1eadd;text-decoration:none}
.site-nav a.nav-cta{
  background:var(--primary);color:#fff;
}
.site-nav a.nav-cta:hover{background:var(--primary-dark)}

/* ---------- Main / sections ---------- */
.site-main{min-height:calc(100vh - 72px - 80px)}
.auth-hero{
  background:linear-gradient(180deg,#fff 0%,#f6efe2 100%);
  border-bottom:1px solid var(--border);
  padding:56px 0 40px;
}
.auth-hero h1{margin:0 0 10px;font-size:34px;letter-spacing:-.2px}
.auth-hero .hero-sub{margin:0;color:var(--muted);font-size:16px;max-width:680px}
.auth-section{padding:40px 0 64px}

/* hero homepage */
.hero{padding:64px 0;background:#fff;border-bottom:1px solid var(--border)}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}
.hero h1{font-size:42px;line-height:1.1;margin:0 0 16px}
.hero .hero-sub{color:var(--muted);font-size:18px;max-width:520px}
.hero-cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.hero-art{display:flex;justify-content:center}
.hero-card{
  width:220px;height:280px;border-radius:14px;background:var(--primary);
  color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;
  box-shadow:var(--shadow);transform:rotate(-4deg);
}
.hero-card span{font-size:56px;font-weight:800;letter-spacing:2px}
.hero-card small{font-size:14px;opacity:.85;letter-spacing:1px;margin-top:6px}

.features{padding:48px 0;background:var(--bg)}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.feature h3{margin:8px 0 6px;font-size:18px}
.feature p{margin:0;color:var(--muted)}
.feature-ico{
  width:36px;height:36px;border-radius:8px;background:var(--accent);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;
}

/* ---------- Cards & forms ---------- */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);
}
.card.no-pad{padding:0;overflow:hidden}
.card h2{margin:0 0 16px;font-size:20px}
.form-card .form-row{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.form-card.no-card{box-shadow:none;border:0;padding:0;background:transparent}
.form-row label{font-weight:600;font-size:14px;color:#3a2e26}
.form-row .req{color:var(--primary)}
.form-row input[type=text],
.form-row input[type=email],
.form-row input[type=tel],
.form-row input[type=password],
.form-row input[type=file]{
  width:100%;padding:12px 14px;font-size:15px;
  border:1px solid #d8cdb8;border-radius:8px;background:#fff;
  transition:border-color .15s, box-shadow .15s;
}
.form-row input:focus{
  outline:0;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(139,28,28,.12);
}
.hint{color:var(--muted);font-size:12px}
.form-actions{margin-top:8px}
.form-foot{margin-top:18px;text-align:center;color:var(--muted);font-size:14px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:12px 22px;border-radius:8px;border:0;
  font-weight:600;font-size:15px;cursor:pointer;
  transition:background .15s, transform .05s;text-decoration:none;
  line-height:1;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff}
.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:#f1eadd;color:var(--text)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#8a1a1a;color:#fff}
.btn-block{display:block;width:100%}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:6px}

/* ---------- Alerts ---------- */
.alert{padding:14px 16px;border-radius:10px;margin-bottom:18px;border:1px solid transparent}
.alert ul{margin:6px 0 0 18px;padding:0}
.alert p{margin:4px 0}
.alert-success{background:#e9f5ec;color:#1f5a29;border-color:#bfe0c8}
.alert-error{background:#fbeaea;color:#7c1d1d;border-color:#ecc2c2}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:14px;background:#fff}
.data-table th,.data-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}
.data-table thead th{background:#f6efe2;font-weight:700;color:#3a2e26;font-size:13px;text-transform:uppercase;letter-spacing:.4px}
.data-table tr:last-child td{border-bottom:0}
.data-table .actions{white-space:nowrap}
.data-table .actions .inline{display:inline-block;margin-right:4px}
.data-table .actions .inline:last-child{margin-right:0}
.data-table td.empty{text-align:center;color:var(--muted);padding:28px}

/* ---------- Badges & chips ---------- */
.badge{
  display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;
  background:#eee;color:#444;
}
.badge.ok{background:#dff1e2;color:#1f5a29}
.badge.warn{background:#fbeed1;color:#825206}
.badge.admin{background:#e8e2f4;color:#3a2c75}

.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.chip{
  padding:6px 12px;border-radius:999px;background:#fff;border:1px solid var(--border);
  color:var(--text);font-size:13px;font-weight:500;
}
.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.chip:hover{text-decoration:none}
.back-link{margin-left:auto;color:var(--muted);font-size:13px}

/* ---------- Admin stats ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow);
}
.stat-card .stat-num{font-size:32px;font-weight:800;color:var(--text)}
.stat-card span:last-child{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.6px}
.stat-card.warn{border-top:3px solid var(--warn)}
.stat-card.ok{border-top:3px solid var(--ok)}
.admin-nav{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Catalog grid ---------- */
.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.catalog-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);
}
.catalog-icon{
  background:var(--primary);color:#fff;height:120px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;font-weight:800;letter-spacing:2px;
}
.catalog-body{padding:18px}
.catalog-body h3{margin:0 0 6px;font-size:17px}
.catalog-meta{color:var(--muted);font-size:13px;margin:0 0 14px}
.catalog-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{
  background:#2b211c;color:#e6dccf;padding:24px 0;margin-top:48px;
}
.site-footer p{margin:0;text-align:center;font-size:13px;opacity:.8}

/* ---------- Responsive ---------- */
@media (max-width:780px){
  .hero-grid{grid-template-columns:1fr}
  .hero h1{font-size:32px}
  .features-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .site-nav a{padding:8px 10px;font-size:13px}
}
