/* ═══════════════════════════════════════════════════
   SHARED PREMIUM STYLES — inclus în toate template-urile
   ═══════════════════════════════════════════════════ */

/* ── Mobile touch improvements ── */
button, a, [onclick] {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
@media (hover: none) {
  .btn-fullscreen:hover,
  .btn-copy-link:hover,
  .btn-qr:hover,
  .reaction-btn:hover { transform: none; }
}

/* ── Fullscreen button ── */
.btn-fullscreen {
  position: fixed; bottom: 20px; left: 20px; z-index: 200;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.15);
  border: 1.5px solid rgba(255,255,255,0.25);
  color: rgba(255,255,255,0.7);
  font-size: 1.1rem; cursor: pointer;
  backdrop-filter: blur(6px);
  transition: background .2s, transform .2s;
  display: flex; align-items: center; justify-content: center;
}
.btn-fullscreen:hover { background: rgba(255,255,255,0.3); transform: scale(1.1); }
body.dark-bg .btn-fullscreen { color: rgba(255,255,255,0.6); }
body:not(.dark-bg) .btn-fullscreen {
  background: rgba(0,0,0,0.08);
  border-color: rgba(0,0,0,0.15);
  color: rgba(0,0,0,0.5);
}

/* ── WhatsApp Share button ── */
.btn-whatsapp {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 16px;
  background: #25D366; color: #fff;
  border: none; border-radius: 50px;
  padding: 12px 28px; font-size: .95rem;
  font-family: 'Lato', sans-serif; cursor: pointer;
  box-shadow: 0 4px 16px rgba(37,211,102,.35);
  transition: transform .15s, box-shadow .2s;
}
.btn-whatsapp:hover { transform: translateY(-2px); box-shadow: 0 6px 22px rgba(37,211,102,.45); }

/* ── Skeleton loading galerie ── */
.gallery-grid img.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Fallback secțiune lipsă ── */
.section-hidden { display: none !important; }

/* ── EmailJS notice ── */
.emailjs-note {
  font-size: .75rem; color: #aaa; margin-top: 8px; font-style: italic;
}

/* ── Demo Banner ── */
.demo-banner {
  position: fixed; bottom: 72px; right: 20px; z-index: 500;
  display: flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, #0f0c29, #302b63);
  color: #fff; text-decoration: none;
  border: 1px solid rgba(255,255,255,.12); border-radius: 50px;
  padding: 9px 16px 9px 12px;
  font-family: 'Lato', sans-serif; font-size: .8rem; letter-spacing: .2px;
  box-shadow: 0 4px 20px rgba(0,0,0,.35);
  transition: transform .2s, box-shadow .2s;
}
.demo-banner:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 8px 28px rgba(0,0,0,.45); }
.demo-dot { width: 7px; height: 7px; background: #ff4757; border-radius: 50%; flex-shrink: 0; animation: demoDotPulse 1.4s ease-in-out infinite; }
.demo-text { color: rgba(255,255,255,.55); font-size: .72rem; letter-spacing: 1px; text-transform: uppercase; }
.demo-sep { color: rgba(255,255,255,.2); margin: 0 2px; }
.demo-cta { font-weight: 700; color: #fff; font-size: .82rem; }
@keyframes demoDotPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.7)} }

/* ── Typing cursor ── */
.typing-cursor {
  display: inline-block; width: 2px; height: 1.1em;
  background: var(--gold, #c9963d);
  margin-left: 2px; vertical-align: text-bottom;
  animation: blink .7s step-end infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ── Photo placeholder ── */
img.photo-placeholder { opacity: .9 !important; cursor: default !important; }

/* ── Preloader ── */
#preloader {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--cream, #fdfaf5);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .6s ease;
}
#preloader.fade-out { opacity: 0; pointer-events: none; }
.preloader-inner { text-align: center; }
.preloader-icon { font-size: 3.5rem; display: block; animation: preloaderFloat 1.2s ease-in-out infinite; margin-bottom: 20px; }
@keyframes preloaderFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.preloader-bar { width: 100px; height: 3px; background: rgba(0,0,0,.08); border-radius: 2px; margin: 0 auto; overflow: hidden; }
.preloader-fill { height: 100%; background: var(--gold, #c9963d); border-radius: 2px; animation: preloaderFill 1.4s cubic-bezier(.4,0,.2,1) forwards; width: 0; }
@keyframes preloaderFill { to { width: 100%; } }

/* ── Progress dots ── */
#progressDots {
  position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%);
  display: none; gap: 7px; align-items: center; z-index: 100; pointer-events: none;
}
#progressDots.visible { display: flex; }
.prog-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(0,0,0,.15); transition: all .3s ease; }
.prog-dot.active { background: var(--gold, #c9963d); transform: scale(1.5); }

/* ── Creator credit ── */
.creator-credit {
  position: fixed; bottom: 7px; right: 64px; z-index: 100;
  font-size: .6rem; color: rgba(0,0,0,.2); pointer-events: none;
  font-family: 'Lato', sans-serif; letter-spacing: .8px; text-transform: uppercase;
  white-space: nowrap;
}

/* ── Brand watermark ── */
.cd-watermark {
  position: fixed; bottom: 8px; left: 50%; transform: translateX(-50%);
  z-index: 100; display: flex; align-items: center; gap: 5px;
  font-family: 'Lato', sans-serif; font-size: .6rem; letter-spacing: 1.5px;
  text-transform: uppercase; color: rgba(0,0,0,.18); text-decoration: none;
  pointer-events: auto; white-space: nowrap;
  transition: color .25s, opacity .25s; opacity: .7;
}
.cd-watermark:hover { color: rgba(201,150,61,.8); opacity: 1; }
.cd-watermark svg { flex-shrink: 0; opacity: .7; }

/* ── Preloader logo ── */
.preloader-logo {
  display: block; margin: 0 auto 10px;
  opacity: .45; animation: preloaderLogoFade 1.2s ease-in-out infinite alternate;
}
@keyframes preloaderLogoFade { from{opacity:.3} to{opacity:.6} }

/* ── Copy link button ── */
.btn-copy-link {
  position: fixed; top: 20px; right: 74px; z-index: 100;
  width: 46px; height: 46px; border-radius: 50%;
  background: rgba(201,150,61,.9); border: none; color: #fff;
  font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform .2s, background .2s;
}
.btn-copy-link:hover { transform: scale(1.1); background: var(--gold, #c9963d); }
.btn-copy-link.hidden { display: none !important; }

/* ── Toast notification ── */
.toast-notification {
  position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%) translateY(10px);
  background: rgba(26,26,22,.9); color: #fff; border-radius: 50px;
  padding: 10px 24px; font-size: .88rem; font-family: 'Lato', sans-serif;
  z-index: 9000; opacity: 0; transition: opacity .25s, transform .25s;
  pointer-events: none; white-space: nowrap;
}
.toast-notification.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── QR Button ── */
.btn-qr { position:fixed; top:20px; right:128px; z-index:100; width:46px; height:46px; border-radius:50%; background:rgba(26,26,22,.85); border:none; color:#fff; font-size:1.1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform .2s; }
.btn-qr:hover { transform:scale(1.1); }
.btn-qr.hidden { display:none!important; }
.qr-modal { position:fixed; inset:0; z-index:9000; background:rgba(0,0,0,.65); display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.qr-modal.hidden { display:none!important; }
.qr-box { background:#fff; border-radius:20px; padding:32px; text-align:center; position:relative; max-width:280px; box-shadow:0 20px 60px rgba(0,0,0,.3); }
.qr-close { position:absolute; top:12px; right:12px; background:#f0f0f0; border:none; border-radius:50%; width:28px; height:28px; cursor:pointer; font-size:.8rem; }
.qr-title { font-family:"Cormorant Garamond",serif; font-size:1.2rem; color:#1a1a16; margin-bottom:16px; font-weight:600; }
#qrCanvas { display:flex; justify-content:center; margin-bottom:12px; }
.qr-hint { font-size:.75rem; color:#aaa; margin-bottom:14px; line-height:1.5; }
.qr-download { background:var(--gold,#c9963d); color:#fff; border:none; border-radius:50px; padding:9px 22px; font-size:.85rem; cursor:pointer; font-family:"Lato",sans-serif; font-weight:700; transition:transform .15s; }
.qr-download:hover { transform:translateY(-2px); }

/* ── Emoji Reactions ── */
.reaction-bar {
  position: fixed; right: 0; bottom: calc(50% + 40px);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: rgba(255,255,255,.96); backdrop-filter: blur(8px);
  border-radius: 14px 0 0 14px; padding: 10px 7px;
  box-shadow: -4px 0 20px rgba(0,0,0,.12); z-index: 200;
  border: 1px solid rgba(0,0,0,.06); border-right: none;
  transition: opacity .3s, transform .3s;
}
.reaction-bar.hidden { opacity: 0; pointer-events: none; transform: translateX(20px); }
.reaction-label { font-size: .55rem; color: #bbb; writing-mode: vertical-rl; letter-spacing: .8px; text-transform: uppercase; margin-bottom: 4px; }
.reaction-btn { background: none; border: none; font-size: 1.4rem; cursor: pointer; padding: 4px 2px; border-radius: 8px; transition: transform .15s, background .15s; line-height: 1; }
.reaction-btn:hover { transform: scale(1.3); background: rgba(0,0,0,.05); }

/* ── Presence Indicator ── */
.presence-indicator {
  position: fixed; top: 76px; left: 50%;
  transform: translateX(-50%) translateY(-10px);
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border-radius: 50px; padding: 9px 20px;
  box-shadow: 0 4px 24px rgba(0,0,0,.12);
  z-index: 300; font-family: 'Lato', sans-serif;
  font-size: .82rem; color: #444;
  opacity: 0; transition: opacity .7s, transform .7s;
  pointer-events: none; white-space: nowrap;
  border: 1px solid rgba(0,0,0,.06);
}
.presence-indicator.visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.presence-dot { width: 8px; height: 8px; background: #25D366; border-radius: 50%; flex-shrink: 0; animation: presencePulse 1.6s ease-in-out infinite; }
@keyframes presencePulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.6);opacity:.4} }

/* ── Reaction Endings ── */
@keyframes rxIn { from{opacity:0;transform:scale(.9)} to{opacity:1;transform:scale(1)} }
@keyframes rxEmoji { 0%{transform:scale(0) rotate(-180deg)} 55%{transform:scale(1.35)} 100%{transform:scale(1)} }
@keyframes rxPart { 0%{opacity:.9;transform:translateY(0) rotate(0deg)} 100%{opacity:0;transform:translateY(-85vh) rotate(30deg)} }
