:root{
  --neon-green:#21ff97;
  --neon-purple:#a246ff;
  --black:#0a0a0a;
  --dark:#0f0f16;
  --text:#e7ffe7;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--black);color:var(--text);font-family:'Rajdhani',system-ui,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial}

.bg{
  position:fixed;inset:0;z-index:-1;
  background: 
    linear-gradient(135deg, rgba(0,50,0,0.8), rgba(0,30,0,0.9)),
    url('/images/main-background.jpg?v=2');
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  background-repeat: no-repeat;
}

/* Neon background for protected area */
body.protected .bg {
  background-image: 
    radial-gradient(1200px 600px at 10% 10%, rgba(33,255,151,.15), transparent),
    radial-gradient(900px 500px at 90% 20%, rgba(162,70,255,.12), transparent),
    radial-gradient(800px 800px at 50% 100%, rgba(33,255,151,.08), transparent),
    linear-gradient(180deg, #050507, #0b0b12);
  filter: saturate(120%);
}

.container{max-width:1100px;margin:0 auto;padding:48px 20px;position:relative;z-index:1}
.logo{font-family:'Orbitron', monospace;font-size:44px;letter-spacing:2px;text-shadow:0 0 12px rgba(33,255,151,.5), 0 0 20px rgba(0,0,0,.8);text-align:center}
.tag{opacity:.9;margin-top:-6px;margin-bottom:24px;text-shadow:0 0 8px rgba(0,0,0,.6);text-align:center}

.actions{display:flex;gap:16px;flex-wrap:wrap;margin:24px 0;background:rgba(0,0,0,.6);padding:20px;border-radius:16px;backdrop-filter:blur(8px);justify-content:center;border:1px solid rgba(33,255,151,.2);position:relative;z-index:1}
.btn{background:linear-gradient(135deg,var(--neon-green),var(--neon-purple));color:#000;padding:12px 18px;border:none;border-radius:12px;font-weight:700;text-decoration:none;cursor:pointer;box-shadow:0 0 20px rgba(33,255,151,.35), 0 0 28px rgba(162,70,255,.25);transition:transform .15s ease, filter .2s;position:relative;overflow:hidden;z-index:2}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}
.btn:hover{transform:translateY(-2px);filter:brightness(1.1)}
.btn:hover::before{left:100%}
.btn.small{padding:10px 14px;font-size:14px}
.btn.confirm{margin-top:10px}

.link{background:none;border:none;color:var(--neon-green);cursor:pointer;text-shadow:0 0 8px rgba(33,255,151,.6);font-weight:600;padding:8px 12px;border-radius:6px;transition:all 0.2s ease}
.link:hover{background:rgba(33,255,151,.1);text-shadow:0 0 12px rgba(33,255,151,.8)}

.force-logout {
  color: #ff6b6b !important;
  border: 1px solid rgba(255,107,107,.3) !important;
}

.force-logout:hover {
  text-shadow: 0 0 8px rgba(255,107,107,.8) !important;
  background: rgba(255,107,107,.1) !important;
}

.protected{margin-top:32px}
.admin-area{margin-top:32px;background:rgba(0,0,0,.8);border:1px solid rgba(162,70,255,.3);border-radius:16px;padding:24px;backdrop-filter:blur(8px);box-shadow:0 4px 20px rgba(0,0,0,.5)}
.hidden{display:none}

.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin:16px 0}
.card{background:rgba(0,0,0,.7);border:1px solid rgba(33,255,151,.25);border-radius:14px;padding:16px;backdrop-filter:blur(8px);box-shadow:0 4px 20px rgba(0,0,0,.5)}
.card h4{margin:8px 0 10px 0}
.price{opacity:.9;margin-bottom:10px}
.product-img{width:100%;height:140px;border-radius:10px;background:linear-gradient(135deg, rgba(33,255,151,.25), rgba(162,70,255,.2));display:flex;align-items:center;justify-content:center;font-size:48px}
.product-img.hidden{display:none}
.qty{display:flex;align-items:center;gap:8px}
.qty input{width:80px;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0d0d14;color:var(--text)}

.cart{background:rgba(255,255,255,.03);border:1px dashed rgba(162,70,255,.35);border-radius:14px;padding:16px;min-height:56px}
.cart-line{display:flex;justify-content:space-between;margin:6px 0}
.total{margin-top:10px;font-weight:700}

.form{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.form input{flex:1 1 220px;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0d0d14;color:var(--text)}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);z-index:9999}
.modal-content{position:relative;width:min(420px,92%);background:rgba(0,0,0,.9);border:1px solid rgba(162,70,255,.35);border-radius:16px;padding:22px;box-shadow:0 0 40px rgba(162,70,255,.2);backdrop-filter:blur(12px)}
.close{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text);font-size:18px;cursor:pointer}

.controls{display:flex;justify-content:flex-end;margin-top:-10px;background:rgba(0,0,0,.6);padding:8px 12px;border-radius:8px;backdrop-filter:blur(4px);border:1px solid rgba(162,70,255,.2)}

@media (prefers-reduced-motion:no-preference){
  .logo{animation:glow 3s ease-in-out infinite}
}

@keyframes glow{
  0%{text-shadow:0 0 6px rgba(33,255,151,.3)}
  50%{text-shadow:0 0 18px rgba(162,70,255,.45), 0 0 30px rgba(33,255,151,.35)}
  100%{text-shadow:0 0 6px rgba(33,255,151,.3)}
}

/* Responsive Design */
@media (max-width: 768px) {
  .container{padding:24px 16px}
  .logo{font-size:32px;letter-spacing:1px}
  .tag{font-size:16px;margin-bottom:20px}
  .actions{flex-direction:column;gap:12px;padding:16px}
  .btn{padding:14px 20px;font-size:16px;width:100%;text-align:center;min-height:48px;touch-action:manipulation;-webkit-tap-highlight-color:rgba(33,255,151,.3)}
  .btn.small{padding:12px 16px;font-size:14px}
  
  .products{grid-template-columns:1fr;gap:16px}
  .card{padding:12px}
  .product-img{height:120px}
  
  .form{flex-direction:column;gap:8px}
  .form input{flex:none;width:100%}
  
  .modal-content{width:95%;padding:16px}
}

@media (min-width: 769px) {
  .actions{flex-direction:row;justify-content:center}
  .btn{min-width:140px}
  
  /* Ensure background image is visible on desktop */
  .bg {
    background: 
      linear-gradient(135deg, rgba(0,50,0,0.8), rgba(0,30,0,0.9)),
      url('/images/main-background.jpg?v=2');
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    filter: blur(2px);
  }
}

@media (max-width: 480px) {
  .logo{font-size:28px}
  .tag{font-size:14px}
  .btn{padding:12px 16px;font-size:14px}
  .container{padding:16px 12px}
}

/* Ensure hidden wins over modal display */
.modal.hidden{display:none}

/* Ensure modals are always on top */
#loginModal, #adminModal {
  z-index: 99999 !important;
}

#loginModal .modal-content, #adminModal .modal-content {
  z-index: 100000 !important;
}

/* Status messages */
.status-message {
  text-align: center;
  padding: 2rem;
  border-radius: 8px;
  margin: 2rem 0;
}

.status-message.pending {
  background: linear-gradient(135deg, #ffa726, #ff9800);
  color: white;
}

.status-message.rejected {
  background: linear-gradient(135deg, #f44336, #d32f2f);
  color: white;
}

.status-message h2 {
  margin-bottom: 1rem;
  font-size: 1.5rem;
}

.status-message p {
  margin-bottom: 1rem;
  line-height: 1.6;
}

/* User management styles */
.users-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  margin: 16px 0;
}

.user-card {
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(33,255,151,.25);
  border-radius: 14px;
  padding: 16px;
  backdrop-filter: blur(4px);
}

.user-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.user-actions .btn {
  flex: 1;
  padding: 8px 12px;
  font-size: 12px;
}

.approve-btn {
  background: linear-gradient(135deg, #4caf50, #2e7d32) !important;
}

.reject-btn {
  background: linear-gradient(135deg, #f44336, #c62828) !important;
}

.test-approve-btn {
  background: linear-gradient(135deg, #ff9800, #f57c00) !important;
}

/* User stats */
.user-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin: 20px 0;
}

.stat-card {
  background: rgba(0,0,0,.7);
  border: 1px solid rgba(33,255,151,.25);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  backdrop-filter: blur(8px);
}

.stat-card h3 {
  margin: 0 0 8px 0;
  font-size: 14px;
  opacity: 0.8;
}

.stat-value {
  font-size: 24px;
  font-weight: bold;
  color: var(--neon-green);
  text-shadow: 0 0 8px rgba(33,255,151,.5);
}

/* Order history */
.order-history {
  display: grid;
  gap: 12px;
  margin: 16px 0;
}

.order-card {
  background: rgba(0,0,0,.7);
  border: 1px solid rgba(162,70,255,.25);
  border-radius: 12px;
  padding: 16px;
  backdrop-filter: blur(8px);
}

.order-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.order-id {
  font-weight: bold;
  color: var(--neon-green);
}

.order-status {
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: bold;
}

.order-status.approved {
  background: rgba(76,175,80,.2);
  color: #4caf50;
}

.order-status.rejected {
  background: rgba(244,67,54,.2);
  color: #f44336;
}

.order-status.pending {
  background: rgba(255,152,0,.2);
  color: #ff9800;
}

.order-details {
  font-size: 14px;
  line-height: 1.4;
}

.order-items {
  margin-bottom: 8px;
  opacity: 0.9;
}

.order-total {
  font-weight: bold;
  color: var(--neon-green);
  margin-bottom: 4px;
}

.order-points {
  color: #ffd700;
  margin-bottom: 4px;
}

.order-date {
  opacity: 0.7;
  font-size: 12px;
}

/* Special pricing highlights */
.price {
  font-size: 14px;
  line-height: 1.4;
}

.price strong {
  color: var(--neon-green);
  text-shadow: 0 0 4px rgba(33,255,151,.3);
}

/* Quantity input improvements */
.qty input[type="number"] {
  background: rgba(0,0,0,.6);
  border: 1px solid rgba(33,255,151,.3);
  color: white;
  padding: 8px;
  border-radius: 6px;
  width: 100%;
  margin-top: 8px;
}

.qty input[type="number"]:focus {
  outline: none;
  border-color: var(--neon-green);
  box-shadow: 0 0 8px rgba(33,255,151,.3);
}

/* Admin orders */
.orders-list {
  display: grid;
  gap: 16px;
  margin: 16px 0;
}

.order-card {
  background: rgba(0,0,0,.7);
  border: 1px solid rgba(162,70,255,.25);
  border-radius: 12px;
  padding: 16px;
  backdrop-filter: blur(8px);
}

.order-customer {
  margin-bottom: 12px;
  padding: 8px;
  background: rgba(33,255,151,.1);
  border-radius: 6px;
  border-left: 3px solid var(--neon-green);
}

.order-items {
  margin-bottom: 8px;
  opacity: 0.9;
}

.order-actions {
  margin-top: 12px;
  display: flex;
  gap: 8px;
}

.order-actions .btn {
  flex: 1;
}

/* Login actions */
.login-actions {
  margin-top: 16px;
  text-align: center;
}

.login-actions .btn {
  background: linear-gradient(135deg, #2196f3, #1976d2) !important;
  width: 100%;
}
/* === SFONDO GLOBALE === */
.bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('/images/sfondo-home.jpg'); /* Cambia con il tuo file */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: brightness(0.7) blur(2px);
  z-index: -1;
}

/* Se vuoi effetto leggero "vibrazione" psichedelica */
@keyframes bgMove {
  0% { background-position: 50% 50%; }
  50% { background-position: 48% 52%; }
  100% { background-position: 50% 50%; }
}
.bg {
  animation: bgMove 20s ease-in-out infinite;
}

/* === SFONDO VISIBILE SU TUTTO === */
body {
  background: transparent !important; /* toglie lo sfondo nero del body */
  color: #fff; /* testo leggibile su sfondo scuro */
  font-family: 'Rajdhani', sans-serif;
  margin: 0;
  padding: 0;
}

/* === CONTENITORI TRASPARENTI === */
.container,
section,
.modal-content {
  background: rgba(0, 0, 0, 0.3); /* leggera trasparenza, si vede lo sfondo dietro */
  border-radius: 15px;
  padding: 20px;
  backdrop-filter: blur(8px);
}

/* === TOGLIE I BOX NERI COMPLETI === */
main, .protected, .admin-area {
  background: transparent !important;
  box-shadow: none !important;
}

.bg-video {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
  filter: brightness(0.5);
}


