/* GESTIAMO360 - Offline Website (v1)
   Edit / brand: search for "CONFIG:" in app.js
*/
:root{
  --bg:#0b1220;
  --bg2:#0f1b35;
  --card:#121c33;
  --muted:#98a2b3;
  --text:#e7ebf3;
  --white:#ffffff;
  --accent:#2f7cff;
  --accent2:#22c55e;
  --warning:#f59e0b;
  --danger:#ef4444;
  --border:rgba(255,255,255,.10);
  --shadow: 0 16px 40px rgba(0,0,0,.35);
  --radius:18px;
  --max:1180px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

html,body{height:100%;}
body{
  margin:0;
  font-family:var(--sans);
  background: radial-gradient(1200px 600px at 20% 0%, rgba(47,124,255,.18), transparent 60%),
              radial-gradient(900px 600px at 80% 10%, rgba(34,197,94,.12), transparent 55%),
              linear-gradient(180deg, var(--bg), #070b14 70%);
  color:var(--text);
  line-height:1.55;
}

body.light{
  --bg:#f7f9fc;
  --bg2:#eef2ff;
  --card:#ffffff;
  --muted:#566375;
  --text:#111827;
  --border:rgba(17,24,39,.12);
  --shadow:0 16px 40px rgba(17,24,39,.10);
  background: radial-gradient(1200px 600px at 15% 0%, rgba(47,124,255,.14), transparent 60%),
              radial-gradient(900px 600px at 85% 10%, rgba(34,197,94,.10), transparent 55%),
              linear-gradient(180deg, #f7f9fc, #f2f5ff 65%);
}

a{color:inherit; text-decoration:none;}
a:hover{opacity:.92; text-decoration:underline;}
img{max-width:100%; height:auto; display:block;}
.container{max-width:var(--max); margin:0 auto; padding:0 20px;}
.muted{color:var(--muted);}
.small{font-size:.92rem;}
.tiny{font-size:.82rem;}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  backdrop-filter: blur(8px);
}
body.light .badge{background:rgba(17,24,39,.03);}

.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(5,8,15,.55);
  border-bottom:1px solid var(--border);
}
body.light .nav{background:rgba(247,249,252,.75);}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:800; letter-spacing:.3px;
}
.brand svg{width:34px; height:34px;}
.brand span{font-size:1.04rem;}
.nav-links{display:flex; align-items:center; gap:18px; flex-wrap:wrap;}
.nav-links a{opacity:.9;}
.nav-links a.active{opacity:1; text-decoration:underline;}
.nav-cta{display:flex; align-items:center; gap:10px;}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);
  box-shadow:none;
  cursor:pointer;
  transition: transform .08s ease, background .15s ease;
  user-select:none;
}
.btn:hover{background:rgba(255,255,255,.10); text-decoration:none;}
.btn:active{transform:translateY(1px);}
.btn.primary{
  background: linear-gradient(135deg, rgba(47,124,255,.98), rgba(47,124,255,.72));
  border-color: rgba(47,124,255,.55);
}
.btn.primary:hover{background: linear-gradient(135deg, rgba(47,124,255,1), rgba(47,124,255,.78));}
.btn.success{
  background: linear-gradient(135deg, rgba(34,197,94,.98), rgba(34,197,94,.72));
  border-color: rgba(34,197,94,.55);
}
.btn.ghost{background:transparent;}
.icon-btn{padding:10px 12px; border-radius:14px; min-width:44px;}
.kbd{
  font-family:var(--mono);
  font-size:.78rem;
  padding:4px 8px;
  border-radius:10px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
}
body.light .kbd{background:rgba(17,24,39,.04);}

.mobile-toggle{display:none;}

.hero{
  padding:54px 0 26px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:26px;
  align-items:stretch;
}
.card{
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
body.light .card{background:rgba(255,255,255,.75);}
.hero-card{padding:30px;}
.hero h1{
  font-size:2.3rem;
  line-height:1.12;
  margin:10px 0 12px;
  letter-spacing:-.5px;
}
.hero p{margin:0 0 18px; color:var(--muted); font-size:1.04rem;}
.hero-actions{display:flex; flex-wrap:wrap; gap:10px; margin-top:16px;}
.hero-aside{
  padding:18px;
  display:flex; flex-direction:column; gap:12px;
}
.aside-row{
  display:flex; align-items:center; gap:12px;
  padding:14px;
  border-radius:16px;
  border:1px dashed var(--border);
  background:rgba(255,255,255,.04);
}
body.light .aside-row{background:rgba(17,24,39,.02);}
.aside-row svg{width:26px; height:26px;}
.aside-row strong{display:block;}
.aside-row span{display:block; color:var(--muted); font-size:.92rem;}

.section{padding:26px 0;}
.section h2{
  margin:0 0 10px;
  font-size:1.55rem;
  letter-spacing:-.3px;
}
.section .lead{margin:0 0 18px; color:var(--muted);}

.grid-4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.grid-3{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;}
.grid-2{display:grid; grid-template-columns:repeat(2, 1fr); gap:14px;}
@media (max-width:1020px){
  .hero-grid{grid-template-columns:1fr; }
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
}
@media (max-width:620px){
  .grid-4{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .mobile-toggle{display:inline-flex;}
}

.product-card{padding:18px; position:relative; overflow:hidden;}
.product-card .top{
  display:flex; align-items:center; gap:12px;
}
.product-card .top svg{width:44px; height:44px;}
.product-card h3{margin:10px 0 8px; font-size:1.1rem;}
.product-card ul{margin:0; padding-left:18px; color:var(--muted);}
.product-card li{margin:6px 0;}
.product-card .actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px;}
.product-card .ribbon{
  position:absolute; top:14px; right:14px;
  font-size:.78rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.08);
}

.table-wrap{overflow:auto; border-radius:16px; border:1px solid var(--border);}
table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:740px;
}
th,td{
  padding:12px 12px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
th{
  text-align:left;
  font-size:.9rem;
  letter-spacing:.2px;
  color:var(--muted);
  background:rgba(255,255,255,.05);
  position:sticky; top:0;
}
body.light th{background:rgba(17,24,39,.03);}
tr:last-child td{border-bottom:none;}
td.center{text-align:center;}
td.nowrap{white-space:nowrap;}
td strong{font-weight:700;}
.pill{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:28px; height:26px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  font-weight:700;
}
.check{color:var(--accent2); font-weight:900;}
.nocheck{color:var(--muted);}

.pricing{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
@media (max-width:1020px){ .pricing{grid-template-columns:1fr;} }
.price-card{padding:18px;}
.price-card h3{margin:4px 0 8px;}
.price{
  font-size:2rem;
  font-weight:900;
  letter-spacing:-.5px;
}
.price small{font-size:1rem; font-weight:600; color:var(--muted);}
hr.sep{border:none; border-top:1px solid var(--border); margin:16px 0;}
.list{margin:0; padding-left:18px; color:var(--muted);}
.list li{margin:7px 0;}

.callout{
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(47,124,255,.35);
  background: radial-gradient(900px 500px at 0% 0%, rgba(47,124,255,.18), transparent 60%),
              rgba(255,255,255,.05);
}
body.light .callout{background: radial-gradient(900px 500px at 0% 0%, rgba(47,124,255,.12), transparent 60%),
                    rgba(255,255,255,.65);}
.callout h3{margin:0 0 6px;}
.callout p{margin:0 0 12px; color:var(--muted);}

.footer{
  padding:26px 0 36px;
  border-top:1px solid var(--border);
  margin-top:26px;
}
.footer-grid{
  display:grid; grid-template-columns: 1.1fr .9fr; gap:14px;
}
@media (max-width:1020px){.footer-grid{grid-template-columns:1fr;}}
.footer a{opacity:.9;}
.footer a:hover{opacity:1;}
.footer .links{display:flex; gap:14px; flex-wrap:wrap; color:var(--muted);}

.notice{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--muted);
}

.toolbar{
  position:fixed;
  left:16px;
  bottom:16px;
  z-index:99;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:10px;
  border-radius:16px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}
body.light .toolbar{background:rgba(255,255,255,.72);}
.toolbar .btn{padding:10px 12px; border-radius:14px;}

.editing [data-editable="true"]{
  outline:2px dashed rgba(47,124,255,.55);
  outline-offset: 6px;
  border-radius:12px;
}

/* Modal */
.modal-backdrop{
  position:fixed; inset:0; z-index:120;
  background:rgba(0,0,0,.55);
  display:none;
}
.modal-backdrop.show{display:block;}
.modal{
  position:fixed; left:50%; top:50%; transform:translate(-50%,-50%);
  z-index:130;
  width:min(720px, calc(100vw - 30px));
  display:none;
}
.modal.show{display:block;}
.modal .card{padding:18px;}
.form{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.form label{display:block; font-size:.88rem; color:var(--muted); margin-bottom:6px;}
.form input, .form textarea, .form select{
  width:100%;
  box-sizing:border-box;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-family:var(--sans);
}
body.light .form input, body.light .form textarea, body.light .form select{
  background:rgba(17,24,39,.02);
}
.form textarea{min-height:120px; resize:vertical; grid-column:1/-1;}
.form .full{grid-column:1/-1;}
.form .actions{grid-column:1/-1; display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end;}
.hint{font-size:.82rem; color:var(--muted);}

/* Print */
@media print{
  .nav, .toolbar, .modal, .modal-backdrop, .no-print {display:none !important;}
  body{background:#fff !important; color:#000 !important;}
  .card{box-shadow:none !important; background:#fff !important;}
  a{text-decoration:none;}
  .table-wrap{overflow:visible;}
  table{min-width:auto;}
  tr, td, th{page-break-inside:avoid;}
  .section{padding:10px 0;}
}

/* Table actions */
.table-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
  margin: 8px 0 10px;
}


/* --- Immagini esterne (Pexels) --- */
.aside-photo{
  width:100%;
  height:190px;
  object-fit:cover;
  border-radius:18px;
  border:1px solid var(--border);
  box-shadow:0 10px 30px rgba(0,0,0,.10);
  display:block;
}
.card-photo{
  width:100%;
  height:170px;
  object-fit:cover;
  border-radius:16px;
  border:1px solid var(--border);
  margin:12px 0 14px;
  display:block;
}
.banner{
  margin:18px 0 22px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 14px 40px rgba(0,0,0,.10);
}
.banner img{
  width:100%;
  height:280px;
  object-fit:cover;
  display:block;
}
@media (max-width:720px){
  .aside-photo{height:170px;}
  .card-photo{height:150px;}
  .banner img{height:210px;}
}


/* --- PUBLIC VERSION: editing tools removed --- */
.toolbar{display:none !important;}
.editing [data-editable="true"]{outline:none !important;}
[contenteditable="true"]{outline:none !important;}
