/* ============================================================
   Cataloghi Tama — Backoffice
   ============================================================ */
:root{
  --green:#94C11F;--green-d:#7da018;--green-l:#acd64a;
  --dark:#002D5D;--dark-2:#00244a;--dark-3:#001a35;
  --ink:#1f2d33;--muted:#6b7d84;--line:#e7ecee;--bg:#eef2f1;--white:#fff;
  --danger:#e2574c;--radius:14px;--ease:cubic-bezier(.22,1,.36,1);
  --shadow:0 14px 34px -22px rgba(0,45,93,.4);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Bottoni condivisi */
.btn-primary,.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;font-weight:600;font-size:.92rem;border-radius:10px;cursor:pointer;border:1.5px solid transparent;padding:.7rem 1.2rem;font-family:inherit;transition:.22s var(--ease)}
.btn-sm{padding:.5rem .85rem;font-size:.84rem}
.btn-primary{background:var(--green);color:#00203f;box-shadow:0 8px 18px -8px rgba(148,193,31,.7)}
.btn-primary:hover{background:var(--green-l);transform:translateY(-2px)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--dark)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-d)}
.btn-block{width:100%}
.btn-icon{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;background:#fff;border:1px solid var(--line);cursor:pointer;font-size:.95rem;color:var(--dark);transition:.2s var(--ease)}
.btn-icon:hover{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-icon-danger:hover{background:var(--danger);border-color:var(--danger)}

/* ---------- Shell ---------- */
.admin-shell{display:flex;min-height:100vh}
.admin-sidebar{width:248px;background:var(--dark);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0;transition:transform .3s var(--ease)}
.admin-brand{display:flex;align-items:center;gap:.7rem;padding:1.4rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.08)}
.admin-brand img{height:30px}
.admin-brand span{font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.admin-nav{display:flex;flex-direction:column;gap:.25rem;padding:1.2rem .8rem;flex:1}
.admin-nav a{display:flex;align-items:center;gap:.8rem;padding:.8rem 1rem;border-radius:10px;color:rgba(255,255,255,.72);font-weight:500;font-size:.95rem;transition:.2s var(--ease)}
.admin-nav a svg{width:19px;height:19px;flex-shrink:0}
.admin-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.admin-nav a.is-active{background:var(--green);color:#00203f;font-weight:600;box-shadow:0 8px 18px -8px rgba(148,193,31,.8)}
.admin-sidebar-foot{padding:1.2rem 1.4rem;border-top:1px solid rgba(255,255,255,.08)}
.admin-sidebar-link{color:rgba(255,255,255,.6);font-size:.85rem}
.admin-sidebar-link:hover{color:var(--green)}

.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}
.admin-topbar{display:flex;align-items:center;gap:1rem;padding:1.1rem 2rem;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.admin-page-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--dark);flex:1}
.admin-burger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--dark)}
.admin-user{display:flex;align-items:center;gap:.7rem}
.admin-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-d));color:#00203f;display:grid;place-items:center;font-weight:700}
.admin-username{font-weight:600;font-size:.9rem}
.logout-form{margin:0}
.admin-content{padding:2rem;flex:1}

@media (max-width:880px){
  .admin-username{display:none}
  .admin-burger{display:block}
  .admin-sidebar{position:fixed;z-index:60;transform:translateX(-100%);box-shadow:0 0 60px rgba(0,0,0,.4)}
  .admin-sidebar.open{transform:none}
}

/* ---------- Flash ---------- */
.flash{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1.2rem 2rem 0;padding:.9rem 1.2rem;border-radius:10px;font-size:.92rem;font-weight:500;animation:slideIn .4s var(--ease)}
.flash-success{background:rgba(148,193,31,.14);color:#5d7a10;border-left:3px solid var(--green)}
.flash-error{background:rgba(226,87,76,.12);color:#b53a30;border-left:3px solid var(--danger)}
.flash-close{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:.9rem}
.flash-close:hover{opacity:1}
@keyframes slideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}

/* ---------- Stat cards ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.3rem;margin-bottom:1.8rem}
.stat-card{background:#fff;border-radius:var(--radius);padding:1.5rem;display:flex;align-items:center;gap:1.1rem;box-shadow:var(--shadow);transition:transform .3s var(--ease)}
.stat-card:hover{transform:translateY(-4px)}
.stat-icon{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;font-size:1.5rem;flex-shrink:0}
.stat-icon-green{background:rgba(148,193,31,.16)}
.stat-icon-blue{background:rgba(0,45,93,.14)}
.stat-icon-amber{background:rgba(240,170,40,.18)}
.stat-icon-violet{background:rgba(120,90,200,.16)}
.stat-num{font-size:1.9rem;font-weight:800;color:var(--dark);line-height:1}
.stat-label{color:var(--muted);font-size:.88rem;margin-top:.2rem}

/* ---------- Panel ---------- */
.panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.6rem;margin-bottom:1.5rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.panel-head h2,.panel-title{font-size:1.1rem;font-weight:700;color:var(--dark);margin:0}
.panel-title{margin-bottom:1.1rem}
.panel-head-actions{display:flex;align-items:center;gap:.7rem}
.panel-empty{padding:2.5rem 1rem;text-align:center;color:var(--muted)}
.panel-empty a{color:var(--green-d);font-weight:600}

/* ---------- Table ---------- */
.data-table{width:100%;border-collapse:collapse;font-size:.92rem}
.data-table th{text-align:left;padding:.7rem .8rem;color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--line)}
.data-table td{padding:.85rem .8rem;border-bottom:1px solid var(--line);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr{transition:background .15s}
.data-table tbody tr:hover{background:#f7faf8}
.ta-right{text-align:right}
.row-link{font-weight:600;color:var(--dark)}
.row-link:hover{color:var(--green-d)}
.muted{color:var(--muted)}
.small{font-size:.82rem}
.cell-thumb img,.thumb-fallback{width:40px;height:52px;border-radius:6px;object-fit:cover}
.thumb-fallback{background:var(--dark);color:var(--green);display:grid;place-items:center;font-size:.62rem;font-weight:700;letter-spacing:.1em}
.inline{display:inline;margin:0}
.table-filter{padding:.5rem .85rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.85rem}
.table-filter:focus{outline:none;border-color:var(--green)}

.pill{display:inline-block;padding:.22rem .65rem;border-radius:50px;font-size:.76rem;font-weight:600}
.pill-on{background:rgba(148,193,31,.18);color:#5d7a10}
.pill-off{background:var(--line);color:var(--muted)}
.pill-cat{background:rgba(0,45,93,.1);color:var(--dark)}
code.slug{background:#f0f3f2;border:1px solid var(--line);padding:.12rem .45rem;border-radius:5px;font-size:.8rem;color:var(--dark)}

/* ---------- Switch ---------- */
.switch{display:inline-flex;align-items:center;width:46px;height:26px;border-radius:50px;background:var(--line);border:none;cursor:pointer;padding:3px;transition:background .25s var(--ease)}
.switch.on{background:var(--green)}
.switch-knob{width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 5px rgba(0,0,0,.2);transition:transform .25s var(--ease)}
.switch.on .switch-knob{transform:translateX(20px)}
.switch-field{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem;cursor:pointer}
.switch-field input{display:none}
.switch-field input:checked + .switch{background:var(--green)}
.switch-field input:checked + .switch .switch-knob{transform:translateX(20px)}
.switch-text{font-weight:500;font-size:.92rem}

/* ---------- Form ---------- */
.form-topbar{margin-bottom:1.2rem}
.form-grid{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;align-items:start}
.field{display:block;margin-bottom:1.2rem}
.field>span{display:block;font-weight:600;font-size:.88rem;color:var(--dark);margin-bottom:.45rem}
.field em{color:var(--danger);font-style:normal}
.field input,.field textarea,.field .select,.dropdown-menu input{
  width:100%;padding:.75rem .9rem;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;color:var(--ink);transition:border .2s,box-shadow .2s;background:#fff;
}
.field .select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23002D5D' d='M6 8 0 2l1.4-1.4L6 5.2 10.6.6 12 2z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.4rem}
.field input:focus,.field textarea:focus,.field .select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(148,193,31,.16)}
.field textarea{resize:vertical}
.field small{display:block;margin-top:.35rem;font-size:.8rem}
.form-side{display:flex;flex-direction:column;gap:1.5rem}
.form-actions{display:flex;justify-content:flex-end;gap:.8rem;margin-top:.5rem}
.check-inline{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--muted);margin-top:.8rem;cursor:pointer}

/* Dropzone */
.dropzone{position:relative;border:2px dashed var(--line);border-radius:12px;background:#fafbfa;transition:.25s var(--ease);cursor:pointer;overflow:hidden}
.dropzone:hover,.dropzone.dragover{border-color:var(--green);background:rgba(148,193,31,.06)}
.dropzone-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.dropzone-inner{padding:1.8rem 1rem;text-align:center;color:var(--muted);pointer-events:none}
.dropzone-sm .dropzone-inner{padding:1.1rem 1rem}
.dropzone-inner svg{color:var(--green);margin-bottom:.5rem}
.dropzone-text{margin:.2rem 0;color:var(--ink)}
.dropzone-hint{font-size:.8rem;margin:.2rem 0 0}
.dropzone-file{margin:.6rem 0 0;color:var(--green-d);font-weight:600;font-size:.85rem;word-break:break-all}

/* Cover preview */
.cover-preview{aspect-ratio:3/4;border-radius:10px;overflow:hidden;background:var(--dark);display:grid;place-items:center;margin-bottom:.9rem}
.cover-preview-wide{aspect-ratio:16/9}
.cover-preview img{width:100%;height:100%;object-fit:cover}
.cover-placeholder{color:rgba(255,255,255,.5);font-size:.85rem}

/* Dropdown (password) */
.dropdown{display:inline-block;position:relative}
.dropdown summary{list-style:none}
.dropdown summary::-webkit-details-marker{display:none}
.dropdown-menu{position:absolute;right:0;top:42px;z-index:10;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 18px 40px -18px rgba(0,45,93,.5);padding:.8rem;display:flex;flex-direction:column;gap:.5rem;width:220px}

/* ---------- Login ---------- */
.login-body{min-height:100vh;display:grid;place-items:center;background:var(--dark-3);position:relative;overflow:hidden;padding:2rem}
.login-bg{position:absolute;inset:0;overflow:hidden}
.login-bg .blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:lfloat 16s ease-in-out infinite}
.login-bg .blob-1{width:420px;height:420px;background:var(--green);top:-140px;right:-80px}
.login-bg .blob-2{width:360px;height:360px;background:#0a4f87;bottom:-140px;left:-80px;animation-delay:-6s}
@keyframes lfloat{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,28px)}}
.login-card{position:relative;background:rgba(0,36,74,.92);border:1px solid rgba(148,193,31,.2);backdrop-filter:blur(14px);border-radius:20px;padding:2.6rem;width:min(400px,100%);text-align:center;box-shadow:0 40px 90px -30px rgba(0,0,0,.7);animation:pop .5s var(--ease);color:#fff}
@keyframes pop{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}
.login-logo{height:40px;margin:0 auto 1.4rem}
.login-card h1{font-size:1.5rem;margin:0;color:#fff}
.login-sub{color:var(--green);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin:.3rem 0 1.6rem}
.login-form{text-align:left;margin-top:1rem}
.login-form .field>span{color:rgba(255,255,255,.8)}
.login-form input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#fff}
.login-form input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(148,193,31,.25);background:rgba(255,255,255,.1)}
.login-form .btn-primary{margin-top:.5rem}
.login-back{display:inline-block;margin-top:1.4rem;color:rgba(255,255,255,.55);font-size:.85rem}
.login-back:hover{color:var(--green)}
.login-card .flash{margin:0 0 1rem}

@media (max-width:680px){
  .form-grid{grid-template-columns:1fr}
  .admin-content{padding:1.2rem}
  .flash{margin:1rem 1.2rem 0}
  .admin-topbar{padding:1rem 1.2rem}
}
