/* =====================================================
   Social Share Pro — Frontend Styles
   ===================================================== */

:root {
  --ssp-primary: #1a1a2e;
  --ssp-accent:  #e94560;
  --ssp-radius:  12px;
  --ssp-gap:     8px;
}

.ssp-share-wrapper {
  margin: 2em 0;
  padding: 1.5em;
  background: linear-gradient(135deg, color-mix(in srgb, var(--ssp-primary) 6%, white), color-mix(in srgb, var(--ssp-accent) 4%, white));
  border: 1px solid color-mix(in srgb, var(--ssp-primary) 12%, white);
  border-radius: var(--ssp-radius);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.ssp-share-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ssp-primary);
  opacity: 0.5;
  margin-bottom: 1em;
}

/* --- Preview card --- */
.ssp-share-preview {
  display: flex;
  align-items: center;
  gap: 1em;
  margin-bottom: 1.25em;
  padding-bottom: 1.25em;
  border-bottom: 1px solid color-mix(in srgb, var(--ssp-primary) 8%, white);
}

.ssp-preview-image {
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.ssp-preview-text {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  min-width: 0;
}

.ssp-preview-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ssp-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ssp-preview-excerpt {
  font-size: 0.8rem;
  color: color-mix(in srgb, var(--ssp-primary) 60%, white);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* --- Buttons row --- */
.ssp-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ssp-gap);
}

.ssp-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  font-family: inherit;
  font-weight: 600;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
  white-space: nowrap;
  background-color: var(--btn-color, var(--ssp-primary));
  color: #fff;
}

.ssp-btn:hover {
  opacity: 0.88;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--btn-color, var(--ssp-primary)) 35%, transparent);
  color: #fff;
  text-decoration: none;
}

.ssp-btn:active {
  transform: translateY(0);
}

.ssp-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ssp-icon svg {
  fill: currentColor;
}

/* copy button */
.ssp-btn-copy {
  --btn-color: var(--ssp-primary);
  background: transparent;
  border: 2px solid color-mix(in srgb, var(--ssp-primary) 20%, transparent);
  color: var(--ssp-primary);
}
.ssp-btn-copy:hover {
  background: var(--ssp-primary);
  color: #fff;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--ssp-primary) 25%, transparent);
}
.ssp-btn-copy.ssp-copied {
  --btn-color: #22c55e;
  border-color: #22c55e;
  color: #22c55e;
}

/* ===================== STYLES ===================== */

/* Rounded (default) */
.ssp-style-rounded .ssp-btn { border-radius: 10px; }

/* Square */
.ssp-style-square .ssp-btn { border-radius: 4px; }

/* Pill */
.ssp-style-pill .ssp-btn { border-radius: 999px; }

/* Minimal — outlined */
.ssp-style-minimal .ssp-btn {
  background: transparent;
  border: 2px solid var(--btn-color, var(--ssp-primary));
  color: var(--btn-color, var(--ssp-primary));
  border-radius: 8px;
}
.ssp-style-minimal .ssp-btn:hover {
  background: var(--btn-color, var(--ssp-primary));
  color: #fff;
}

/* Floating — icon only, elevated */
.ssp-style-floating .ssp-btn {
  border-radius: 50%;
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
}
.ssp-style-floating .ssp-label { display: none; }
.ssp-style-floating .ssp-btn:hover {
  transform: translateY(-3px) scale(1.05);
}

/* ===================== SIZES ===================== */
.ssp-size-small .ssp-btn  { padding: 6px 10px; font-size: 0.75rem; }
.ssp-size-small .ssp-icon svg { width: 14px; height: 14px; }
.ssp-size-small.ssp-style-floating .ssp-btn { padding: 9px; }

.ssp-size-medium .ssp-btn { padding: 9px 14px; font-size: 0.82rem; }
.ssp-size-medium .ssp-icon svg { width: 17px; height: 17px; }
.ssp-size-medium.ssp-style-floating .ssp-btn { padding: 12px; }

.ssp-size-large .ssp-btn  { padding: 12px 20px; font-size: 0.9rem; }
.ssp-size-large .ssp-icon svg { width: 20px; height: 20px; }
.ssp-size-large.ssp-style-floating .ssp-btn { padding: 15px; }

/* ===================== RESPONSIVE ===================== */
@media (max-width: 480px) {
  .ssp-share-wrapper { padding: 1em; }
  .ssp-preview-image { width: 54px; height: 54px; }
  .ssp-preview-title { font-size: 0.85rem; }
  .ssp-btn .ssp-label { display: none; }
  .ssp-btn { padding: 9px !important; border-radius: 50% !important; }
}

/* =====================================================
   Counters
   ===================================================== */

.ssp-btn-wrap {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.ssp-count {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--ssp-primary) 55%, white);
  letter-spacing: 0.03em;
  text-align: center;
  min-width: 24px;
  transition: transform 0.2s ease, color 0.2s ease;
  line-height: 1;
}

/* Hide counter section when not enabled */
.ssp-buttons:not(:has(.ssp-count)) .ssp-btn-wrap {
  flex-direction: row;
}

/* Bump animation when count increases */
@keyframes ssp-bump {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.35); color: var(--ssp-accent); }
  100% { transform: scale(1); }
}

.ssp-count-bump {
  animation: ssp-bump 0.35s ease;
}

/* Zero counts slightly dimmer */
.ssp-count:empty,
.ssp-count[data-zero="true"] {
  opacity: 0.35;
}
