/* =============================================
   VARIABLES
   ============================================= */
:root {
    --royal-blue: rgb(24, 51, 112);
    --silver: rgb(186, 192, 198);
    --light-silver: rgb(220, 224, 228);
    --dark-blue: rgb(18, 38, 84);
    --accent-silver: rgb(160, 168, 176);
    --bg-light: #f0f2f5;
    --danger: #dc3545;
    --success: #28a745;
    --warning: #e6a817;
    color-scheme: light only;
}
/* =============================================
   RESET & BASE
   ============================================= */
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Montserrat', sans-serif; color: var(--dark-blue); overflow-x: hidden; background: var(--bg-light); }
body.menu-open { overflow: hidden; }

/* =============================================
   ANIMATIONS
   ============================================= */
@keyframes fadeInUp { from { opacity:0; transform:translateY(40px); } to { opacity:1; transform:translateY(0); } }
@keyframes float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-20px); } }
@keyframes shimmer { 0% { background-position:-1000px 0; } 100% { background-position:1000px 0; } }

/* =============================================
   TOP NAV (desktop ≥1025px)
   ============================================= */
.top-nav { display:none; position:fixed; top:0; left:0; right:0; z-index:1000; background:rgba(18,38,84,0.96); backdrop-filter:blur(12px); border-bottom:1px solid rgba(186,192,198,0.2); transition:all 0.3s; }
.top-nav.scrolled { background:rgba(18,38,84,0.99); box-shadow:0 4px 20px rgba(0,0,0,0.3); }
.top-nav-inner { max-width:1400px; margin:0 auto; padding:0 40px; display:flex; align-items:center; justify-content:space-between; height:65px; }
.top-nav-logo { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:700; color:white; text-decoration:none; letter-spacing:3px; flex-shrink:0; }
.top-nav-links { display:flex; align-items:center; gap:4px; }
.top-nav-links a { color:var(--light-silver); text-decoration:none; font-size:13px; font-weight:400; letter-spacing:1px; padding:6px 12px; border-radius:4px; transition:all 0.2s; white-space:nowrap; }
.top-nav-links a:hover { color:white; background:rgba(255,255,255,0.1); }
.top-nav-divider { color:rgba(186,192,198,0.4); font-size:14px; margin:0 4px; }
.top-nav-admin { color:var(--silver) !important; border:1px solid rgba(186,192,198,0.3); }
.top-nav-admin:hover { border-color:var(--silver) !important; }
.top-nav-logout { background:rgba(220,53,69,0.15) !important; color:#ff6b7a !important; border:1px solid rgba(220,53,69,0.3); }
.top-nav-logout:hover { background:rgba(220,53,69,0.3) !important; color:white !important; }

/* =============================================
   MOBILE MENU
   ============================================= */
.mobile-menu-toggle { display:flex; align-items:center; justify-content:center; position:fixed; top:20px; left:20px; z-index:1002; background:var(--royal-blue); border:2px solid var(--silver); color:white; width:50px; height:50px; border-radius:50%; cursor:pointer; transition:all 0.3s; font-size:20px; }
.mobile-menu-toggle:hover { background:var(--dark-blue); transform:scale(1.1); }
.nav-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:999; backdrop-filter:blur(2px); }
.nav-overlay.visible { display:block; }
.side-nav { position:fixed; left:0; top:0; height:100vh; width:280px; background:linear-gradient(135deg,var(--royal-blue) 0%,var(--dark-blue) 100%); padding:40px 20px; z-index:1001; transition:transform 0.4s cubic-bezier(0.4,0,0.2,1); box-shadow:4px 0 20px rgba(0,0,0,0.3); transform:translateX(-100%); overflow-y:auto; }
.side-nav.mobile-visible { transform:translateX(0); }
.nav-logo { font-family:'Cormorant Garamond',serif; font-size:32px; font-weight:700; color:white; text-align:center; margin-bottom:50px; letter-spacing:2px; }
.nav-close-btn { position:absolute; top:15px; right:15px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2); color:white; width:36px; height:36px; border-radius:50%; cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:0.2s; }
.nav-close-btn:hover { background:rgba(255,255,255,0.2); }
.nav-links { list-style:none; }
.nav-links li { margin:10px 0; }
.nav-links a { color:var(--light-silver); text-decoration:none; font-size:16px; font-weight:300; letter-spacing:1px; transition:all 0.3s; display:flex; align-items:center; padding:12px 20px; border-radius:8px; }
.nav-links a:hover,.nav-links a.active { color:white; background:rgba(255,255,255,0.1); transform:translateX(5px); }
.nav-divider { border-top:1px solid rgba(255,255,255,0.15); margin:15px 0 !important; }
.nav-admin-link { background:rgba(255,255,255,0.08) !important; border:1px solid rgba(255,255,255,0.2); }

/* =============================================
   SITE MAIN & FOOTER
   ============================================= */
.site-main { min-height:100vh; }
.site-footer { background:var(--dark-blue); }
.footer-below { padding:16px 40px; border-top:1px solid rgba(186,192,198,0.15); }
.footer-below-inner { display:flex; align-items:center; justify-content:flex-end; max-width:1400px; margin:0 auto; }
.copyright-text { font-size:12px; color:var(--silver); }
.powered-by img { height:28px; opacity:0.7; transition:opacity 0.2s; }
.powered-by img:hover { opacity:1; }

/* =============================================
   HERO
   ============================================= */
.hero { height:100vh; background:linear-gradient(135deg,var(--royal-blue) 0%,var(--dark-blue) 50%,var(--royal-blue) 100%); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.hero::before { content:''; position:absolute; inset:0; background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><path d="M0,300 Q300,100 600,300 T1200,300" fill="none" stroke="rgba(186,192,198,0.1)" stroke-width="2"/></svg>'); background-size:cover; animation:float 20s ease-in-out infinite; }
.hero-content { text-align:center; z-index:1; color:white; animation:fadeInUp 1.2s ease-out; }
.hero-title { font-family:'Cormorant Garamond',serif; font-size:90px; font-weight:300; letter-spacing:8px; margin-bottom:20px; background:linear-gradient(90deg,white,var(--silver),white); background-size:200% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; animation:shimmer 4s linear infinite; }
.hero-ampersand { font-size:60px; font-weight:400; font-style:italic; color:var(--light-silver); display:block; margin:10px 0; }
.hero-date { font-size:24px; font-weight:200; letter-spacing:4px; color:var(--light-silver); margin-top:30px; }

/* =============================================
   COUNTDOWN
   ============================================= */
.countdown { padding:100px 50px; background:white; text-align:center; }
.section-title { font-family:'Cormorant Garamond',serif; font-size:48px; font-weight:600; color:var(--royal-blue); margin-bottom:60px; letter-spacing:2px; }
.countdown-timer { display:flex; justify-content:center; gap:40px; flex-wrap:wrap; }
.countdown-item { background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); padding:40px; border-radius:20px; min-width:150px; box-shadow:0 10px 30px rgba(24,51,112,0.3); position:relative; overflow:hidden; }
.countdown-number { font-size:56px; font-weight:700; color:white; }
.countdown-label { font-size:14px; color:var(--silver); text-transform:uppercase; letter-spacing:2px; margin-top:10px; }

/* =============================================
   SAVE DATE / EVENT / STORY / RSVP (home)
   ============================================= */
.save-date-banner { padding:80px 50px; background:linear-gradient(135deg,var(--dark-blue),var(--royal-blue)); text-align:center; color:white; position:relative; overflow:hidden; }
.save-date-content { max-width:700px; margin:0 auto; position:relative; z-index:1; }
.save-date-content h2 { font-family:'Cormorant Garamond',serif; font-size:48px; margin-bottom:20px; font-weight:400; }
.save-date-content p { font-size:18px; line-height:1.8; margin-bottom:35px; color:var(--light-silver); }
.our-story { padding:100px 50px; background:white; }
.story-container { max-width:900px; margin:0 auto; }
.story-intro { text-align:center; margin-bottom:60px; }
.story-intro p { font-size:18px; line-height:1.9; color:#555; margin-bottom:20px; }
.story-preview { background:linear-gradient(135deg,rgba(248,249,250,1),rgba(240,242,245,1)); padding:50px; border-left:4px solid var(--royal-blue); margin:40px 0; }
.story-preview p { font-size:16px; line-height:1.8; color:#666; margin-bottom:15px; }
.read-more-btn { display:inline-block; margin-top:30px; padding:14px 35px; background:white; color:var(--royal-blue); text-decoration:none; transition:all 0.4s; font-weight:600; letter-spacing:1.5px; border:2px solid var(--royal-blue); text-transform:uppercase; font-size:13px; position:relative; overflow:hidden; z-index:1; }
.read-more-btn::before { content:''; position:absolute; top:0; left:0; width:0; height:100%; background:var(--royal-blue); transition:width 0.4s; z-index:-1; }
.read-more-btn:hover::before { width:100%; }
.read-more-btn:hover { color:white; transform:translateY(-3px); box-shadow:0 10px 30px rgba(24,51,112,0.3); }
.event-section { padding:100px 0; }
.event-section:nth-child(even) { background:linear-gradient(to bottom,white,var(--light-silver)); }
.event-section:nth-child(odd) { background:white; }
.event-content { max-width:1200px; margin:0 auto; padding:0 50px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.event-text h3 { font-family:'Cormorant Garamond',serif; font-size:42px; color:var(--royal-blue); margin-bottom:25px; font-weight:600; }
.event-text p { font-size:16px; line-height:1.8; color:#555; margin-bottom:15px; }
.event-text strong { color:var(--dark-blue); }
.dress-code-section { padding:100px 0; }
.dress-code-section:nth-child(even) { background:linear-gradient(to bottom,white,var(--light-silver)); }
.dress-code-section:nth-child(odd) { background:white; }
.dress-code-content { max-width:1200px; margin:0 auto; padding:0 50px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.dress-code-text h3 { font-family:'Cormorant Garamond',serif; font-size:42px; color:var(--royal-blue); margin-bottom:25px; font-weight:600; }
.dress-code-text p { font-size:16px; line-height:1.8; color:#555; margin-bottom:15px; }
.dress-code-text strong { color:var(--dark-blue); }
.event-actions { display:flex; gap:20px; margin-top:30px; flex-wrap:wrap; }
.event-visual { background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); min-height:400px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; box-shadow:0 20px 60px rgba(24,51,112,0.3); }
.event-icon-large { width:120px; height:120px; position:relative; z-index:1; }
.event-icon-large svg { width:100%; height:100%; fill:white; opacity:0.9; }
.location-btn,.save-date-btn { display:inline-block; padding:14px 35px; background:white; color:var(--royal-blue); text-decoration:none; transition:all 0.4s; font-weight:600; letter-spacing:1.5px; border:2px solid var(--royal-blue); text-transform:uppercase; font-size:13px; position:relative; overflow:hidden; z-index:1; cursor:pointer; }
.location-btn::before,.save-date-btn::before { content:''; position:absolute; top:0; left:0; width:0; height:100%; background:var(--royal-blue); transition:width 0.4s; z-index:-1; }
.location-btn:hover::before,.save-date-btn::before:hover { width:100%; }
.location-btn:hover,.save-date-btn:hover { color:white; transform:translateY(-3px); box-shadow:0 10px 30px rgba(24,51,112,0.3); }

/* =============================================
   RSVP SECTION (homepage boarding pass)
   ============================================= */
.rsvp-section { padding:100px 50px; background:var(--royal-blue); color:white; }
.rsvp-section .section-title { color:white; }
.rsvp-info-container { max-width:1000px; margin:0 auto 60px; }
.rsvp-intro-text { text-align:center; max-width:700px; margin:0 auto 50px; font-size:18px; line-height:1.8; color:var(--light-silver); }
/*.rsvp-details { display:grid; grid-template-columns:1fr; gap:30px; margin:50px 0; text-align:left; }
*/
.rsvp-details {
  display: grid;
  grid-template-columns: repeat(3, 1fr);  /* ← 3 colonne su desktop */
  gap: 30px;
  margin: 50px 0;
  text-align: left;
}

.rsvp-detail-item { flex-direction:column;display:flex; gap:25px; align-items:flex-start; background:rgba(255,255,255,0.05); padding:30px; border-left:4px solid var(--silver); transition:all 0.4s; }
.rsvp-detail-item:hover { background:rgba(255,255,255,0.08); transform:translateY(-5px); }
.detail-icon { margin-bottom:10px; min-width:64px;max-width: 64px; height:64px; background:linear-gradient(135deg,rgba(255,255,255,0.15),rgba(255,255,255,0.08)); border-radius:50%; display:flex; align-items:center; justify-content:center; border:1px solid rgba(255,255,255,0.2); flex-shrink:0; }
.detail-text h4 { font-family:'Cormorant Garamond',serif; font-size:24px; margin-bottom:12px; color:white; }
.detail-text p { line-height:1.7; color:var(--light-silver); font-size:16px; }

/* Boarding pass */
.boarding-pass { max-width:900px; margin:60px auto; background:white; overflow:visible; box-shadow:0 2px 11px 3px rgba(0,0,0,0.3); position:relative; border:1px solid var(--silver); }
.boarding-pass::before { content:''; position:absolute; left:0; right:0; top:71%; height:2px; background:repeating-linear-gradient(90deg,var(--silver) 0,var(--silver) 10px,transparent 10px,transparent 20px); transform:translateY(-50%); z-index:3; }
.boarding-pass::after { content:''; position:absolute; left:-15px; top:71%; width:30px; height:30px; background:var(--royal-blue); border-radius:50%; transform:translateY(-50%);z-index: 5; }
.boarding-pass-notch-right { position:absolute; right:-15px; top:71%; width:30px; height:30px; background:var(--royal-blue); border-radius:50%; transform:translateY(-50%); z-index:5; }
.boarding-header { background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); padding:45px 40px; text-align:center; position:relative; overflow:hidden; }
.boarding-header h3 { font-family:'Cormorant Garamond',serif; font-size:42px; margin-bottom:12px; position:relative; z-index:1; font-weight:400; letter-spacing:3px; color:white; }
.boarding-subtitle { font-size:13px; color:var(--silver); letter-spacing:3px; text-transform:uppercase; position:relative; z-index:1; }
.boarding-body { padding:50px 45px; color:var(--dark-blue); position:relative; z-index:1; }
.qr-scanner { text-align:center; margin-bottom:40px; }
.qr-placeholder { width:220px; height:220px; margin:20px auto; background:linear-gradient(135deg,#f8f9fa,#f0f2f5); border:2px solid var(--royal-blue); border-radius:15px; display:flex; align-items:center; justify-content:center; }
.or-divider { text-align:center; margin:30px 0;margin-bottom:63px; color:var(--silver); font-size:14px; letter-spacing:2px; }
.pnr-input-group { margin:40px 0; }
.pnr-input-group label { display:block; font-size:12px; text-transform:uppercase; letter-spacing:2px; color:var(--royal-blue); margin-bottom:10px; font-weight:600; }
.pnr-input { width:100%; padding:15px 20px; font-size:18px; border:2px solid var(--silver); font-family:'Montserrat',sans-serif; transition:all 0.3s; text-transform:uppercase; letter-spacing:3px; background:white; }
.pnr-input:focus { outline:none; border-color:var(--royal-blue); box-shadow:0 0 0 3px rgba(24,51,112,0.1); }

/* RSVP redirect button (replaces check-in-btn on homepage) */
.check-in-btn { width:100%; padding:18px; background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); color:white; border:none; font-size:15px; font-weight:600; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all 0.4s; }
.check-in-btn:hover { transform:translateY(-2px); box-shadow:0 12px 35px rgba(24,51,112,0.4); }
#qr-fullscreen {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 100vw;
  height: 100vh;
  background: #000;
  z-index: 99999;
  flex-direction: column;
}
#qr-fullscreen.show {
  display: flex;
}

/* Forza il reader a riempire tutto */
#qr-fullscreen .qrBody {
  flex: 1;
  width: 100%;
  position: relative;
  overflow: hidden;
}

#qr-fullscreen #reader {
  width: 100% !important;
  height: 100% !important;
}

/* Forza il video a riempire il contenitore */
#qr-fullscreen #reader video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  position: absolute;
  top: 0;
  left: 0;
}

/* Nascondi elementi inutili di html5-qrcode */
#qr-fullscreen #reader__dashboard {
  display: none !important;
}

#qr-fullscreen #reader__scan_region {
  width: 100% !important;
  height: 100% !important;
}

.qrBody { position: relative; width: 100%; flex: 1; overflow: hidden; }

#qr-result-overlay {
  display: none;
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.85);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: white;
  text-align: center;
  gap: 20px;
  z-index: 20;
}
#qr-result-overlay.show { display: flex; }
#qr-result-icon { font-size: 60px; }
#qr-result-text { font-size: 18px; padding: 0 20px; }
#qr-result-overlay button {
  padding: 12px 30px;
  border: none;
  border-radius: 8px;
  background: white;
  color: black;
  font-size: 16px;
  cursor: pointer;
}

.cameraOptions { display: none; }
.cameraOptions.showOptions { display: block; }
.cameraOption {
  padding: 10px 16px;
  color: white;
  cursor: pointer;
  white-space: nowrap;
  font-size: 14px;
}
.cameraOption:hover { background: rgba(255,255,255,0.1); border-radius: 8px; }

i[data-action='flashlight'].active { color: yellow; }


/* HOME FOOTER */
.footer { background:var(--dark-blue); color:white; padding:80px 50px 40px; }
.footer-content { max-width:1200px; margin:0 auto; text-align:center; }
.gift-section { margin-bottom:50px; }
.gift-section h3 { font-family:'Cormorant Garamond',serif; font-size:32px; margin-bottom:20px; color:var(--silver); }
.gift-section-text { font-size:18px; line-height:1.8; max-width:600px; margin:20px auto; color:var(--light-silver); }
.iban-box { background:linear-gradient(135deg,rgba(255,255,255,0.08),rgba(255,255,255,0.12)); padding:35px 30px; margin:30px auto; max-width:550px; border:1px solid rgba(186,192,198,0.4); border-left:4px solid var(--silver); }
.iban-label { font-size:14px; color:var(--silver); margin-bottom:10px; }
.iban-intestato { font-size:12px; color:var(--silver); margin-top:10px; }
.iban-code { font-size:17px; font-family:'Courier New',monospace; letter-spacing:2px; color:white; margin:15px 0; display:flex; align-items:center; justify-content:center; gap:15px; }
.copy-iban-btn { background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2); padding:8px 12px; border-radius:6px; cursor:pointer; transition:0.3s; display:inline-flex; align-items:center; }
.copy-iban-btn:hover { background:rgba(255,255,255,0.2); transform:scale(1.05); }
.copy-iban-btn svg { width:20px; height:20px; fill:white; }
.footer-love { font-family:'Cormorant Garamond',serif; font-size:24px; margin-top:40px; color:var(--silver); }
.footer-love-heart { font-size:36px; margin:20px 0; display:block; color:var(--silver); font-weight:300; }
.footer-copyright { margin-top:40px; font-size:12px; color:var(--silver); }
.toast { position:fixed; bottom:-100px; left:50%; transform:translateX(-50%); background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); color:white; padding:18px 35px; box-shadow:0 10px 40px rgba(0,0,0,0.3); z-index:9999; transition:bottom 0.4s; font-weight:600; letter-spacing:1px; display:flex; align-items:center; gap:12px; border:1px solid rgba(186,192,198,0.3); }
.toast.show { bottom:40px; }
.toast svg { width:24px; height:24px; fill:white; }
.sound-toggle { position:fixed; bottom:30px; right:30px; width:60px; height:60px; background:var(--royal-blue); border:2px solid var(--silver); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:999; transition:0.3s; }
.sound-toggle:hover { transform:scale(1.1); }
.sound-toggle.muted { background:var(--silver); }

/* =============================================
   LOGIN PAGE
   ============================================= */
.login-page { padding:100px 20px; display:flex; justify-content:center; align-items:center; min-height:80vh; }
.login-card { background:white; padding:50px; border-radius:10px; max-width:400px; width:100%; box-shadow:0 10px 30px rgba(24,51,112,0.2); }
.login-card h2 { font-family:'Cormorant Garamond',serif; font-size:36px; color:var(--royal-blue); text-align:center; margin-bottom:40px; }
.login-error { color:var(--danger); margin-bottom:20px; text-align:center; font-size:14px; }
.login-field { margin-bottom:25px; }
.login-field:last-of-type { margin-bottom:35px; }
.login-label { display:block; font-weight:600; color:var(--dark-blue); margin-bottom:8px; font-size:14px; }
.login-input { width:100%; padding:12px 15px; border:2px solid var(--silver); border-radius:5px; font-size:16px; font-family:'Montserrat',sans-serif; transition:border-color 0.2s; }
.login-input:focus { outline:none; border-color:var(--royal-blue); }
.login-btn { width:100%; padding:15px; background:var(--royal-blue); color:white; font-size:16px; font-weight:600; border:none; cursor:pointer; transition:0.3s; border-radius:5px; font-family:'Montserrat',sans-serif; letter-spacing:1px; }
.login-btn:hover { background:var(--dark-blue); }
.login-footer { text-align:center; margin-top:20px; font-size:14px; color:var(--silver); }

/* =============================================
   ADMIN LAYOUT
   ============================================= */
.admin-layout { display:flex; min-height:100vh; background:#f0f2f5; }
.admin-sidebar { width:240px; background:linear-gradient(180deg,var(--royal-blue) 0%,var(--dark-blue) 100%); padding:30px 0; position:fixed; top:65px; left:0; height:calc(100vh - 65px); overflow-y:auto; z-index:100; box-shadow:2px 0 15px rgba(0,0,0,0.2); }
.admin-sidebar-logo { text-align:center; padding:0 20px 25px; border-bottom:1px solid rgba(255,255,255,0.1); margin-bottom:15px; }
.admin-sidebar-logo h2 { font-family:'Cormorant Garamond',serif; font-size:22px; color:white; margin:0; letter-spacing:1px; }
.admin-sidebar-logo span { font-size:11px; color:var(--silver); letter-spacing:2px; text-transform:uppercase; }
.admin-nav { list-style:none; padding:0 10px; }
.admin-nav-item { margin:3px 0; }
.admin-nav-link { display:flex; align-items:center; gap:10px; padding:10px 14px; color:var(--light-silver); text-decoration:none; font-size:14px; border-radius:7px; transition:all 0.2s; }
.admin-nav-link:hover,.admin-nav-link.active { background:rgba(255,255,255,0.12); color:white; }
.admin-nav-link.active { border-left:3px solid var(--silver); font-weight:600; }
.admin-nav-icon { font-size:17px; width:20px; text-align:center; flex-shrink:0; }
.admin-nav-section { font-size:10px; text-transform:uppercase; letter-spacing:2px; color:rgba(186,192,198,0.45); padding:18px 14px 6px; }
.admin-main { margin-left:240px; margin-top:65px; padding:35px; flex:1; min-height:calc(100vh - 65px); }
.admin-page-header { margin-bottom:30px; display:flex; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; gap:15px; }
.admin-page-header-text h1 { font-family:'Cormorant Garamond',serif; font-size:34px; color:var(--royal-blue); margin-bottom:4px; }
.admin-page-header-text p { font-size:14px; color:#777; }

/* Stats */
.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:28px; }
.stat-card { background:white; padding:20px 22px; border-radius:10px; box-shadow:0 2px 10px rgba(0,0,0,0.05); border-left:4px solid var(--royal-blue); display:flex; align-items:center; gap:16px; }
.stat-card.stat-green { border-left-color:var(--success); }
.stat-card.stat-yellow { border-left-color:var(--warning); }
.stat-card.stat-red { border-left-color:var(--danger); }
.stat-icon { width:44px; height:44px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:20px; background:rgba(24,51,112,0.07); flex-shrink:0; }
.stat-card.stat-green .stat-icon { background:rgba(40,167,69,0.1); }
.stat-card.stat-yellow .stat-icon { background:rgba(230,168,23,0.12); }
.stat-card.stat-red .stat-icon { background:rgba(220,53,69,0.08); }
.stat-info h3 { font-size:26px; font-weight:700; color:var(--dark-blue); line-height:1; }
.stat-info p { font-size:12px; color:#888; margin-top:3px; }

/* Admin Card */
.admin-card { background:white; border-radius:10px; box-shadow:0 2px 10px rgba(0,0,0,0.05); overflow:hidden; }
.admin-card-header { padding:20px 26px; border-bottom:1px solid #eee; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.admin-card-header h2 { font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--royal-blue); }
.admin-card-body { padding:26px; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:7px; padding:9px 18px; font-size:13px; font-weight:600; letter-spacing:0.4px; border:none; border-radius:6px; cursor:pointer; text-decoration:none; transition:all 0.2s; font-family:'Montserrat',sans-serif; }
.btn-primary { background:var(--royal-blue); color:white; }
.btn-primary:hover { background:var(--dark-blue); transform:translateY(-1px); box-shadow:0 6px 18px rgba(24,51,112,0.3); }
.btn-secondary { background:#f0f2f5; color:var(--dark-blue); border:1px solid #ddd; }
.btn-secondary:hover { background:#e4e6ea; }
.btn-danger { background:rgba(220,53,69,0.08); color:var(--danger); border:1px solid rgba(220,53,69,0.2); }
.btn-danger:hover { background:var(--danger); color:white; }
.btn-sm { padding:5px 10px; font-size:12px; }

/* Badges */
.status-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.status-badge .status-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.status-confirmed { background:rgba(40,167,69,0.1); color:#1a7a36; }
.status-confirmed .status-dot { background:var(--success); }
.status-pending { background:rgba(230,168,23,0.12); color:#7a5700; }
.status-pending .status-dot { background:var(--warning); }
.status-declined { background:rgba(220,53,69,0.08); color:#b02a37; }
.status-declined .status-dot { background:var(--danger); }
.role-badge { display:inline-flex; align-items:center; gap:5px; padding:3px 9px; border-radius:12px; font-size:11px; font-weight:600; white-space:nowrap; }
.role-capo { background:rgba(255,193,7,0.15); color:#7a5700; border:1px solid rgba(255,193,7,0.3); }
.role-member { background:rgba(24,51,112,0.08); color:var(--royal-blue); border:1px solid rgba(24,51,112,0.15); }
.role-single { background:#f5f5f5; color:#888; border:1px solid #e0e0e0; }
.pnr-code-pill { font-family:'Courier New',monospace; font-size:13px; font-weight:700; background:rgba(24,51,112,0.07); color:var(--royal-blue); padding:3px 8px; border-radius:5px; letter-spacing:2px; }
.text-muted { color:#bbb; }

/* =============================================
   DATATABLES — left-aligned headers, styled empty state
   ============================================= */
.dataTables_wrapper { font-family:'Montserrat',sans-serif; font-size:13px; }
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select { border:2px solid #e0e4eb; border-radius:6px; padding:5px 8px; font-family:'Montserrat',sans-serif; }
.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_wrapper .dataTables_length select:focus { outline:none; border-color:var(--royal-blue); }
.dataTables_paginate {
  margin-top: 20px;
}
table.dataTable { border-collapse:collapse !important; width:100% !important; }

/* Left-align all headers */
table.dataTable thead th {
    background:#f5f7fa;
    color:var(--dark-blue);
    font-weight:600;
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:0.7px;
    padding:13px 14px;
    border-bottom:2px solid #e0e4eb;
    text-align:left !important;   /* override DataTables default center */
}

/* Also override the DataTables sorting arrow alignment */
table.dataTable thead th.sorting,
table.dataTable thead th.sorting_asc,
table.dataTable thead th.sorting_desc {
    text-align:left !important;
    padding-right:30px;           /* room for sort arrow */
}

table.dataTable tbody td { padding:11px 14px; border-bottom:1px solid #f0f0f0; vertical-align:middle; text-align:left; }
table.dataTable tbody tr:hover { background:#f8f9ff; }
table.dataTable tbody tr:last-child td { border-bottom:none; }

/* Empty-table state — styled to match design, not broken layout */
table.dataTable tbody td.dataTables_empty {
    text-align:center;
    padding:60px 20px;
    color:#aaa;
    font-size:14px;
    font-style:italic;
    background:white;
}

.dataTables_paginate .paginate_button { border-radius:5px !important; border:1px solid #e0e4eb !important; margin:0 2px !important; padding:4px 10px !important; cursor:pointer; }
.dataTables_paginate .paginate_button.current { background:var(--royal-blue) !important; color:white !important; border-color:var(--royal-blue) !important; }
.dataTables_paginate .paginate_button:hover:not(.current) { background:#f0f2f5 !important; color:var(--dark-blue) !important; }

#torchIcon {
    transition: stroke 0.2s ease;
}
/* =============================================
   FORM FIELDS
   ============================================= */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.form-grid.cols-3 { grid-template-columns:1fr 1fr 1fr; }
.form-field { display:flex; flex-direction:column; gap:7px; }
.form-field.full-width { grid-column:1 / -1; }
.form-label { font-size:12px; font-weight:600; color:var(--dark-blue); letter-spacing:0.5px; text-transform:uppercase; }
.form-input,.form-select,.form-textarea { padding:10px 13px; border:2px solid #e0e4eb; border-radius:6px; font-size:14px; font-family:'Montserrat',sans-serif; color:var(--dark-blue); transition:border-color 0.2s, box-shadow 0.2s; background:white; }
.form-input:focus,.form-select:focus,.form-textarea:focus { outline:none; border-color:var(--royal-blue); box-shadow:0 0 0 3px rgba(24,51,112,0.1); }
.form-textarea { resize:vertical; min-height:90px; }
.form-hint { font-size:12px; color:#999; }
.form-actions { display:flex; gap:12px; align-items:center; padding-top:18px; border-top:1px solid #eee; margin-top:10px; flex-wrap:wrap; }
.form-divider { border:none; border-top:1px solid #eee; margin:20px 0; }
.form-meta { background:#f8f9fa; padding:9px 14px; border-radius:6px; font-size:12px; color:#777; margin-top:14px; border:1px solid #eee; }
.form-checkbox-wrapper { padding:9px 0; }
.form-checkbox-label { display:flex; align-items:center; gap:9px; font-size:14px; cursor:pointer; color:var(--dark-blue); }
.form-checkbox-label input[type="checkbox"] { width:17px; height:17px; cursor:pointer; accent-color:var(--royal-blue); }

/* =============================================
   GROUP TYPE SELECTOR
   ============================================= */
.group-type-selector { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:8px; }
.group-type-option { cursor:pointer; }
.group-type-option input[type="radio"] { display:none; }
.group-type-card { display:flex; flex-direction:column; align-items:center; text-align:center; padding:18px 14px; border:2px solid #e0e4eb; border-radius:10px; transition:all 0.22s; background:white; gap:6px; cursor:pointer; min-height:100px; justify-content:center; }
.group-type-card.disabled { opacity:0.4; cursor:not-allowed; }
.group-type-option input:checked + .group-type-card { border-color:var(--royal-blue); background:rgba(24,51,112,0.04); box-shadow:0 0 0 3px rgba(24,51,112,0.1); }
.group-type-option input:not(:disabled):not(:checked) + .group-type-card:hover { border-color:var(--accent-silver); background:#f8f9fa; }
.group-type-icon { font-size:22px; }
.group-type-label { font-size:13px; font-weight:700; color:var(--dark-blue); }
.group-type-desc { font-size:11px; color:#888; line-height:1.4; }
.group-panel { margin-top:14px; padding:18px; background:rgba(24,51,112,0.03); border:1px solid rgba(24,51,112,0.12); border-radius:8px; animation:fadeInUp 0.25s ease; }

/* =============================================
   FLASH MESSAGES & TABLE UTILITIES
   ============================================= */
.flash-message { padding:13px 18px; border-radius:7px; margin-bottom:18px; font-size:14px; font-weight:500; display:flex; align-items:center; gap:9px; }
.flash-success { background:rgba(40,167,69,0.1); color:#1a7a36; border:1px solid rgba(40,167,69,0.25); }
.flash-error { background:rgba(220,53,69,0.08); color:#b02a37; border:1px solid rgba(220,53,69,0.2); }
.table-actions { display:flex; gap:7px; align-items:center; }

/* PNR Banner */
.pnr-banner { background:rgba(24,51,112,0.05); border:1px solid rgba(24,51,112,0.12); border-left:4px solid var(--royal-blue); padding:14px 20px; border-radius:7px; margin-bottom:22px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.pnr-banner-label { font-size:12px; font-weight:600; color:var(--dark-blue); text-transform:uppercase; letter-spacing:0.5px; }
.pnr-banner-code { font-size:18px; font-family:'Courier New',monospace; font-weight:700; color:var(--royal-blue); background:white; padding:3px 10px; border-radius:5px; border:1px solid rgba(24,51,112,0.2); letter-spacing:4px; }
.pnr-banner-hint { font-size:13px; color:#888; }

/* =============================================
   PUBLIC RSVP PAGE
   ============================================= */
.rsvp-public-page { min-height:100vh; background:#f4f5f8; }
.rsvp-public-hero { background:linear-gradient(135deg,var(--royal-blue) 0%,var(--dark-blue) 100%); padding:70px 24px 60px; text-align:center; position:relative; overflow:hidden; }
.rsvp-public-hero::before { content:''; position:absolute; inset:0; background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 300"><path d="M0,150 Q300,50 600,150 T1200,150" fill="none" stroke="rgba(186,192,198,0.15)" stroke-width="2"/></svg>'); background-size:cover; }
.rsvp-hero-confirmed { background:linear-gradient(135deg,#1a6632 0%,#0d3d1f 100%); }
.rsvp-public-hero-content { position:relative; z-index:1; color:white; animation:fadeInUp 0.8s ease; }
.rsvp-confirmed-icon { font-size:64px; margin-bottom:16px; }
.rsvp-public-date { font-size:13px; letter-spacing:4px; color:var(--light-silver); margin-bottom:10px; text-transform:uppercase; }
.rsvp-public-title { font-family:'Cormorant Garamond',serif; font-size:52px; font-weight:300; letter-spacing:4px; margin-bottom:14px; }
.rsvp-public-subtitle { font-size:17px; color:var(--light-silver); font-weight:300; }
.rsvp-public-subtitle strong { color:white; }
.rsvp-public-body { max-width:680px; margin:0 auto; padding:36px 20px 60px; }
.rsvp-public-intro { background:white; border-radius:12px; padding:22px 24px; margin-bottom:28px; font-size:15px; line-height:1.7; color:#555; box-shadow:0 2px 10px rgba(0,0,0,0.05); border-left:4px solid var(--royal-blue); }
.rsvp-guest-card { background:white; border-radius:14px; padding:26px; margin-bottom:20px; box-shadow:0 2px 14px rgba(0,0,0,0.07); border:1px solid #eaecf0; }
.rsvp-guest-header { display:flex; align-items:center; gap:14px; margin-bottom:22px; flex-wrap:wrap; }
.rsvp-guest-avatar { width:48px; height:48px; border-radius:50%; flex-shrink:0; background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); color:white; font-size:16px; font-weight:700; display:flex; align-items:center; justify-content:center; letter-spacing:1px; }
.rsvp-avatar-sm { width:36px; height:36px; font-size:13px; }
.rsvp-guest-identity { flex:1; min-width:0; }
.rsvp-guest-name { font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--dark-blue); margin-bottom:2px; }
.rsvp-guest-group { font-size:12px; color:#888; }
.rsvp-status-badge { margin-left:auto; flex-shrink:0; }
.rsvp-field-group { margin-bottom:18px; }
.rsvp-field-label { display:block; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--dark-blue); margin-bottom:10px; }
.rsvp-attendance-btns { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.rsvp-attend-option { cursor:pointer; }
.rsvp-attend-option input { display:none; }
.rsvp-attend-label { display:flex; align-items:center; gap:10px; padding:14px 16px; border:2px solid #e0e4eb; border-radius:10px; font-size:14px; font-weight:600; transition:all 0.2s; background:white; cursor:pointer; }
.rsvp-attend-icon { font-size:20px; }
.rsvp-attend-si input:checked + .rsvp-attend-label { border-color:var(--success); background:rgba(40,167,69,0.06); color:#1a7a36; }
.rsvp-attend-no input:checked + .rsvp-attend-label { border-color:var(--danger); background:rgba(220,53,69,0.05); color:#b02a37; }
.rsvp-attend-option input:not(:checked) + .rsvp-attend-label:hover { border-color:var(--accent-silver); background:#f8f9fa; }
.rsvp-textarea { width:100%; padding:10px 13px; border:2px solid #e0e4eb; border-radius:8px; font-size:14px; font-family:'Montserrat',sans-serif; min-height:70px; resize:vertical; transition:border-color 0.2s; }
.rsvp-textarea:focus { outline:none; border-color:var(--royal-blue); box-shadow:0 0 0 3px rgba(24,51,112,0.1); }
.rsvp-public-submit-area { text-align:center; margin-top:30px; }
.rsvp-public-deadline { font-size:13px; color:#888; margin-bottom:18px; }
.rsvp-public-submit-btn { display:inline-block; width:100%; padding:18px; background:linear-gradient(135deg,var(--royal-blue),var(--dark-blue)); color:white; border:none; border-radius:12px; font-size:16px; font-weight:700; letter-spacing:1px; cursor:pointer; transition:all 0.3s; font-family:'Montserrat',sans-serif; text-align:center; }
.rsvp-public-submit-btn:hover { transform:translateY(-2px); box-shadow:0 12px 35px rgba(24,51,112,0.35); }
.rsvp-confirm-summary { background:white; border-radius:14px; padding:32px 28px; box-shadow:0 2px 14px rgba(0,0,0,0.07); text-align:center; }
.rsvp-confirm-group { font-family:'Cormorant Garamond',serif; font-size:30px; color:var(--royal-blue); margin-bottom:10px; }
.rsvp-confirm-msg { font-size:16px; color:#555; margin-bottom:28px; line-height:1.6; }
.rsvp-confirm-list { margin:24px 0; display:flex; flex-direction:column; gap:12px; }
.rsvp-confirm-item { display:flex; align-items:center; gap:14px; padding:14px 16px; background:#f8f9fa; border-radius:10px; text-align:left; }
.rsvp-confirm-item-text { display:flex; flex-direction:column; gap:5px; flex:1; }
.rsvp-confirm-item-text strong { font-size:15px; }
.rsvp-confirm-info { display:flex; flex-direction:column; gap:14px; margin:24px 0; text-align:left; }
.rsvp-confirm-info-item { display:flex; gap:14px; align-items:flex-start; padding:14px; background:rgba(24,51,112,0.04); border-radius:10px; font-size:13px; line-height:1.6; color:#555; }
.rsvp-confirm-info-icon { font-size:22px; flex-shrink:0; }
.rsvp-confirm-pnr { margin-top:20px; font-size:13px; color:#888; line-height:1.7; }
.rsvp-confirm-pnr code { font-family:'Courier New',monospace; font-weight:700; color:var(--royal-blue); font-size:15px; letter-spacing:3px; }
    .boarding-pass {
    border-radius: 12px;
}
.boarding-header {
    border-radius: 12px 12px 0 0;
}
#reader #qr-shaded-region {
    display: block !important;
}

#reader > div#qr-shaded-region ~ canvas { display: none !important; }
#reader > div#qr-shaded-region ~ div#qr-shaded-region { display: none !important; }
#reader > video ~ video { display: none !important; }
#reader canvas {
    display: none !important;
}

#reader__dashboard,
#reader__dashboard_section,
#reader__status_span,
#reader__camera_permission_button {
    display: none !important;
}
/* =============================================
   RESPONSIVE
   ============================================= */
@media (min-width:1025px) {
    .top-nav { display:flex; }
    .mobile-menu-toggle { display:none; }
    .side-nav { display:none; }
    .site-main { padding-top:65px; }
}

@media (max-width:1024px) {

    .top-nav { display:none; }
    .admin-sidebar { top:0; height:100vh; }
    .admin-main { margin-left:0; margin-top:70px; padding:20px 16px; }
    .admin-stats { grid-template-columns:repeat(2,1fr); }
    .form-grid,.form-grid.cols-3 { grid-template-columns:1fr; }
    .group-type-selector { grid-template-columns:1fr; }
    .hero-title { font-size:48px; letter-spacing:4px; }
    .hero-ampersand { font-size:36px; }
    .section-title { font-size:36px; }
    .countdown-timer { gap:16px; }
    .countdown-item { min-width:110px; padding:24px 16px; }
    .countdown-number { font-size:38px; }
    .event-content { grid-template-columns:1fr; gap:30px; padding:0 24px; }
    .countdown,.event-section,.our-story,.save-date-banner,.rsvp-section,.footer { padding:60px 24px; }
    .rsvp-detail-item { flex-direction:column; text-align:center; padding:20px; }
    .detail-icon { margin:0 auto; }
    .iban-code { flex-direction:column; gap:10px; }
    .toast { left:16px; right:16px; transform:none; font-size:13px; }
    .toast.show { bottom:16px; }
    .boarding-pass { margin:30px 16px; }
    .boarding-header { padding:30px 20px; }


    .boarding-header h3 { font-size:28px; }
    .boarding-body { padding:28px 20px; }
    .admin-stats { grid-template-columns:1fr 1fr; }
    .admin-page-header { flex-direction:column; }
    .rsvp-public-title { font-size:36px; }
    .rsvp-attendance-btns { grid-template-columns:1fr; }
    .rsvp-guest-header { flex-wrap:wrap; }
    .rsvp-status-badge { margin-left:0; }
    .pnr-banner { flex-direction:column; align-items:flex-start; gap:8px; }
    .group-type-selector { grid-template-columns:1fr; }
    .event-content {
        display: flex !important;
        flex-direction: column !important;
    }
    .event-content .event-visual {
        order: -1 !important;
              min-height: 280px !important;
        width: 100% !important;
        background-size: cover !important;
        background-position: center !important;
        display: block !important;
    }
       .rsvp-details {
        grid-template-columns: 1fr !important;
    }


  .boarding-pass {
        border-radius: 12px;
        margin: 30px 12px;
        /* overflow visible per far uscire i notch */
        overflow: visible;
    }

    .boarding-pass::before {
        display: block !important; /* forza visibile */
        left: 0;
        right: 0;
        z-index:2
    }

    .boarding-pass::after {
        display: block !important;
        width: 22px;
        height: 22px;
        left: -11px;
        z-index:2;
    }

    .boarding-pass-notch-right {
        display: block !important;
        width: 22px;
        height: 22px;
        right: -11px;
    }


}
@media (max-width:480px) {
    .admin-stats { grid-template-columns:1fr; }
    .admin-main { padding:14px; }
    .rsvp-public-title { font-size:28px; }
    .boarding-pass::before,.boarding-pass::after,.boarding-pass-notch-right { display:none; }
}
@media (prefers-color-scheme: dark) {

    html, body {
        background-color: #f0f2f5 !important;
        color: rgb(18, 38, 84) !important;
    }

    /* NON mettere background su .boarding-pass direttamente —
       i notch e il tratteggio hanno bisogno di overflow:visible.
       Forza il bianco solo su header e body interni. */
    .boarding-pass {
        background: transparent !important;
        /* Il colore del ticket lo danno header e body */
    }

    .boarding-header {
        background: linear-gradient(135deg, rgb(24,51,112), rgb(18,38,84)) !important;
        color: white !important;
        border-radius: 12px 12px 0 0 !important;
    }

    .boarding-body {
        background: white !important;
        color: rgb(18, 38, 84) !important;
        border-radius: 12px !important;
    }

    /* I notch devono restare del colore della sezione RSVP
       (royal-blue) per creare l'effetto punch-out */
    .boarding-pass::after,
    .boarding-pass-notch-right {
        background: rgb(24, 51, 112) !important;
    }
    /* Testi bianchi su sfondi scuri — forzati esplicitamente */
    .hero,
    .save-date-banner,
    .countdown-item,
    .rsvp-section,
    .footer,
    .boarding-header,
    #qr-fullscreen,
    .nav-links a,
    .side-nav,
    .top-nav {
        color: white !important;
    }

    /* Sfondi sezioni scure — forza il gradiente originale */
    .hero {
        background: linear-gradient(135deg, rgb(24,51,112) 0%, rgb(18,38,84) 50%, rgb(24,51,112) 100%) !important;
    }
    .save-date-banner {
        background: linear-gradient(135deg, rgb(18,38,84), rgb(24,51,112)) !important;
    }
    .rsvp-section {
        background: rgb(24, 51, 112) !important;
    }
    .footer {
        background: rgb(18, 38, 84) !important;
    }
    .boarding-header {
        background: linear-gradient(135deg, rgb(24,51,112), rgb(18,38,84)) !important;
        color: white !important;
    }
    .countdown-item {
        background: linear-gradient(135deg, rgb(24,51,112), rgb(18,38,84)) !important;
    }
    .side-nav {
        background: linear-gradient(135deg, rgb(24,51,112) 0%, rgb(18,38,84) 100%) !important;
    }
    .top-nav {
        background: rgba(18,38,84,0.96) !important;
    }

    /* Sezioni bianche — forza bianco */
    .countdown,
    .our-story,
    .event-section,
    .boarding-pass,
    .boarding-body {
        background: white !important;
        color: rgb(18, 38, 84) !important;
    }

    /* Testi dentro il boarding body */
    .boarding-body h4,
    .boarding-body label,
    .boarding-body p,
    .pnr-input-group label,
    .or-divider,
    .qr-scanner-title {
        color: rgb(18, 38, 84) !important;
    }

    /* Input */
    .pnr-input {
        background: white !important;
        color: rgb(18, 38, 84) !important;
        border-color: rgb(186, 192, 198) !important;
    }

    /* Testi silver/light nelle sezioni scure */
    .hero-date,
    .boarding-subtitle,
    .countdown-label,
    .rsvp-detail-item p,
    .detail-text p,
    .save-date-content p {
        color: rgb(220, 224, 228) !important;
    }

    /* Story e event sections */
    .story-preview p,
    .event-text p,
    .event-text h3 {
        color: inherit !important;
    }
    .event-text h3 {
        color: rgb(24, 51, 112) !important;
    }
}

.buttonScanner {
    padding-bottom: max(24px, env(safe-area-inset-bottom)) !important;
}

#qr-fullscreen {
    padding-bottom: env(safe-area-inset-bottom);
}
.buttonScanner {
    padding-bottom: 60px !important;
}
