/* DC Sync — Frontend Styles
   Exact match of Gestionale card design
   Font: "Assistant", Sans-serif
   No progress bar
*/
@import url('https://fonts.googleapis.com/css2?family=Assistant:wght@400;500;600;700;800&display=swap');

/* =========== GRID =========== */
.dc-grid {
  display: grid;
  gap: 24px;
  margin: 0 auto;
  font-family: 'Assistant', sans-serif;
}
.dc-grid-1 { grid-template-columns: 1fr; }
.dc-grid-2 { grid-template-columns: repeat(2, 1fr); }
.dc-grid-3 { grid-template-columns: repeat(3, 1fr); }
.dc-grid-4 { grid-template-columns: repeat(4, 1fr); }
.dc-grid-5 { grid-template-columns: repeat(5, 1fr); }

.dc-empty { text-align: center; padding: 40px; color: #888; font-family: 'Assistant', sans-serif; }

/* =========== CARD =========== */
.dc-card,
.dc-card:link,
.dc-card:visited,
.dc-card:hover,
.dc-card:active,
.dc-card *  {
  text-decoration: none !important;
}
.dc-card {
  display: flex;
  flex-direction: column;
  color: inherit;
  background: #fff !important;
  border: 15px solid #fff;
  border-radius: 0;
  overflow: hidden;
  transition: background 0.3s, border 0.3s, box-shadow 0.3s;
  cursor: pointer;
  box-shadow: 0 0 10px 0 rgba(0,0,0,0.5) !important;
}
.dc-card:hover {
  box-shadow: 0 0 10px 0 rgba(0,0,0,0.6) !important;
  color: inherit;
}

/* =========== CARD IMAGE =========== */
.dc-card-image {
  position: relative !important;
  width: 100%;
  height: 300px;
  background: #1a1a1a;
  overflow: hidden;
  border-radius: 0;
}
.dc-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block;
}
/* Gradient overlay */
.dc-card-overlay {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  padding: 20px 20px 18px !important;
  background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.55) 50%, transparent 100%) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  height: 100% !important;
  box-sizing: border-box !important;
}
.dc-card-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ccc;
}
.dc-card-placeholder svg { width: 48px; height: 48px; }

/* =========== BADGE =========== */
.dc-card-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 7px 18px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #fff;
  font-family: 'Assistant', sans-serif;
  z-index: 3;
  border: 2px solid #fff;
}
.dc-badge-vendita { background: #15BC00; }
.dc-badge-sold { background: #d61116; }
.dc-badge-successi { background: #0ea5e9; }
/* Etichetta badges */
.dc-etichetta-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #fff;
  font-family: 'Assistant', sans-serif;
}
.dc-etichetta-in_costruzione { background: #f59e0b; }
.dc-etichetta-completato     { background: #16a34a; }
.dc-etichetta-in_attesa      { background: #6b7280; }
.dc-etichetta-urgente        { background: #dc2626; }
.dc-etichetta-da_confermare  { background: #0ea5e9; }
.dc-etichetta-annullato      { background: #991b1b; }

/* =========== RIBBON (Sold Out / Consegnato) =========== */
.dc-ribbon {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 2;
}
.dc-ribbon span {
  position: absolute;
  top: 28px;
  left: -40px;
  width: 180px;
  padding: 6px 0;
  text-align: center;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #fff;
  transform: rotate(-45deg);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
  font-family: 'Assistant', sans-serif;
}
.dc-ribbon-sold span { background: #d61116; }
.dc-ribbon-successi span { background: #0ea5e9; }

/* =========== CARD BODY (stats only) =========== */
.dc-card-body {
  padding: 0;
  display: flex;
  flex-direction: column;
  flex: 1;
}
/* Overlay header: logo above title */
.dc-card-header {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 10px;
}
img.dc-card-logo,
.dc-card-overlay img.dc-card-logo,
.dc-card img.dc-card-logo {
  width: 60px !important;
  max-width: 60px !important;
  height: auto !important;
  max-height: 40px !important;
  object-fit: contain !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
  display: block !important;
}
.dc-card-header-text {
  min-width: 0;
}
.dc-card-title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.2px;
  color: #fff;
  font-family: 'Assistant', sans-serif;
  line-height: 1.25;
}
.dc-card-location {
  font-size: 16px;
  color: rgba(255,255,255,1);
  font-family: 'Assistant', sans-serif;
  margin-top: 3px;
  text-transform: capitalize !important;
}
/* CTA button over image */
.dc-card-cta {
  display: block;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background: rgba(214, 17, 22, 0.3);
  border: 2px solid #d61116;
  font-family: 'Assistant', sans-serif;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  padding: 10px 0;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
}
.dc-card:hover .dc-card-cta { background: #d61116; color: #fff; }

img.dc-card-ribbon-img, .dc-card-image img.dc-card-ribbon-img, .dc-card img.dc-card-ribbon-img {
    position: absolute !important;
    left: 0px !important;
    top: 0px !important;
    transform: none !important;
    width: 130px !important;
    height: 130px !important;
    max-width: 130px !important;
    max-height: 130px !important;
    object-fit: contain !important;
    z-index: 4 !important;
    filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.3));
    pointer-events: none;
}

/* Hide mini gallery inside carousel — only show in grid */
.dc-cl .dc-mini-gal { display: none !important; }

/* =========== MINI GALLERY (inside card) =========== */
.dc-mini-gal {
  position: relative;
  overflow: hidden;
  background: #f5f5f5;
  height: 70px;
}
.dc-mini-gal-track {
  display: flex;
  transition: transform 0.35s ease;
  cursor: grab;
  user-select: none;
}
.dc-mini-gal-item {
  flex: 0 0 calc(100% / 3);
  max-width: calc(100% / 3);
  padding: 2px;
  box-sizing: border-box;
  overflow: hidden;
}
.dc-mini-gal-item img {
  width: 100% !important;
  height: 70px !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  border-radius: 0;
  max-height: 70px !important;
  min-height: 70px !important;
}
.dc-mini-gal-btn { display: none !important; }

/* =========== STATS GRID =========== */
.dc-card-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  font-family: 'Assistant', sans-serif;
}
.dc-stat-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  font-size: 14px;
  color: #333;
}
.dc-stat-ico-wrap {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.dc-stat-ico {
  width: 16px;
  height: 16px;
  color: #333;
}
.dc-stat-label {
  font-size: 16px;
  color: #333;
  font-weight: 700;
  white-space: nowrap;
}
.dc-stat-value {
  font-size: 15px;
  font-weight: 800;
  color: #d61116;
}

/* =========== PROGRESS BAR =========== */
.dc-progress-wrap {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #f0f0f0;
  font-family: 'Assistant', sans-serif;
}
.dc-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 6px;
  overflow: hidden;
}
.dc-progress-label {
  font-size: 11px;
  font-weight: 600;
  color: #555;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.dc-progress-pct {
  font-size: 12px;
  font-weight: 700;
  color: #1a1a1a;
  flex-shrink: 0;
}
.dc-progress-track {
  width: 100%;
  height: 6px;
  background: #f0f0f0;
  border-radius: 3px;
  overflow: hidden;
}
.dc-progress-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s ease;
}
.dc-bar-red { background: linear-gradient(90deg, #dc2626, #ef4444); }

/* Step dots */
.dc-progress-steps {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
}
.dc-step-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #e5e5e5;
  transition: background 0.3s;
}
.dc-step-dot.dc-step-active {
  background: #dc2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.2);
}

/* =========== CAROUSEL [dc_carousel] =========== */
.dc-cl {
  --dc-per: 3;
  position: relative;
  overflow: visible;
  font-family: 'Assistant', sans-serif;
  padding: 20px 28px;
}
.dc-cl-wrap {
  overflow: hidden;
  padding: 0px;
  margin: -25px;
  position: relative;
  z-index: 1;
}
.dc-cl-track {
  display: flex;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.dc-cl-slide {
  flex: 0 0 calc(100% / var(--dc-per));
  max-width: calc(100% / var(--dc-per));
  padding: 10px;
  box-sizing: border-box;
}
/* Peek: show next card preview — mobile/tablet only */
.dc-cl-peek .dc-cl-slide {
  flex: 0 0 calc(100% / var(--dc-per));
  max-width: calc(100% / var(--dc-per));
}
@media (max-width: 768px) {
  .dc-cl-peek .dc-cl-slide {
    flex: 0 0 85%;
    max-width: 85%;
  }
}
.dc-cl-slide .dc-card {
  height: 100%;
}

/* No arrows: full width at all breakpoints */
.dc-cl-no-arrows,
.dc-cl-no-arrows.dc-cl { padding: 0 !important; }

/* Navigation Arrows */
.dc-cl-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 56px;
  height: 56px;
  border-radius: 0;
  border: 2px solid #d61116;
  background: #d61116;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.25s;
  box-shadow: none;
}
.dc-cl-btn svg { stroke: #fff; }
.dc-cl-btn:hover,
.dc-cl-btn:focus {
  background: #b80e12;
  border-color: #b80e12;
  box-shadow: none;
}
.dc-cl-btn:hover svg,
.dc-cl-btn:focus svg { stroke: #fff; }
.dc-cl-prev { left: -20px; }
.dc-cl-next { right: -20px; }

/* Dots */
.dc-cl-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 50px;
}
.dc-cl-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: #d0d0d0;
  cursor: pointer;
  padding: 0;
  transition: all 0.3s;
}
.dc-cl-dot.active {
  background: #d61116;
  width: 24px;
  border-radius: 4px;
}
.dc-cl-dot:hover { background: #999; }
.dc-cl-dot.active:hover { background: #d61116; }

/* Responsive */
@media (max-width: 768px) {
  .dc-cl { padding: 15px 0; }
  .dc-cl-wrap { margin: -15px 0; padding: 15px 0; }
  .dc-cl-slide { flex: 0 0 92% !important; max-width: 92% !important; padding: 0 4px; }
  .dc-cl-btn { display: none !important; }
  .dc-cl-dots { margin-top: 20px; }
  .dc-card-image { height: 280px; }
}

/* =========== GALLERY SHORTCODE =========== */
.dc-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.dc-gallery-item {
  display: block;
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.dc-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s;
}
.dc-gallery-item:hover img { transform: scale(1.05); }

/* =========== MINIMAL GRID (Sold Out / Successi) — dcg- prefix =========== */
.dcg-empty { text-align: center; padding: 40px; color: #888; font-family: 'Assistant', sans-serif; }
.dcg-grid {
  display: grid;
  gap: 24px;
  margin: 0 auto;
  font-family: 'Assistant', sans-serif;
}
.dcg-grid-1 { grid-template-columns: 1fr; }
.dcg-grid-2 { grid-template-columns: repeat(2, 1fr); }
.dcg-grid-3 { grid-template-columns: repeat(3, 1fr); }
.dcg-grid-4 { grid-template-columns: repeat(4, 1fr); }
.dcg-grid-5 { grid-template-columns: repeat(5, 1fr); }

.dcg-card,
.dcg-card:link,
.dcg-card:visited,
.dcg-card:hover,
.dcg-card:active,
.dcg-card * { text-decoration: none !important; }
.dcg-card {
  display: block;
  color: inherit;
  background: #fff !important;
  border: 15px solid #fff;
  border-radius: 0;
  overflow: hidden;
  transition: background 0.3s, border 0.3s, box-shadow 0.3s;
  cursor: pointer;
  box-shadow: 0 0 10px 0 rgba(0,0,0,0.5) !important;
}
.dcg-card:hover {
  box-shadow: 0 0 10px 0 rgba(0,0,0,0.6) !important;
  color: inherit;
}

.dcg-card-image {
  position: relative !important;
  width: 100%;
  height: 280px;
  background: #1a1a1a;
  overflow: hidden;
}
.dcg-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block;
}
.dcg-card-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ccc;
}

.dcg-card-topbar {
  position: absolute;
  top: 14px;
  left: 14px;
  right: 14px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  z-index: 3;
}
.dcg-card-topbar-left {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dcg-card-date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  font-family: 'Assistant', sans-serif;
  text-shadow: 0 1px 3px rgba(0,0,0,0.6);
}
.dcg-card-badge {
  padding: 7px 18px;
  border-radius: 8px;
  align-self: flex-start;
  width: auto;
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #fff;
  font-family: 'Assistant', sans-serif;
  border: 2px solid #fff;
}
.dcg-badge-sold { background: #d61116; }
.dcg-badge-successi { background: #1F73BE; }
.dcg-badge-vendita { background: #15BC00; }

.dcg-card-cta {
  padding: 7px 18px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background: rgba(214, 17, 22, 0.5);
  border: 2px solid #d61116;
  font-family: 'Assistant', sans-serif;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: background 0.2s;
}
.dcg-card:hover .dcg-card-cta { background: #d61116; }

.dcg-card-overlay {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  padding: 20px 20px 18px !important;
  background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.55) 50%, transparent 100%) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  height: 100% !important;
  box-sizing: border-box !important;
}
.dcg-card-header {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 10px;
}
img.dcg-card-logo,
.dcg-card-overlay img.dcg-card-logo,
.dcg-card img.dcg-card-logo {
  width: 60px !important;
  max-width: 60px !important;
  height: auto !important;
  max-height: 40px !important;
  object-fit: contain !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
  display: block !important;
}
.dcg-card-title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.2px;
  color: #fff;
  font-family: 'Assistant', sans-serif;
  line-height: 1.25;
}
.dcg-card-location {
  font-size: 16px;
  color: rgba(255, 255, 255, 1);
  font-family: 'Assistant', sans-serif;
  margin-top: 3px;
}

/* =========== RESPONSIVE =========== */
@media (max-width: 1024px) {
  .dc-grid-4, .dc-grid-5 { grid-template-columns: repeat(3, 1fr); }
  .dcg-grid-4, .dcg-grid-5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .dc-grid-3, .dc-grid-4, .dc-grid-5 { grid-template-columns: repeat(2, 1fr); }
  .dcg-grid-3, .dcg-grid-4, .dcg-grid-5 { grid-template-columns: repeat(2, 1fr); }
  .dc-card-title { font-size: 17px; }
  .dcg-card-title { font-size: 17px; }
  .dc-gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .dc-grid-2, .dc-grid-3, .dc-grid-4, .dc-grid-5 { grid-template-columns: 1fr; }
  .dcg-grid-2, .dcg-grid-3, .dcg-grid-4, .dcg-grid-5 { grid-template-columns: 1fr; }
  .dc-gallery { grid-template-columns: 1fr; }
}
