/* Bootstrap 5 + Lucide Icons */

:root{
  --bg:#FFFFFF;
  --bg-soft:#F8F9FA;
  --surface:#F5F5F5;
  --surface-2:#EEEEEE;
  --surface-3:#E8E8E8;
  --field:#FAFAFA;
  --field-hover:#F0F0F0;
  --text:#1A1A1A;
  --text-soft:#333333;
  --muted:#6B6B6B;
  --muted-2:#999999;
  --border:rgba(0,0,0,.08);
  --border-strong:rgba(0,0,0,.14);
  --brand:#980000;           /* Argento Titanio */
  --brand-2:#7A0000;         /* Titanio scuro */
  --brand-3:#B80000;         /* Titanio chiaro */
  --brand-soft:rgba(152,0,0,.08);
  --brand-glow:rgba(152,0,0,.20);
  --accent:#980000;          /* Blu profondo sobrio */
  --success:#00A854;
  --success-soft:rgba(0,168,84,.10);
  --error:#D32F2F;
  --error-soft:rgba(211,47,47,.08);
  --radius:12px;
  --radius-lg:20px;
  
}

*{box-sizing:border-box;}
html,body{font-family:'Inter',system-ui,-apple-system,sans-serif;}
body{
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  padding:0;
  position:relative;
  overflow-x:hidden;
}

/* Glow di sfondo */
body::before{
  content:"";
  position:fixed;
  top:-20%;left:50%;transform:translateX(-50%);
  width:1200px;height:700px;
  background:
    radial-gradient(ellipse at center, rgba(152,0,0,.04) 0%, rgba(152,0,0,.02) 30%, transparent 65%);
  pointer-events:none;
  z-index:0;
  filter:blur(40px);
}
body::after{
  content:"";
  position:fixed;
  bottom:-30%;right:-10%;
  width:900px;height:600px;
  background:radial-gradient(ellipse at center, rgba(152,0,0,.03) 0%, transparent 60%);
  pointer-events:none;
  z-index:0;
  filter:blur(60px);
}

/* ===== FORZA IL COLORE BRAND SU TUTTI I COMPONENTI DANGER ===== */
.btn-danger {
    background-color: #980000 !important;
    border-color: #980000 !important;
    color: #fff !important;
}
.btn-danger:hover,
.btn-danger:focus {
    background-color: #7a0000 !important;
    border-color: #7a0000 !important;
    color: #fff !important;
}
.btn-danger:active {
    background-color: #7a0000 !important;
    border-color: #7a0000 !important;
}
.btn-outline-danger {
    color: #980000 !important;
    border-color: #980000 !important;
}
.btn-outline-danger:hover {
    background-color: #980000 !important;
    color: #fff !important;
}

.text-danger {
    color: #980000 !important;
}
.bg-danger {
    background-color: #980000;
}
.border-danger {
    border-color: #980000 !important;
}

.alert-danger {
    background-color: rgba(152,0,0,0.1) !important;
    border-color: #980000 !important;
    color: #980000 !important;
}

/* Opzionale: anche per i link */
a.text-danger:hover {
    color: #7a0000 !important;
}

/* ===== ICONE LUCIDE ===== */
.icon {
    display: inline-block;
    width: 24px;
    height: 24px;
}

.icon.sm {
    width: 16px;
    height: 16px;
}

.icon.md {
    width: 20px;
    height: 20px;
}

.icon.lg {
    width: 32px;
    height: 32px;
}


.qpos-shell{max-width:1140px;margin:0 auto;position:relative;z-index:1;padding:0 16px 60px;}

/* ============================================================
   NAVBAR / TOPBAR - Bootstrap 5 puro, Dark Titanium
   ============================================================ */

.qpos-topbar{
  background:var(--surface-2) !important;  /* ← più scuro di #EEEEEE */
  padding:16px 24px;
  margin:16px auto 24px;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  max-width:1108px;
}

.qpos-topbar .container-fluid{
  max-width:1140px;
  padding:0;
}

.qpos-brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.qpos-brand {
  display: flex !important;
  align-items: center;
  gap: 11px;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -.02em;
  color: var(--text) !important;
  padding: 0 !important;
  margin: 0 !important;
}

.qpos-brand:hover {
  color: var(--brand) !important;
}

.qpos-brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 11px;
  /*background: linear-gradient(135deg, #2A1010 0%, #150808 100%);*/
  background: transparent !important; 
  display: grid;
  place-items: center;
  color: var(--brand);
  /*box-shadow:
    0 10px 30px -8px rgba(0,0,0,.2),
    0 0 0 1px rgba(152,0,0,.18) inset;*/
  position: relative;
}

.qpos-brand-mark::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 11px;
  background: linear-gradient(135deg, rgba(152,0,0,.18), transparent 60%);
  pointer-events: none;
}

.qpos-brand small {
  display: block;
  font-size: 9.5px;
  font-weight: 600;
  color: var(--muted);
  letter-spacing: .2em;
  margin-top: -2px;
}


/* Hamburger mobile */
.qpos-topbar .navbar-toggler{
  border:1px solid var(--border) !important;
  border-radius:10px;
  padding:8px 10px;
  background:var(--surface);
  transition:all .2s ease;
}
.qpos-topbar .navbar-toggler:hover{
  background:var(--surface-2);
  border-color:var(--border-strong) !important;
}
.qpos-topbar .navbar-toggler-icon{
  width:20px;height:20px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba%2840,40,40,0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* Nav links desktop */
.qpos-nav-link{
  display:flex !important;
  align-items:center;
  gap:8px;
  color:var(--text-soft) !important;
  font-size:14px;
  font-weight:500;
  padding:8px 14px !important;
  border-radius:10px;
  transition:all .2s ease;
}
.qpos-nav-link:hover{
  color:var(--brand) !important;
  background:var(--surface);
}
.qpos-nav-link i{color:var(--muted);transition:color .2s;}
.qpos-nav-link:hover i{color:var(--brand);}

/* Nav links mobile (grandi) */
.qpos-nav-link-lg{
  font-size:16px;
  padding:14px 16px !important;
  border-radius:12px;
}
.qpos-nav-link-lg:hover{
  background:var(--surface-2);
}

/* Connessione protetta */
.qpos-secure{
  display:flex;align-items:center;gap:7px;
  font-size:12px;color:var(--text-soft);font-weight:500;
  background:var(--surface);border:1px solid var(--border);
  padding:8px 14px;border-radius:999px;
  backdrop-filter:blur(20px);
  white-space:nowrap;
}
.qpos-secure-lg{
  font-size:13px;
  padding:12px 16px;
  justify-content:center;
}
.qpos-secure .dot{
  width:6px;height:6px;border-radius:50%;background:var(--success);
  box-shadow:0 0 0 3px var(--success-soft);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px var(--success-soft);}
  50%{box-shadow:0 0 0 7px rgba(0,168,84,.04);}
}

/* ============================================================
   OFFCANVAS MOBILE - Dark Titanium, slide da destra
   ============================================================ */

.qpos-offcanvas{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border-left:1px solid var(--border);
  width:300px !important;
}
.qpos-offcanvas .offcanvas-header{
  border-bottom:1px solid var(--border);
  padding:20px 24px;
}
.qpos-offcanvas .offcanvas-title{
  color:var(--text);
  font-size:16px;
  font-weight:600;
  letter-spacing:-.01em;
}
.qpos-offcanvas .offcanvas-body{
  padding:20px 16px;
}
.qpos-offcanvas .btn-close{
  opacity:.7;
  transition:all .25s ease;
  width:28px;height:28px;
  padding:0;
  background-size:14px;
}
.qpos-offcanvas .btn-close:hover{
  opacity:1;
  transform:rotate(90deg);
}

/* Backdrop offcanvas */
.offcanvas-backdrop.show{
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(4px);
}

/* ============================================================
   LAYOUT GRID
   ============================================================ */

.qpos-grid{display:grid;grid-template-columns:1fr;gap:24px;min-width:0;}
@media(min-width:960px){
  .qpos-grid{grid-template-columns:1.05fr 1fr;gap:44px;align-items:start;}
  /* Impedisce alle colonne della grid di allargarsi oltre il disponibile */
  .qpos-grid > * { min-width: 0; }
}

/* ============================================================
   HERO
   ============================================================ */

.qpos-hero-old{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:40px 34px;
  position:relative;overflow:hidden;
}



.qpos-hero{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:34px;
  box-shadow:0 30px 60px -38px rgba(0,0,0,.8);   /* ← stesso shadow del form */
  position:relative;
  overflow:hidden;
  /* Previene overflow nella grid a due colonne */
  min-width: 0;
  max-width: 100%;
}

/*
.qpos-hero::before{
  content:"";position:absolute;top:-40%;right:-15%;
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(152,0,0,.06) 0%,transparent 65%);
  pointer-events:none;filter:blur(20px);
}
.qpos-hero::after{
  content:"";position:absolute;bottom:-30%;left:-10%;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(152,0,0,.04) 0%,transparent 65%);
  pointer-events:none;filter:blur(30px);
}
*/

/* Hero badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--brand-soft);
  border:1px solid rgba(152,0,0,.12);
  color:var(--brand);
  font-size:11px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 14px;
  border-radius:999px;
  margin-bottom:20px;
  position:relative;
}

.qpos-hero h1{
  font-size:32px;font-weight:700;letter-spacing:-.03em;
  margin:0 0 14px;line-height:1.15;position:relative;
}
.qpos-hero h1 .accent{
  background:linear-gradient(135deg,var(--brand-3) 0%,var(--brand-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.qpos-hero p.lead{
  color:var(--muted);font-size:15px;line-height:1.65;
  margin:0 0 28px;position:relative;max-width:520px;
}
.qpos-hero p.lead strong{color:var(--text-soft);font-weight:600;}

.qpos-features{display:grid;gap:10px;margin-top:28px;position:relative;}
.qpos-feature{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px;border-radius:12px;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  border:1px solid transparent;
}
.qpos-feature:hover{
  background:var(--surface-2);
  border-color:var(--border);
  transform:translateX(2px);
}
.qpos-feature-icon{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(152,0,0,.10),rgba(152,0,0,.06));
  color:var(--brand);
  display:grid;place-items:center;
  border:1px solid rgba(152,0,0,.12);
}
.qpos-feature h5{font-size:14px;font-weight:600;margin:0 0 3px;color:var(--text);}
.qpos-feature p{font-size:13px;color:var(--muted);margin:0;line-height:1.55;}

/* ============================================================
   CARD PREVIEW 3D
   ============================================================ */

.card-stage{perspective:1400px;margin:32px auto 0;max-width:400px;position:relative;}
.card-flip{
  position:relative;width:100%;aspect-ratio:1.586/1;
  transform-style:preserve-3d;
  transition:transform .9s cubic-bezier(.4,.2,.2,1);
}
.card-flip.flipped{transform:rotateY(180deg);}
.card-face{
  position:absolute;inset:0;border-radius:var(--radius-lg);
  backface-visibility:hidden;padding:24px 26px;color:#fff;
  overflow:hidden;
  box-shadow:
    0 30px 60px -15px rgba(0,0,0,.7),
    0 0 0 1px rgba(152,0,0,.08) inset;
}
.card-front{
  background:
    radial-gradient(circle at 90% 0%, rgba(152,0,0,.12) 0%, transparent 45%),
    radial-gradient(circle at 0% 100%, rgba(152,0,0,.20) 0%, transparent 55%),
    linear-gradient(135deg,#0A0000 0%,#2A0000 35%,#980000 55%,#4A0000 80%,#0A0000 100%);
}
.card-front::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);
  pointer-events:none;
}
.card-back{
  background:linear-gradient(135deg,#0A0000 0%,#2A0000 50%,#0A0000 100%);
  transform:rotateY(180deg);padding:0;
}
.card-chip{
  width:46px;height:36px;border-radius:6px;
  background:linear-gradient(135deg,#e8c770 0%,#b8912d 100%);
  position:relative;margin-top:14px;
  box-shadow:0 2px 4px rgba(0,0,0,.3) inset;
}
.card-chip::before,.card-chip::after{content:"";position:absolute;background:rgba(0,0,0,.2);}
.card-chip::before{inset:6px 4px;border-radius:2px;}
.card-chip::after{left:50%;top:4px;bottom:4px;width:1px;}
.card-contactless{position:absolute;top:24px;right:26px;opacity:.85;}
.card-number{
  font-family:'Courier New',monospace;
  font-size:20px;letter-spacing:2.5px;
  margin-top:30px;font-weight:600;
  text-shadow:0 1px 3px rgba(0,0,0,.4);
}
.card-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:18px;gap:12px;
}
.card-label{
  font-size:9px;text-transform:uppercase;letter-spacing:1.6px;
  opacity:.6;margin-bottom:3px;
}
.card-value{font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;}
.card-brand-logo{
  font-size:22px;font-weight:800;font-style:italic;letter-spacing:-1px;
}
.card-stripe{height:46px;background:#000;margin-top:26px;}
.card-cvv-box{
  background:#fff;color:#000;
  margin:22px 26px 0;padding:11px 14px;
  border-radius:4px;font-family:'Courier New',monospace;
  font-size:16px;font-weight:700;letter-spacing:3px;text-align:right;
}
.card-back-info{
  position:absolute;bottom:18px;left:26px;right:26px;
  font-size:10px;opacity:.55;line-height:1.5;color:#fff;
}

/* ============================================================
   FORM CARD
   ============================================================ */

.qpos-form-card{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:34px;
  box-shadow:0 30px 60px -38px rgba(0,0,0,.8);
  position:sticky;top:24px;
  /* Previene overflow orizzontale nella homepage */
  min-width: 0;
  overflow: hidden;
  /* Garantisce che non sfori mai il contenitore padre */
  max-width: 100%;
  width: 100%;
}

/* Demo badge */
.title-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(152,0,0,.06);
  border:1px solid rgba(152,0,0,.15);
  color:var(--brand);
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  padding:6px 14px;
  border-radius:999px;
  margin-bottom:18px;
}

.qpos-form-title{
  font-size:19px;font-weight:700;margin:0 0 5px;letter-spacing:-.02em;
}
.qpos-form-sub{font-size:13px;color:var(--muted);margin:0 0 22px;}

/* Amount display */
.amount-display{
  background:var(--field);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 22px;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:22px;transition:all .3s ease;
  position:relative;overflow:hidden;
}
.amount-display::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(152,0,0,.03),transparent);
  opacity:0;transition:opacity .3s;
}
.amount-display.filled{
  border-color:rgba(152,0,0,.20);
  box-shadow:0 0 0 4px var(--brand-soft),0 8px 24px -8px rgba(0,0,0,.6);
}
.amount-display.filled::before{opacity:1;}
.amount-display .lbl{
  font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;
  color:var(--muted);font-weight:600;position:relative;
}
.amount-display .val{
  font-size:28px;font-weight:700;letter-spacing:-.025em;color:var(--text);
  position:relative;
}
.amount-display .desc{font-size:12px;color:var(--muted);margin-top:3px;position:relative;}

/* Campi form */
.q-field{
  background:var(--field);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:13px 14px;
  width:100%;
  font-size:14.5px;
  color:var(--text);
  font-family:inherit;
  transition:all .2s ease;
  outline:none;
}
.q-field::placeholder{color:var(--muted-2);}
.q-field:hover{background:var(--field-hover);border-color:var(--border-strong);}
.q-field:focus{
  background:var(--field-hover);
  border-color:var(--brand);
  box-shadow:0 0 0 4px var(--brand-soft);
}
.q-field.is-invalid{
  border-color:var(--error);
  background:var(--error-soft);
  box-shadow:0 0 0 4px rgba(211,47,47,.08);
}
.q-label{
  font-size:12px;font-weight:600;color:var(--text-soft);
  margin-bottom:7px;display:block;
}
.q-error{
  font-size:11.5px;color:var(--error);margin-top:6px;
  display:none;align-items:center;gap:4px;font-weight:500;
}
.q-error.show{display:flex;}

.input-icon-wrap{position:relative;}
.input-icon-wrap .q-field{padding-right:50px;}
.input-icon-right{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  width:34px;height:23px;display:grid;place-items:center;pointer-events:none;
}
.card-brand-badge{
  width:34px;height:23px;border-radius:4px;
  display:grid;place-items:center;
  font-size:9px;font-weight:800;letter-spacing:-.3px;
  color:#fff;transition:all .25s;
}
.brand-visa{background:linear-gradient(135deg,#1a1f71,#2d3591);}
.brand-mc{background:linear-gradient(135deg,#eb001b 50%,#f79e1b 50%);}
.brand-amex{background:linear-gradient(135deg,#006fcf,#0080ef);}
.brand-unknown{background:var(--surface-3);color:var(--muted);border:1px solid var(--border);}

.accepted-cards{
  display:flex;gap:6px;align-items:center;margin-bottom:20px;
}
.accepted-cards .mini{
  width:36px;height:24px;border-radius:4px;
  display:grid;place-items:center;
  font-size:9px;font-weight:800;color:#fff;
  border:1px solid var(--border);
}
.accepted-cards span.txt{font-size:12px;color:var(--muted);margin-left:4px;}

/* Pulsante PAGA - argento titanio premium */
.btn-qpos{
  background:linear-gradient(135deg,var(--brand-3) 0%,var(--brand) 50%,var(--brand-2) 100%);
  color:#FFFFFF;
  border:none;border-radius:var(--radius);
  padding:17px 22px;width:100%;
  font-weight:700;font-size:15px;letter-spacing:.02em;
  cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);
  box-shadow:
    0 12px 30px -8px rgba(152,0,0,.25),
    0 0 0 1px rgba(255,255,255,.15) inset;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:10px;
  text-shadow:0 1px 0 rgba(0,0,0,.2);
}

.btn-qpos::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform .7s;
}
.btn-qpos:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:
    0 16px 36px -8px rgba(152,0,0,.35),
    0 0 0 1px rgba(255,255,255,.2) inset;
  filter:brightness(1.05);
}
.btn-qpos:hover::before{transform:translateX(100%);}
.btn-qpos:active:not(:disabled){transform:translateY(0);}
.btn-qpos:disabled{opacity:.6;cursor:not-allowed;}

/* Trust */
.qpos-trust{
  display:flex;flex-wrap:wrap;gap:16px;justify-content:center;
  margin-top:22px;padding-top:20px;border-top:1px solid var(--border);
}
.trust-item{
  display:flex;align-items:center;gap:6px;
  font-size:11px;color:var(--muted);font-weight:500;
}
.trust-item i{color:var(--success);font-size:13px;}

/* Alert globale */
.alert-global{
  background:var(--error-soft);
  border:1px solid rgba(255,77,109,.25);
  color:var(--error);
  border-radius:var(--radius);
  padding:12px 14px;font-size:13px;font-weight:500;
  display:none;align-items:center;gap:8px;margin-bottom:18px;
}
.alert-global.show{display:flex;}

/* ============================================================
   INFO SECTION SOTTO
   ============================================================ */

.qpos-info-section{
  margin-top:48px;
  position:relative;
}
.qpos-info-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  margin-bottom:48px;
}
@media(min-width:768px){
  .qpos-info-grid{grid-template-columns:repeat(3,1fr);}
}

.qpos-info-card{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  position:relative;
  overflow:hidden;
}
.qpos-info-card:hover{
  border-color:var(--border-strong);
  transform:translateY(-2px);
  box-shadow:0 20px 40px -15px rgba(0,0,0,.6);
}
.qpos-info-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--brand),transparent);
  opacity:0;transition:opacity .3s;
}
.qpos-info-card:hover::before{opacity:1;}

.qpos-info-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(152,0,0,.10),rgba(152,0,0,.06));
  color:var(--brand);
  display:grid;place-items:center;
  border:1px solid rgba(152,0,0,.12);
  margin-bottom:18px;
}
.qpos-info-card h4{
  font-size:16px;
  font-weight:700;
  color:var(--text);
  margin:0 0 10px;
  letter-spacing:-.01em;
}
.qpos-info-card p{
  font-size:13.5px;
  color:var(--muted);
  line-height:1.65;
  margin:0;
}

/* ============================================================
   URL EXAMPLE BOX - Responsive, no scroll orizzontale
   ============================================================ */

.qpos-url-example{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-soft) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.qpos-url-example::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--brand),transparent);
}
.url-label{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--muted);
  font-size:12px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:16px;
}

/* URL Box - block layout per wrapping naturale */
.url-box{
  display:block;
  background:var(--field);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:16px 20px;
  font-family:'Courier New',monospace;
  font-size:14px;
  position:relative;
  word-break:break-all;
  text-align:left;
  line-height:1.7;
}
.url-box:hover{border-color:var(--border-strong);}

/* Ogni parte dell'URL su riga propria */
.url-line{
  display:block;
}
.url-line:first-child{
  margin-bottom:4px;
}
.url-protocol{color:var(--muted-2);}
.url-domain{color:var(--muted);}
.url-slug{
  color:var(--brand);
  font-weight:600;
  background:linear-gradient(90deg, rgba(152,0,0,.08), transparent);
  padding:2px 8px;
  border-radius:6px;
  margin-left:-4px;
}

/* Pulsante copia - posizionato in alto a destra */
.url-copy{
  position:absolute;
  top:12px;
  right:12px;
  background:var(--surface-2);
  border:1px solid var(--border);
  color:var(--muted);
  cursor:pointer;
  padding:6px 10px;
  border-radius:8px;
  transition:all .2s;
  display:flex;align-items:center;
  gap:6px;
  font-family:'Inter',system-ui,sans-serif;
  font-size:11px;
  font-weight:600;
}
.url-copy:hover{
  color:var(--brand);
  border-color:var(--border-strong);
  background:var(--surface-3);
}
.url-copy:active{transform:scale(.95);}

.url-hint{
  color:var(--muted-2);
  font-size:13px;
  margin-top:16px;
  margin-bottom:0;
}

/* Mobile: URL ancora più compatto */
@media(max-width:600px){
  .qpos-url-example{padding:24px 18px;}
  .url-box{padding:14px 16px;font-size:13px;}
  .url-copy{
    position:static;
    margin-top:12px;
    justify-content:center;
    width:100%;
  }
}

/* ============================================================
   FOOTER
   ============================================================ */

.qpos-footer{
  text-align:center;margin-top:40px;font-size:11px;color:var(--muted-2);
  display:flex;flex-direction:column;gap:8px;align-items:center;
}
.qpos-footer a{color:var(--muted);text-decoration:none;transition:color .2s;}
.qpos-footer a:hover{color:var(--brand);}
.qpos-footer .powered{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 11px;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);
  font-size:10.5px;font-weight:600;letter-spacing:.08em;
  color:var(--text-soft);
}
.qpos-footer .powered .dot-mini{
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 0 8px var(--brand-glow);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media(max-width:600px){
  .qpos-shell{padding:0 4px 20px;}
  .qpos-topbar{padding:16px 0;}
  .qpos-hero,.qpos-form-card{padding:26px 20px;}
  .qpos-hero h1{font-size:23px;}
  .card-number{font-size:16px;letter-spacing:1.8px;}
  .amount-display .val{font-size:23px;}
  .qpos-secure span:not(.dot){display:none;}
  .qpos-info-card{padding:24px 20px;}
  .url-box{font-size:12px;padding:12px 14px;}
}

/* ============================================================
   COOKIE BANNER - Dark Titanium
   ============================================================ */

/* Backdrop scuro con blur */
.cookie-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(6px);
  z-index:1040;
  opacity:0;
  visibility:hidden;
  transition:opacity .4s ease, visibility .4s ease;
}
.cookie-backdrop.show{
  opacity:1;
  visibility:visible;
}

/* Toast banner bottom */
.cookie-toast{
  position:fixed;
  bottom:20px;
  left:50%;
  transform:translateX(-50%) translateY(120%);
  z-index:1050;
  width:calc(100% - 32px);
  max-width:520px;
  opacity:0;
  transition:transform .5s cubic-bezier(.4,0,.2,1), opacity .4s ease;
}
.cookie-toast.show{
  transform:translateX(-50%) translateY(0);
  opacity:1;
}

/* Inner card */
.cookie-toast-inner{
  display:flex;
  align-items:center;
  gap:16px;
  background:linear-gradient(180deg, var(--surface-2) 0%, var(--surface) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:18px 22px;
  box-shadow:
    0 24px 48px -12px rgba(0,0,0,.8),
    0 0 0 1px rgba(255,255,255,.06) inset;
  position:relative;
  overflow:hidden;
}
.cookie-toast-inner::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(152,0,0,.18), transparent);
}

/* Icona cookie */
.cookie-icon{
  width:40px;height:40px;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(152,0,0,.10), rgba(59,91,219,.08));
  color:var(--brand);
  display:grid;place-items:center;
  border:1px solid rgba(152,0,0,.10);
  flex-shrink:0;
}

/* Testo */
.cookie-body{flex:1;min-width:0;}
.cookie-title{
  font-size:13px;
  font-weight:700;
  color:var(--text);
  margin:0 0 3px;
  letter-spacing:-.01em;
}
.cookie-text{
  font-size:12px;
  color:var(--muted);
  margin:0;
  line-height:1.5;
}

/* Azioni / Bottoni */
.cookie-actions{
  display:flex;
  gap:8px;
  flex-shrink:0;
}
.cookie-btn{
  font-size:12px;
  font-weight:600;
  padding:9px 18px;
  border-radius:10px;
  border:none;
  cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
}
.cookie-btn-primary{
  background:linear-gradient(135deg, var(--brand-3) 0%, var(--brand) 50%, var(--brand-2) 100%);
  color:#FFFFFF;
  box-shadow:0 4px 12px -2px rgba(152,0,0,.20);
}
.cookie-btn-primary:hover{
  filter:brightness(1.1);
  transform:translateY(-1px);
}
.cookie-btn-ghost{
  background:transparent;
  color:var(--muted);
  border:1px solid var(--border);
}
.cookie-btn-ghost:hover{
  background:var(--surface-3);
  color:var(--text-soft);
  border-color:var(--border-strong);
}

/* Responsive cookie banner */
@media(max-width:600px){
  .cookie-toast{bottom:12px;width:calc(100% - 24px);}
  .cookie-toast-inner{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    padding:16px 18px;
  }
  .cookie-actions{width:100%;}
  .cookie-actions .cookie-btn{flex:1;text-align:center;}
}

/* ============================================================
   STRIPE CARD ELEMENT
   ============================================================ */

.qpos-card-element {
    background: var(--field);
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 13px 14px;
    transition: all .2s ease;
}
.qpos-card-element:hover {
    background: var(--field-hover);
    border-color: var(--border-strong);
}
.qpos-card-element.StripeElement--focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 4px var(--brand-soft);
    background: var(--field-hover);
}
.qpos-card-element.StripeElement--invalid {
    border-color: var(--error);
    box-shadow: 0 0 0 4px rgba(211,47,47,.08);
}

/*
.stripe-card-element {
    background: var(--field);
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 13px 14px;
    transition: all .2s ease;
}
.stripe-card-element:hover {
    background: var(--field-hover);
    border-color: var(--border-strong);
}
.stripe-card-element.StripeElement--focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 4px var(--brand-soft);
    background: var(--field-hover);
}
.stripe-card-element.StripeElement--invalid {
    border-color: var(--error);
    box-shadow: 0 0 0 4px rgba(211,47,47,.08);
}
*/
/* Schermata di successo */
.success-screen {
    display: none;
    text-align: center;
    padding: 30px 20px;
    background: var(--surface-2);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    margin-top: 20px;
}
.success-screen.show { display: block; }
.success-icon { margin-bottom: 16px; }
.success-screen h4 {
    font-weight: 700;
    margin-bottom: 4px;
}
.success-screen p {
    color: var(--muted);
    font-size: 14px;
    margin-bottom: 20px;
}
.receipt-details {
    background: var(--field);
    border-radius: var(--radius);
    padding: 16px;
    text-align: left;
    font-size: 13px;
}
.receipt-details > div {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    border-bottom: 1px solid var(--border);
}
.receipt-details > div:last-child { border-bottom: none; }
.receipt-details span { color: var(--muted); }
.receipt-details strong { color: var(--text); }

.powered {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .08em;
  color: var(--text-soft);
  flex-wrap: wrap;
  justify-content: center;
}

.powered-text {
  display: inline;
}

.powered-break {
  margin-left: 0;
}

@media (min-width: 576px) {
  .powered-break::before {
    content: " - ";
  }
}

/* ============================================================
LAYOUT LINK DI PAGAMENTO (Singola colonna centrata)
============================================================ */
.qpos-payment-layout {
    max-width: 600px;
    margin: 10px auto 40px;
    padding: 0 16px;
    position: relative;
    z-index: 1;
}

/* Rimuove lo sticky dal form quando è in modalità link singolo */
.qpos-payment-layout .qpos-form-card {
    position: relative;
    top: auto;
}

/* Ottimizzazione mobile */
@media (max-width: 600px) {
    .qpos-payment-layout {
        margin: 5px auto 20px;
        padding: 0 12px;
    }
}

@media (max-width: 575.98px) {
  .qpos-brand {
    padding-left: 12px !important;
  }
}
@media (max-width: 575.98px) {
  .icon-mobile {
    width: 22px !important;
    height: 22px !important;
  }
}
/* TEST CARD ELEMENT - STILE IDENTICO A STRIPE */
.test-card-element {
    padding: 0;
    overflow: hidden;
    /* Previene overflow orizzontale nella homepage */
    min-width: 0;
    max-width: 100%;
}

.test-card-fields {
    display: flex;
    align-items: center;
    gap: 0;
    /* Evita che il flex container sfori il contenitore */
    min-width: 0;
    overflow: hidden;
}

.test-card-input {
    border: none;
    background: transparent;
    padding: 13px 8px;
    font-size: 15px;
    color: var(--text);
    font-family: inherit;
    outline: none;
    flex: 1;
    min-width: 0;
    /* Evita che l'input si allarghi oltre il suo contenitore */
    width: 0;
}

.test-card-input::placeholder {
    color: #5A5A62;
    font-size: 15px;
}

/* Larghezze per i singoli campi (come Stripe) */
#cardExp {
    flex: 0.6;
    max-width: 90px;
}
#cardCvv {
    flex: 0.4;
    max-width: 70px;
}

/*   BADGE CARTA (TEST)   */
#cardBrandBadge {
    width: 34px;
    height: 22px;
    border-radius: 3px;
    margin-left: 6px;
    margin-right: 2px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: -0.2px;
    color: #fff;
    transition: all 0.25s ease;
    background: transparent;
    border: none;
}

/*   STATO DEFAULT (unknown)   */
#cardBrandBadge.brand-unknown {
    background: transparent !important;
    border: none !important;
}
#cardBrandBadge.brand-unknown svg {
    display: block;
    width: 28px;
    height: 18px;
}

/*   MARCHE RICONOSCIUTE   */
#cardBrandBadge.brand-visa {
    background: linear-gradient(135deg, #1a1f71, #2d3591) !important;
    border: none !important;
    color: #fff !important;
}
#cardBrandBadge.brand-mc {
    background: linear-gradient(135deg, #eb001b 50%, #f79e1b 50%) !important;
    border: none !important;
    color: #fff !important;
}
#cardBrandBadge.brand-amex {
    background: linear-gradient(135deg, #006fcf, #0080ef) !important;
    border: none !important;
    color: #fff !important;
}

/* Focus unificato su tutto il blocco */
.test-card-element:focus-within {
    border-color: var(--brand);
    box-shadow: 0 0 0 4px var(--brand-soft);
    background: var(--field-hover);
}

.test-card-element:hover {
    background: var(--field-hover);
    border-color: var(--border-strong);
}

/* Stato errore su tutto il blocco */
.test-card-element.has-error {
    border-color: var(--error);
    box-shadow: 0 0 0 4px rgba(211, 47, 47, 0.08);
}

/* Errori sotto il blocco (come in live) */
.test-card-errors {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* ============================================================
   FIX OVERFLOW ORIZZONTALE - Homepage con pay.php incluso
   Problema: il form card si allargava oltre la viewport quando
   incluso nella grid a due colonne di home.php
   ============================================================ */

/* Garantisce che la shell non produca scroll orizzontale */
.qpos-shell {
    overflow-x: hidden;
}

/* Ogni colonna della grid non può sforare il proprio slot */
.qpos-grid > * {
    min-width: 0;
    max-width: 100%;
}

/* Il form #paymentForm non sfora mai il card */
#paymentForm {
    min-width: 0;
    max-width: 100%;
}

/* Campi q-field: previene allargamento in contesti stretti */
.q-field {
    box-sizing: border-box;
    max-width: 100%;
}

/* Larghezze dei campi carta in modalità test - più compatte nella grid */
@media (min-width: 960px) {
    /* Nella grid a due colonne la colonna destra è più stretta:
       riduciamo i flex dei campi carta per non sforare */
    #cardExp {
        flex: 0 0 80px;
        max-width: 80px;
    }
    #cardCvv {
        flex: 0 0 60px;
        max-width: 60px;
    }
}

/* Mobile: padding ridotto per guadagnare spazio */
@media (max-width: 480px) {
    .qpos-form-card {
        padding: 20px 16px;
    }
    .qpos-hero {
        padding: 24px 16px;
    }
    #cardExp {
        flex: 0 0 72px;
        max-width: 72px;
    }
    #cardCvv {
        flex: 0 0 56px;
        max-width: 56px;
    }
    .test-card-input {
        padding: 11px 6px;
        font-size: 14px;
    }
    .test-card-input::placeholder {
        font-size: 13px;
    }
}
