*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#F7F6F2;--bg2:#FFFFFF;--bg3:#F0EEE8;
  --accent:#2B5BA8;--accent2:#4A8FD4;--green:#3A7D56;
  --text:#1A1A2E;--muted:#6B6B7E;--border:#E2DED6;
  --shadow:0 2px 16px rgba(0,0,0,0.07);
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;overflow-x:hidden;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;padding:0 2.5rem;height:68px;display:flex;align-items:center;justify-content:space-between;
  background:rgba(247,246,242,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;}
nav ul{list-style:none;display:flex;gap:2rem;}
nav ul a{text-decoration:none;color:var(--muted);font-size:0.82rem;letter-spacing:0.04em;transition:color 0.2s;}
nav ul a:hover{color:var(--text);}
.nav-cta{background:var(--accent)!important;color:#fff!important;padding:0.4rem 1.1rem;border-radius:4px;transition:opacity 0.2s!important;}
.nav-cta:hover{opacity:0.88;}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:8rem 2rem 5rem;position:relative;
  background:linear-gradient(160deg,#fff 0%,#EEF3FB 50%,#F7F6F2 100%);}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(to bottom,transparent,var(--bg));pointer-events:none;}
.hero-inner{max-width:780px;position:relative;z-index:1;}
.hero-logo{height:100px;margin:0 auto 2rem;display:block;animation:fadeUp 0.7s ease both;}
.hero-badge{display:inline-block;font-family:'DM Mono',monospace;font-size:0.67rem;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--accent);background:rgba(43,91,168,0.08);
  border:1px solid rgba(43,91,168,0.2);padding:0.35rem 1rem;border-radius:3px;
  margin-bottom:1.8rem;animation:fadeUp 0.7s 0.1s ease both;}
.hero h1{font-family:'Lora',serif;font-size:clamp(2.4rem,6vw,4.2rem);font-weight:600;
  line-height:1.1;margin-bottom:1.4rem;color:var(--text);animation:fadeUp 0.7s 0.15s ease both;}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:400;}
.hero p{font-size:1rem;color:var(--muted);line-height:1.8;max-width:540px;margin:0 auto 2.5rem;animation:fadeUp 0.7s 0.22s ease both;}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fadeUp 0.7s 0.3s ease both;}
.btn-primary{background:var(--accent);color:#fff;border:none;padding:0.85rem 2rem;font-size:0.88rem;font-weight:500;cursor:pointer;border-radius:4px;text-decoration:none;transition:background 0.2s,transform 0.15s;display:inline-block;}
.btn-primary:hover{background:#1e4a8a;transform:translateY(-2px);}
.btn-ghost{background:#fff;color:var(--text);border:1.5px solid var(--border);padding:0.85rem 2rem;font-size:0.88rem;cursor:pointer;border-radius:4px;text-decoration:none;transition:border-color 0.2s,transform 0.15s;display:inline-block;}
.btn-ghost:hover{border-color:var(--accent);transform:translateY(-2px);}

/* STATS */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stat-item{padding:2rem;text-align:center;border-right:1px solid var(--border);opacity:0;transform:translateY(14px);transition:all 0.5s ease;}
.stat-item:last-child{border-right:none;}
.stat-item.vis{opacity:1;transform:translateY(0);}
.stat-num{font-family:'DM Mono',monospace;font-size:1.9rem;font-weight:500;color:var(--accent);display:block;}
.stat-label{font-size:0.76rem;color:var(--muted);margin-top:0.25rem;}

/* WRAP */
.wrap{max-width:1100px;margin:0 auto;padding:5rem 2.5rem;}
.stag{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);margin-bottom:0.6rem;opacity:0;transform:translateY(12px);transition:all 0.5s ease;}
.stit{font-family:'Lora',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:600;line-height:1.18;margin-bottom:1rem;opacity:0;transform:translateY(12px);transition:all 0.5s 0.07s ease;}
.ssub{color:var(--muted);font-size:0.9rem;line-height:1.8;max-width:520px;margin-bottom:3rem;opacity:0;transform:translateY(12px);transition:all 0.5s 0.13s ease;}
.stag.vis,.stit.vis,.ssub.vis{opacity:1;transform:translateY(0);}

/* FEATURES with tilt */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;}
.feat-card{
  padding:2rem;background:#fff;border:1.5px solid var(--border);border-radius:10px;
  opacity:0;transform:translateY(16px);transition:opacity 0.5s ease,transform 0.5s ease,box-shadow 0.3s ease;
  position:relative;overflow:hidden;will-change:transform;
  cursor:default;
}
.feat-card::before{
  content:'';position:absolute;inset:0;border-radius:10px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(43,91,168,0.07) 0%, transparent 65%);
  opacity:0;transition:opacity 0.3s;pointer-events:none;
}
.feat-card:hover::before{opacity:1;}
.feat-card.vis{opacity:1;transform:translateY(0);}
.feat-num{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.15em;color:var(--accent);margin-bottom:0.8rem;opacity:0.5;}
.feat-card h3{font-size:0.92rem;font-weight:500;margin-bottom:0.4rem;color:var(--text);}
.feat-card p{font-size:0.79rem;color:var(--muted);line-height:1.65;}

/* SCREENSHOTS */
.screenshots{padding:5rem 0;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.screenshots .wrap-title{max-width:1100px;margin:0 auto;padding:0 2.5rem 2.5rem;}
.gallery-track{display:flex;gap:1.5rem;padding:0 2.5rem 1rem;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;cursor:grab;}
.gallery-track::-webkit-scrollbar{height:4px;}
.gallery-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.gallery-track.grabbing{cursor:grabbing;}
.ss-card{
  flex:0 0 460px;background:#fff;border:1.5px solid var(--border);border-radius:10px;
  overflow:hidden;box-shadow:var(--shadow);opacity:0;transform:translateY(16px);
  transition:opacity 0.5s ease, transform 0.5s ease, box-shadow 0.4s ease;
  will-change:transform;
}
.ss-card.vis{opacity:1;transform:translateY(0);}
.ss-card img{width:100%;display:block;border-bottom:1px solid var(--border);}
.ss-label{padding:0.85rem 1.1rem;display:flex;align-items:center;gap:0.6rem;background:#FAFAF8;}
.ss-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;}
.ss-name{font-family:'DM Mono',monospace;font-size:0.7rem;color:var(--muted);}

/* VERTICALIZZAZIONI */
.vert-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}
@media(max-width:640px){.vert-grid{grid-template-columns:1fr;}}
.vert-card{
  background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:2.5rem;
  box-shadow:var(--shadow);opacity:0;transform:translateY(18px);
  transition:opacity 0.6s ease,transform 0.6s ease,box-shadow 0.3s ease;
  will-change:transform;cursor:default;
}
.vert-card.vis{opacity:1;transform:translateY(0);}
.vert-card:nth-child(2){transition-delay:0.1s;}
.vert-tag{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;padding:0.28rem 0.7rem;border-radius:3px;display:inline-block;margin-bottom:1.2rem;}
.vert-tag.t{background:rgba(43,91,168,0.1);color:var(--accent);}
.vert-tag.w{background:rgba(58,125,86,0.1);color:var(--green);}
.vert-card h3{font-family:'Lora',serif;font-size:1.45rem;margin-bottom:0.7rem;font-weight:600;}
.vert-card p{font-size:0.82rem;color:var(--muted);line-height:1.75;}
.vert-list{list-style:none;margin-top:1.2rem;}
.vert-list li{font-size:0.8rem;color:var(--muted);padding:0.42rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0.6rem;}
.vert-list li::before{content:'›';font-size:1rem;}
.vert-card:first-child .vert-list li::before{color:var(--accent);}
.vert-card:last-child .vert-list li::before{color:var(--green);}

/* CHANGELOG */
.cl-bg{background:var(--bg3);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.cl-wrap{position:relative;padding-left:2rem;}
.cl-wrap::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:1px;background:var(--border);}
.cl-entry{position:relative;margin-bottom:2.5rem;opacity:0;transform:translateX(-12px);transition:all 0.5s ease;}
.cl-entry.vis{opacity:1;transform:translateX(0);}
.cl-entry::before{content:'';position:absolute;left:-1.7rem;top:0.42rem;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--bg3);}
.cl-ver{font-family:'DM Mono',monospace;font-size:0.67rem;letter-spacing:0.1em;color:var(--accent);margin-bottom:0.2rem;}
.cl-date{font-size:0.72rem;color:var(--muted);margin-bottom:0.5rem;}
.cl-tit{font-size:0.95rem;font-weight:500;margin-bottom:0.3rem;}
.cl-desc{font-size:0.79rem;color:var(--muted);line-height:1.65;}
.cl-tags{display:flex;gap:0.4rem;flex-wrap:wrap;margin-top:0.5rem;}
.cl-tag{font-size:0.6rem;padding:0.18rem 0.5rem;border-radius:3px;font-family:'DM Mono',monospace;}
.cl-tag.new{background:rgba(43,91,168,0.1);color:var(--accent);}
.cl-tag.fix{background:rgba(200,140,50,0.1);color:#9A6A10;}
.cl-tag.imp{background:rgba(58,125,86,0.1);color:var(--green);}

/* CONTACT */
.contact-box{background:linear-gradient(135deg,#EEF3FB 0%,#F7F6F2 100%);border:1.5px solid rgba(43,91,168,0.18);border-radius:10px;padding:3.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem;opacity:0;transform:translateY(16px);transition:all 0.6s ease;}
.contact-box.vis{opacity:1;transform:translateY(0);}
.contact-box h2{font-family:'Lora',serif;font-size:1.9rem;font-weight:600;max-width:380px;line-height:1.25;}
.contact-box h2 em{font-style:italic;color:var(--accent);font-weight:400;}
.contact-box p{font-size:0.82rem;color:var(--muted);margin-top:0.5rem;}
.mail-link{font-family:'DM Mono',monospace;font-size:0.83rem;color:var(--accent);text-decoration:none;background:#fff;border:1.5px solid rgba(43,91,168,0.25);padding:0.75rem 1.3rem;border-radius:4px;transition:border-color 0.2s,box-shadow 0.2s;display:inline-block;}
.mail-link:hover{border-color:var(--accent);box-shadow:0 2px 12px rgba(43,91,168,0.12);}

/* FOOTER */
footer{background:#fff;border-top:1px solid var(--border);padding:2rem 2.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
footer p{font-size:0.74rem;color:var(--muted);}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:999;display:none;align-items:center;justify-content:center;padding:2rem;cursor:zoom-out;}
.lightbox.open{display:flex;}
.lightbox img{max-width:90vw;max-height:88vh;border-radius:6px;box-shadow:0 8px 60px rgba(0,0,0,0.6);object-fit:contain;animation:lbIn 0.25s ease both;}
.lb-caption{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);font-family:'DM Mono',monospace;font-size:0.72rem;letter-spacing:0.1em;color:rgba(255,255,255,0.6);pointer-events:none;white-space:nowrap;}
.lb-close{position:fixed;top:1.5rem;right:1.5rem;background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;opacity:0.7;transition:opacity 0.2s;line-height:1;}
.lb-close:hover{opacity:1;}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;font-size:1.4rem;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s;}
.lb-prev{left:1.5rem;}
.lb-next{right:1.5rem;}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,0.22);}
.ss-card img{cursor:zoom-in;}
@keyframes lbIn{from{opacity:0;transform:scale(0.94);}to{opacity:1;transform:scale(1);}}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all 0.3s ease;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;
  background:rgba(247,246,242,0.98);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);z-index:99;
  flex-direction:column;
  transform:translateY(-8px);opacity:0;
  transition:transform 0.25s ease,opacity 0.25s ease;
  pointer-events:none;}
.mobile-menu.open{display:flex;transform:translateY(0);opacity:1;pointer-events:all;}
.mobile-menu a{text-decoration:none;color:var(--text);font-size:0.95rem;
  padding:0.9rem 2rem;border-bottom:1px solid var(--border);transition:background 0.15s;}
.mobile-menu a:last-child{border-bottom:none;}
.mobile-menu a:active{background:var(--bg3);}
.mobile-menu .mob-cta{background:var(--accent);color:#fff;margin:0.8rem 1.5rem;
  border-radius:4px;text-align:center;border-bottom:none!important;padding:0.75rem 1.5rem;}

/* RESPONSIVE */
@media(max-width:768px){
  .hamburger{display:flex;}
  nav ul{display:none;}
  nav{padding:0 1.5rem;}
  .wrap{padding:4rem 1.5rem;}
  .hero{padding:7rem 1.5rem 4rem;}
  .hero-logo{height:75px;}
  .stats-bar{grid-template-columns:1fr 1fr;}
  .stat-item{padding:1.4rem 1rem;}
  .stat-num{font-size:1.5rem;}
  .feat-grid{grid-template-columns:1fr;}
  .screenshots .wrap-title{padding:0 1.5rem 2rem;}
  .gallery-track{padding:0 1.5rem 1rem;}
  .ss-card{flex:0 0 85vw;}
  .vert-grid{grid-template-columns:1fr;}
  .vert-card{padding:1.8rem;}
  .acc-header{padding:1.1rem 1.2rem;}
  .acc-left{gap:0.6rem;}
  .acc-sub{display:none;}
  .acc-body-inner{padding:0.5rem 1.2rem 1.5rem;}
  .road-item{flex-wrap:wrap;gap:0.6rem;}
  .road-status{min-width:unset;}
  .road-ver{margin-left:0;}
  .vote-board{grid-template-columns:1fr;}
  .survey-opt-text{min-width:unset;max-width:100%;font-size:0.8rem;}
  .survey-opt{flex-wrap:wrap;gap:0.5rem;}
  .survey-bar-wrap{min-width:100px;}
  .suggest-grid{grid-template-columns:1fr;}
  .contact-box{padding:2rem 1.5rem;flex-direction:column;}
  .contact-box h2{font-size:1.5rem;}
  footer{padding:1.5rem;flex-direction:column;align-items:flex-start;gap:0.6rem;}
}

/* ACCORDION */
.accordion { display:flex; flex-direction:column; gap:0.75rem; }
.acc-item { background:#fff; border:1.5px solid var(--border); border-radius:10px; overflow:hidden; transition:box-shadow 0.3s; }
.acc-item.open { box-shadow:0 4px 24px rgba(0,0,0,0.09); }
.acc-header { width:100%; background:none; border:none; padding:1.4rem 1.6rem; display:flex; align-items:center; justify-content:space-between; cursor:pointer; text-align:left; transition:background 0.2s; }
.acc-header:hover { background:#F5F8FF; }
.acc-left { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.acc-tag { font-family:'DM Mono',monospace; font-size:0.6rem; letter-spacing:0.16em; text-transform:uppercase; padding:0.25rem 0.65rem; border-radius:3px; }
.acc-tag.base { background:rgba(107,107,126,0.1); color:var(--muted); }
.acc-tag.trasporti { background:rgba(43,91,168,0.1); color:var(--accent); }
.acc-tag.magazzino { background:rgba(58,125,86,0.1); color:var(--green); }
.acc-title { font-family:'Lora',serif; font-size:1.05rem; font-weight:600; color:var(--text); }
.acc-sub { font-size:0.78rem; color:var(--muted); }
.acc-arrow { font-size:1.4rem; color:var(--muted); transition:transform 0.3s ease; line-height:1; flex-shrink:0; }
.acc-item.open .acc-arrow { transform:rotate(90deg); }
.acc-body { max-height:0; overflow:hidden; transition:max-height 0.45s cubic-bezier(0.4,0,0.2,1); }
.acc-body .cl-entry { opacity:1; transform:none; transition:none; }
.acc-body-inner { padding:0.5rem 2rem 2rem 2rem; }

/* COMMUNITY SECTION */
.community-bg { background:var(--bg); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

/* ROADMAP */
.roadmap { display:flex; flex-direction:column; gap:0.6rem; margin-bottom:3.5rem; }
.road-item { display:flex; align-items:center; gap:1.2rem; background:#fff; border:1.5px solid var(--border); border-radius:10px; padding:1.1rem 1.4rem; opacity:0; transform:translateX(-16px); transition:all 0.5s ease; }
.road-item.vis { opacity:1; transform:translateX(0); }
.road-status { flex-shrink:0; display:flex; align-items:center; gap:0.5rem; min-width:130px; }
.road-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.road-dot.done { background:#3A7D56; }
.road-dot.wip { background:var(--accent); box-shadow:0 0 0 3px rgba(43,91,168,0.15); animation:pulse 1.8s infinite; }
.road-dot.soon { background:#C8A050; }
.road-dot.idea { background:var(--border); border:2px solid var(--muted); }
.road-label { font-family:'DM Mono',monospace; font-size:0.65rem; letter-spacing:0.08em; }
.road-label.done { color:#3A7D56; }
.road-label.wip { color:var(--accent); }
.road-label.soon { color:#9A6A10; }
.road-label.idea { color:var(--muted); }
.road-text { font-size:0.88rem; color:var(--text); font-weight:500; flex:1; }
.road-ver { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--muted); margin-left:auto; flex-shrink:0; }
.road-tag { font-family:'DM Mono',monospace; font-size:0.58rem; letter-spacing:0.1em; text-transform:uppercase; padding:0.18rem 0.5rem; border-radius:3px; flex-shrink:0; }
.road-tag.t { background:rgba(43,91,168,0.1); color:var(--accent); }
.road-tag.m { background:rgba(58,125,86,0.1); color:#3A7D56; }
.road-tag.b { background:rgba(107,107,126,0.1); color:var(--muted); }
@keyframes pulse { 0%,100%{box-shadow:0 0 0 3px rgba(43,91,168,0.15);} 50%{box-shadow:0 0 0 6px rgba(43,91,168,0.08);} }

/* DIVIDER */
.section-divider { border:none; border-top:1px solid var(--border); margin:3rem 0; }



/* SUGGEST FORM */
.suggest-box { background:#fff; border:1.5px solid var(--border); border-radius:10px; padding:2rem 2rem; opacity:0; transform:translateY(14px); transition:all 0.6s ease; }
.suggest-box.vis { opacity:1; transform:translateY(0); }
.suggest-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
@media(max-width:600px){ .suggest-grid{ grid-template-columns:1fr; } }
.form-group { display:flex; flex-direction:column; gap:0.4rem; }
.form-group label { font-size:0.75rem; font-weight:500; color:var(--muted); letter-spacing:0.04em; }
.form-group input, .form-group select, .form-group textarea {
  font-family:'Inter',sans-serif; font-size:0.85rem; color:var(--text);
  background:var(--bg); border:1.5px solid var(--border); border-radius:6px;
  padding:0.6rem 0.85rem; outline:none; transition:border-color 0.2s, box-shadow 0.2s;
  width:100%;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--accent); box-shadow:0 0 0 3px rgba(43,91,168,0.08);
}
.form-group textarea { resize:vertical; min-height:90px; }
.form-full { grid-column:1/-1; }
.btn-send { background:var(--accent); color:#fff; border:none; padding:0.8rem 2rem; font-family:'Inter',sans-serif; font-size:0.88rem; font-weight:500; border-radius:6px; cursor:pointer; transition:background 0.2s, transform 0.15s; }
.btn-send:hover { background:#1e4a8a; transform:translateY(-1px); }
.form-note { font-size:0.73rem; color:var(--muted); margin-top:0.8rem; }
.form-success { display:none; text-align:center; padding:2rem; }
.form-success .success-icon { font-size:2rem; margin-bottom:0.8rem; }
.form-success h4 { font-family:'Lora',serif; font-size:1.2rem; margin-bottom:0.4rem; }
.form-success p { font-size:0.83rem; color:var(--muted); }

/* BACHECA NOTIZIE */
.news-board { display:flex; flex-direction:column; gap:0.75rem; margin-bottom:3.5rem; }
.news-item { background:#fff; border:1.5px solid var(--border); border-radius:10px; padding:1.4rem 1.6rem; transition:box-shadow 0.25s ease; }
.news-item:hover { box-shadow:0 4px 20px rgba(0,0,0,0.08); }
.news-title { font-size:0.95rem; font-weight:500; color:var(--text); margin-bottom:0.7rem; display:flex; align-items:center; gap:0.6rem; }
.news-title::before { content:''; display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.news-details { list-style:none; padding:0; display:flex; flex-direction:column; gap:0.35rem; }
.news-details li { font-size:0.82rem; color:var(--muted); line-height:1.65; padding-left:1.2rem; position:relative; }
.news-details li::before { content:'›'; position:absolute; left:0; color:var(--accent); font-size:0.9rem; }

/* ANON */
.anon-label { display:flex; align-items:flex-start; gap:0.6rem; cursor:pointer; font-size:0.82rem; color:var(--muted); }
.anon-label input[type=checkbox] { margin-top:2px; accent-color:var(--accent); width:15px; height:15px; flex-shrink:0; }
.anon-text { line-height:1.55; }
.anon-banner { background:rgba(43,91,168,0.07); border:1px solid rgba(43,91,168,0.2); border-radius:6px; padding:0.65rem 1rem; font-size:0.8rem; color:var(--accent); margin-bottom:1rem; display:flex; align-items:center; gap:0.5rem; }

/* ROAD PostgreSQL highlight */
.road-item .road-pg { font-size:0.7rem; color:var(--accent); font-family:'DM Mono',monospace; background:rgba(43,91,168,0.08); padding:0.15rem 0.45rem; border-radius:3px; margin-left:0.4rem; }
/* ── DARK MODE ── */
[data-theme="dark"] {
  --bg:#0F1117;
  --bg2:#161B27;
  --bg3:#1A2030;
  --accent:#5B9CF6;
  --accent2:#7EC8E3;
  --green:#4CAF7D;
  --text:#E8EAF2;
  --muted:#8B92B3;
  --border:rgba(255,255,255,0.09);
  --shadow:0 2px 16px rgba(0,0,0,0.35);
}
[data-theme="dark"] body { background:var(--bg); color:var(--text); }
[data-theme="dark"] nav { background:rgba(15,17,23,0.92); }
[data-theme="dark"] .hero { background:linear-gradient(160deg,#131929 0%,#0F1117 100%); }
[data-theme="dark"] .hero::after { background:linear-gradient(to bottom,transparent,var(--bg)); }
[data-theme="dark"] .stats-bar,
[data-theme="dark"] .feat-card,
[data-theme="dark"] .ss-card,
[data-theme="dark"] .vert-card,
[data-theme="dark"] .acc-item,
[data-theme="dark"] .news-item,
[data-theme="dark"] .suggest-box,
[data-theme="dark"] .survey-box,
[data-theme="dark"] .contact-box,
[data-theme="dark"] footer { background:var(--bg2); }
[data-theme="dark"] .feat-card:hover { background:var(--bg3); }
[data-theme="dark"] .acc-header:hover { background:var(--bg3); }
[data-theme="dark"] .screenshots { background:var(--bg2); }
[data-theme="dark"] .cl-bg { background:var(--bg3); }
[data-theme="dark"] .cl-entry::before { border-color:var(--bg3); }
[data-theme="dark"] .contact-box { background:linear-gradient(135deg,#131929 0%,#0F1117 100%); }
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea { background:var(--bg3); color:var(--text); border-color:var(--border); }
[data-theme="dark"] .btn-ghost { background:var(--bg2); border-color:var(--border); color:var(--text); }
[data-theme="dark"] .mail-link { background:var(--bg2); }
[data-theme="dark"] .ss-label { background:var(--bg3); }
[data-theme="dark"] .mobile-menu { background:rgba(15,17,23,0.97); }
[data-theme="dark"] .mobile-menu a { border-color:var(--border); color:var(--text); }
[data-theme="dark"] .hero-badge { background:rgba(91,156,246,0.1); border-color:rgba(91,156,246,0.25); }
[data-theme="dark"] .anon-banner { background:rgba(91,156,246,0.1); border-color:rgba(91,156,246,0.2); }

/* Toggle button */
#themeToggle {
  background:none;
  border:1.5px solid var(--border);
  color:var(--text);
  width:34px;height:34px;
  border-radius:50%;
  cursor:pointer;
  font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:border-color 0.2s, background 0.2s;
  flex-shrink:0;
}
#themeToggle:hover { border-color:var(--accent); background:var(--bg3); }

/* Smooth transition on theme switch */
body, nav, .hero, .feat-card, .ss-card, .vert-card, .acc-item,
.news-item, .suggest-box, .contact-box, footer, .stats-bar,
.form-group input, .form-group select, .form-group textarea {
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
