/* dpro events shortcodes styling - modern card and calendar (complete) */

/* Typography & base */
:root{
  --dpro-accent:#2436ff;
  --dpro-muted:#6b7280;
  --dpro-bg:#ffffff;
  --dpro-card-bg:#ffffff;
  --dpro-radius:12px;
  --dpro-shadow: 0 6px 18px rgba(0,0,0,0.06);
  --dpro-gap:16px;
}

body.dpro-modal-open{overflow:hidden;}

/* Button system */
.dpro-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-family:inherit;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
  padding:10px 18px;
  border-radius:10px;
  border:1px solid transparent;
  background:#f5f6ff;
  color:#1e293b;
  cursor:pointer;
  text-decoration:none;
  transition:box-shadow .18s ease, transform .18s ease, background .18s ease;
  box-shadow:0 10px 24px -22px rgba(36,54,255,0.6);
}
.dpro-button:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:0 16px 32px -26px rgba(36,54,255,0.55);
}
.dpro-button:disabled{
  opacity:.6;
  cursor:not-allowed;
  box-shadow:none;
}
.dpro-button--primary{
  background:var(--dpro-accent);
  color:#fff;
  border-color:var(--dpro-accent);
}
.dpro-button--primary:hover:not(:disabled){
  background:#1d2de0;
}
.dpro-button--ghost{
  background:transparent;
  border:1px solid rgba(15,23,42,0.18);
  color:#0f172a;
  box-shadow:none;
}
.dpro-button--ghost:hover:not(:disabled){
  background:rgba(15,23,42,0.06);
}
.dpro-button--outline{
  background:#fff;
  border:1px solid rgba(36,54,255,0.45);
  color:var(--dpro-accent);
}
.dpro-button--outline:hover:not(:disabled){
  background:rgba(36,54,255,0.08);
}
.dpro-button--link{
  padding:0;
  border:none;
  background:none;
  color:var(--dpro-accent);
  box-shadow:none;
}
.dpro-button--link:hover:not(:disabled){
  text-decoration:underline;
  transform:none;
}
.dpro-button--pill{
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  background:rgba(36,54,255,0.12);
  color:var(--dpro-accent);
  box-shadow:none;
  border:none;
}
.dpro-button--pill:hover:not(:disabled){
  background:rgba(36,54,255,0.18);
}

.dpro-events-list-wrap,
.dpro-events-calendar {
  max-width:1200px;
  margin: 0 auto;
  padding: 28px 20px;
  box-sizing: border-box;
}

/* Headings */
.dpro-list-header h2 {
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size: 42px;
  margin: 0 0 16px;
  font-weight: 700;
  color: #0b1220;
}

/* Carousel header controls */
.dpro-list-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 18px;
}

/* Controls container for arrows */
.dpro-list-controls {
  display:flex;
  gap:12px;
}

/* Arrow buttons */
.dpro-list-prev,
.dpro-list-next,
.dpro-cal-prev,
.dpro-cal-next {
  background: var(--dpro-accent);
  color: #fff;
  border: none;
  padding: 12px 18px;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  transition: transform .15s ease, box-shadow .15s ease;
  font-weight:700;
}
.dpro-list-prev:hover,
.dpro-list-next:hover,
.dpro-cal-prev:hover,
.dpro-cal-next:hover { transform: translateY(-4px); }

/* Carousel container */
.dpro-events-carousel {
  display:flex;
  gap:16px;
  overflow:hidden;
  scroll-behavior:smooth;
  padding-bottom:6px;
  align-items:stretch;
}

/* Card */
.dpro-event-card {
  min-width: 280px;
  max-width: 320px;
  flex: 0 0 auto;
  border-radius: var(--dpro-radius);
  background: var(--dpro-card-bg);
  box-shadow: var(--dpro-shadow);
  overflow: hidden;
  display:flex;
  flex-direction: column;
  transform: translateY(0);
  transition: transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s ease;
}
.dpro-event-card:hover { transform: translateY(-8px); box-shadow:0 18px 40px rgba(16,24,40,0.12); }

/* Card image */
.dpro-event-card-image img {
  width:100%;
  height:180px;
  object-fit:cover;
  display:block;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

/* Card body */
.dpro-event-card-body {
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap:8px;
}
.dpro-event-card-title { margin: 0 0 6px; font-size:18px; font-weight: 700; color:#0b1220; }
.dpro-event-card-time { color: var(--dpro-accent); font-size: 14px; display:block; margin-bottom:6px; }
.dpro-event-card-excerpt { color: var(--dpro-muted); font-size: 14px; margin: 0; }

/* Calendar header */
.dpro-calendar-header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom: 12px;
}
.dpro-calendar-actions { text-align:right; }
.dpro-ical-btn, .dpro-webcal-btn {
  color: var(--dpro-accent);
  text-decoration: none;
  margin-left: 8px;
  font-weight:600;
}

/* Fullcalendar root wrapper */
.dpro-fullcalendar-root {
  background: #fff;
  padding: 12px;
  border-radius: var(--dpro-radius);
  box-shadow: 0 6px 18px rgba(0,0,0,0.04);
  min-height: 320px;
  transition: opacity .24s ease, transform .24s ease;
  opacity: 0;
  transform: translateY(10px);
}
.dpro-fullcalendar-root.dpro-calendar-loaded {
  opacity: 1;
  transform: none;
}

/* Day panel */
.dpro-day-panel {
  margin-top: 14px;
  min-height: 80px;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 30px rgba(0,0,0,0.04);
  padding: 12px;
}

/* Small day-card variant (in day panel) */
.dpro-day-list .dpro-event-card.day-card {
  max-width: 100%;
  display: flex;
  flex-direction: row;
  gap: 12px;
  padding: 8px;
}
.dpro-day-list .dpro-event-card.day-card .dpro-event-card-image img { width:160px; height:100px; }

/* Single event layout refresh */
.dpro-event-single{max-width:980px;margin:0 auto 48px;background:linear-gradient(180deg,rgba(226,241,255,0.9) 0%,#ffffff 45%);border-radius:30px;overflow:hidden;box-shadow:0 32px 70px -38px rgba(15,23,42,0.55);}
.dpro-event-hero{display:flex;gap:32px;align-items:stretch;padding:36px;flex-wrap:wrap;background:linear-gradient(135deg,rgba(37,99,235,0.1),rgba(255,255,255,0.95));}
.dpro-event-hero__media{flex:1 1 320px;min-height:240px;border-radius:24px;overflow:hidden;box-shadow:0 28px 56px -40px rgba(15,23,42,0.6);}
.dpro-event-hero__image{width:100%;height:100%;object-fit:cover;display:block;}
.dpro-event-hero__content{flex:1 1 360px;display:flex;flex-direction:column;gap:18px;color:#0f172a;}
.dpro-event-hero__badge{align-self:flex-start;padding:6px 14px;border-radius:999px;background:rgba(255,255,255,0.72);color:#0f172a;font-weight:700;font-size:0.75rem;letter-spacing:0.08em;text-transform:uppercase;box-shadow:0 10px 24px -18px rgba(15,23,42,0.35);}
.dpro-event-title{margin:0;font-size:2.4rem;line-height:1.1;font-weight:800;color:#0f172a;}
.dpro-event-meta{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:16px 24px;}
.dpro-event-meta__label{display:block;font-size:0.75rem;letter-spacing:0.08em;text-transform:uppercase;color:rgba(15,23,42,0.56);margin-bottom:4px;font-weight:700;}
.dpro-event-meta__value{display:block;font-size:1.05rem;font-weight:600;color:#0f172a;}
.dpro-event-excerpt{margin:0;color:#334155;font-size:1rem;line-height:1.7;max-width:60ch;}
.dpro-event-hero__cta{margin-top:auto;display:flex;gap:14px;flex-wrap:wrap;}
.dpro-ticket-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:999px;background:#2563eb;color:#fff;font-weight:700;text-decoration:none;box-shadow:0 22px 40px -26px rgba(37,99,235,0.7);transition:transform .2s ease,box-shadow .2s ease,background .2s ease;}
.dpro-ticket-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 26px 46px -28px rgba(29,78,216,0.6);}
.dpro-event-body{display:flex;gap:28px;align-items:flex-start;padding:0 36px 40px 36px;background:#fff;flex-wrap:wrap;}
.dpro-event-sidebar{flex:1 1 260px;padding:24px 28px;border-radius:24px;background:linear-gradient(145deg,rgba(226,232,240,0.7),#fff);box-shadow:0 26px 48px -32px rgba(15,23,42,0.45);border:1px solid rgba(15,23,42,0.08);}
.dpro-event-sidebar__title{margin:0 0 18px;font-size:1.1rem;font-weight:700;color:#0f172a;}
.dpro-event-details{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:16px;font-size:0.95rem;}
.dpro-event-details__label{display:block;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.08em;color:rgba(15,23,42,0.56);font-weight:700;margin-bottom:4px;}
.dpro-event-details__value{color:#0f172a;font-weight:600;}
.dpro-event-content{flex:2 1 460px;display:flex;flex-direction:column;gap:24px;font-size:1rem;color:#1e293b;line-height:1.75;}
.dpro-event-content h2,.dpro-event-content h3,.dpro-event-content h4{color:#0f172a;margin-top:1.6em;}
.dpro-event-content__cta{margin-top:12px;display:flex;gap:12px;}

@media (max-width: 960px){
  .dpro-event-hero{flex-direction:column;padding:28px;}
  .dpro-event-hero__media{order:2;min-height:220px;}
  .dpro-event-hero__content{order:1;}
  .dpro-event-body{padding:0 28px 32px 28px;}
}

@media (max-width: 680px){
  .dpro-event-body{flex-direction:column;}
  .dpro-event-sidebar,.dpro-event-content{flex:1 1 100%;}
  .dpro-event-single{border-radius:22px;}
}

/* Skeletons */
.dpro-skeleton{
  background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 37%,#f0f0f0 63%);
  background-size:400% 100%;
  animation:shimmer 1.4s linear infinite;
  border-radius:10px;
  height:100px;
  margin-bottom:10px;
}
.dpro-skel-small{height:60px;}
.dpro-skel-card{width:280px;height:220px;display:inline-block;margin-right:12px;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Accessibility / small screens */
@media (max-width: 900px) {
  .dpro-events-carousel { gap:12px; padding-bottom:10px; }
  .dpro-event-card { min-width: 240px; max-width: 260px; }
  .dpro-list-header h2 { font-size: 32px; }
}

@media (max-width: 600px) {
  .dpro-list-controls { order: 2; }
  .dpro-list-header { flex-direction: column; align-items:flex-start; gap:10px; }
  .dpro-event-card-image img { height:140px; }
  .dpro-calendar-header { flex-direction: column; align-items:stretch; gap:12px; }
  .dpro-event-single-grid { grid-template-columns: 1fr; gap: 12px; }
}

/* subtle fade-up animation when day list appears */
@keyframes dproFadeUp {
  0% { opacity: 0; transform: translateY(6px); }
  100% { opacity: 1; transform: none; }
}
.dpro-day-list { animation: dproFadeUp .18s ease both; }

/* small calendar error message */
.dpro-calendar-error { color:#c02; padding:12px; }



/* Fix: make calendar full width and remove scrollbars */
.dpro-events-calendar { width: 100%; max-width: 1200px; margin: 0 auto; overflow: visible !important; }
#dpro-events-calendar-root, .dpro-fullcalendar-root { max-width: 100% !important; width: 100% !important; height: auto !important; }
.dpro-events-calendar .fc { box-sizing: border-box; }
@media (max-width: 860px) {
    #dpro-events-calendar-root { width: 100% !important; margin: 0 8px; }
    .dpro-calendar-header { padding: 0 6px; }
    .dpro-calendar-actions { display:flex; gap:8px; flex-wrap:wrap; }
}



/* Added by dashboard v2 - dynamic wizard styles */
.dpro-dashboard-theme{background:#fff;border:1px solid #e9eef5;padding:18px;border-radius:8px;font-family:Arial,Helvetica,sans-serif;color:#1f2d3d;}
.dpro-dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.dpro-dashboard-header h2{margin:0;font-size:18px;color:#153e6a;}
.dpro-dashboard-tabs{display:flex;gap:8px;}
.dpro-tab{padding:8px 12px;border-radius:6px;text-decoration:none;background:#f3f6fa;border:1px solid #d6e0ee;color:#153e6a;cursor:pointer;}
.dpro-tab.active{background:#1e73be;color:#fff;border-color:#155a8c;box-shadow:0 2px 6px rgba(21,90,140,0.12);}
.dpro-dashboard-body{padding-top:8px;}

/* Dashboard v5 refresh */
.dpro-dashboard.v5{background:linear-gradient(180deg,#e1f2ff 0%,#f4f9ff 100%);border-radius:20px;box-shadow:0 26px 70px -36px rgba(9,64,120,0.55);padding:28px;max-width:1120px;margin:0 auto;color:#0b1a2b;}
.dpro-dashboard.v5 .dpro-dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:18px;}
.dpro-dashboard.v5 .dpro-dashboard-header h2{margin:0;font-size:26px;font-weight:700;color:#042d56;}
.dpro-dashboard.v5 .dpro-dashboard-subtitle{margin:4px 0 0;font-size:15px;color:#154a7a;}
.dpro-dashboard-alert{margin-bottom:16px;padding:14px 18px;border-radius:12px;border:1px solid rgba(2,132,199,0.35);background:rgba(191,219,254,0.6);color:#0f172a;font-weight:600;box-shadow:0 16px 34px -28px rgba(12,74,110,0.45);}
.dpro-dashboard-alert.is-info{border-color:#38bdf8;background:#dbeafe;color:#082f49;box-shadow:0 18px 34px -28px rgba(8,47,73,0.35);}
.dpro-dashboard-alert.is-error{border-color:#f87171;background:#fee2e2;color:#7f1d1d;box-shadow:0 18px 34px -28px rgba(185,28,28,0.35);}
.dpro-dashboard-alert.is-success{border-color:#34d399;background:#dcfce7;color:#065f46;box-shadow:0 18px 34px -28px rgba(16,185,129,0.35);}
.dpro-dashboard-alert[hidden]{display:none;}
.dpro-dashboard-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;}
.dpro-dashboard-tabs .dpro-tab{background:#cce4ff;border:1px solid transparent;padding:10px 18px;border-radius:999px;color:#07345c;font-weight:600;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, background .18s ease;box-shadow:0 8px 18px -16px rgba(7,52,92,0.55);}
.dpro-dashboard-tabs .dpro-tab:hover{transform:translateY(-2px);box-shadow:0 16px 28px -20px rgba(7,52,92,0.45);}
.dpro-dashboard-tabs .dpro-tab.active{background:#0b79d0;color:#fff;border-color:#075798;box-shadow:0 18px 34px -24px rgba(11,121,208,0.6);}
.dpro-dashboard-content{border:1px solid rgba(12,74,110,0.12);border-radius:16px;padding:26px;background:rgba(255,255,255,0.92);backdrop-filter:blur(4px);position:relative;}
.dpro-dashboard.v5 .button{background:#0b79d0;color:#fff;border:1px solid #0b79d0;border-radius:999px;padding:8px 18px;font-weight:600;box-shadow:0 18px 30px -22px rgba(11,121,208,0.55);transition:transform .16s ease, box-shadow .16s ease, background .16s ease;}
.dpro-dashboard.v5 .button:hover{transform:translateY(-2px);box-shadow:0 24px 38px -28px rgba(7,52,92,0.45);}
.dpro-dashboard.v5 .button.button-secondary{background:#e0f2ff;color:#0b79d0;}
.dpro-dashboard.v5 .button.button-link{background:transparent;color:#0b79d0;border:0;box-shadow:none;padding:0;}
.dpro-dashboard.v5 .button.button-link:hover{transform:none;text-decoration:underline;}
.dpro-dashboard.v5 .button.button-small{padding:6px 12px;border-radius:10px;font-size:13px;}
.dpro-panel{display:block;}
.dpro-panel[hidden]{display:none!important;}

.dpro-events-listing .dpro-table{width:100%;border-collapse:collapse;font-size:14px;}
.dpro-events-listing .dpro-table th,.dpro-events-listing .dpro-table td{padding:12px;border-bottom:1px solid #f0f3f9;text-align:left;}
.dpro-events-listing .dpro-table tbody tr:hover{background:#f8fafc;}
.dpro-table-btn--danger{color:#dc2626;}
.dpro-table-btn--danger:hover,.dpro-table-btn--danger:focus{color:#b91c1c;}
.dpro-table-btn[disabled]{opacity:0.55;cursor:not-allowed;}
.dpro-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#e5e7eb;color:#111827;font-weight:600;font-size:12px;line-height:1;text-transform:capitalize;}
.dpro-status::before{content:'';display:block;width:10px;height:10px;border-radius:999px;background:#9ca3af;}
.dpro-status--published{background:rgba(16,185,129,0.12);color:#065f46;}
.dpro-status--published::before{background:#10b981;}
.dpro-status--pending{background:rgba(251,191,36,0.15);color:#92400e;}
.dpro-status--pending::before{background:#f59e0b;}
.dpro-events-listing .dpro-col-actions{width:160px;text-align:right;}
.dpro-events-listing .dpro-empty{background:#f8fafc;border:1px dashed #cbd5f5;border-radius:12px;padding:32px;text-align:center;margin-bottom:16px;}
.dpro-events-listing .dpro-loading td{color:#94a3b8;font-style:italic;}
.dpro-events-listing .button{margin-right:6px;}

.dpro-create-wrapper{max-width:760px;margin:0 auto;}
.dpro-create-wizard{position:relative;}
.dpro-wizard-step{animation:fadeIn .25s ease;}
.dpro-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:16px;}
.dpro-field-full{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#334155;}
.dpro-field-full textarea{padding:12px;border:1px solid #dbe2f2;border-radius:8px;resize:vertical;min-height:120px;}
.dpro-grid label{display:flex;flex-direction:column;font-weight:600;color:#334155;gap:6px;}
.dpro-grid input{padding:10px 12px;border:1px solid #dbe2f2;border-radius:8px;width:100%;box-sizing:border-box;}
.dpro-step-intro{margin:0 0 16px;color:#5d6b82;font-size:14px;}
.dpro-wizard-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;}
.dpro-media-upload{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;}
.dpro-media-preview{width:240px;height:160px;border:1px dashed #cbd5f5;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#f8fafc;overflow:hidden;position:relative;}
.dpro-media-preview img{width:100%;height:100%;object-fit:cover;display:block;}
.dpro-media-placeholder{color:#94a3b8;font-size:13px;text-align:center;padding:0 12px;}
.dpro-media-actions{display:flex;flex-direction:column;gap:8px;}
.dpro-ticket-builder .dpro-ticket-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;}
.dpro-ticket-row{display:grid;grid-template-columns:minmax(200px,2fr) minmax(140px,1fr) minmax(120px,1fr) minmax(160px,1.15fr) minmax(160px,1.15fr) minmax(120px,1fr) 44px;gap:12px;align-items:start;background:#f8fafc;padding:12px;border-radius:10px;}
.dpro-ticket-row input{padding:8px 10px;border:1px solid #dbe2f2;border-radius:6px;}
.dpro-ticket-row .dpro-remove-ticket{justify-self:end;}
.dpro-ticket-row .dpro-ticket-actions{align-self:start;}
.dpro-ticket-row .dpro-ticket-actions .dpro-button{width:100%;justify-content:center;}
.dpro-ticket-row .dpro-ticket-actions .dpro-button + .dpro-button{margin-top:8px;}
.dpro-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#e2e8f0;color:#0f172a;font-weight:700;font-size:12px;}
.dpro-pill.is-success{background:rgba(16,185,129,0.18);color:#065f46;}
.dpro-pill.is-warn{background:rgba(251,191,36,0.18);color:#92400e;}
.dpro-pill.is-error{background:rgba(248,113,113,0.16);color:#991b1b;}
.dpro-ticket-seat-summary{margin-top:12px;padding:14px;border:1px solid rgba(15,23,42,0.08);border-radius:14px;background:#f8fafc;box-shadow:0 16px 38px -32px rgba(15,23,42,0.18);}
.dpro-ticket-seat-summary__header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:space-between;}
.dpro-ticket-seat-summary__message{margin:0;color:#475569;font-size:13px;}
.dpro-ticket-seat-summary__list{margin:8px 0 0 16px;color:#0f172a;font-size:13px;}
.dpro-ticket-seat-summary__list li{margin-bottom:4px;}
.dpro-ticket-preview-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:12px 0;}
.dpro-ticket-preview-actions__hint{margin:0;color:#475569;font-size:13px;}

@media (max-width:960px){
    .dpro-ticket-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}
    .dpro-ticket-row .dpro-ticket-actions{justify-self:flex-start;}
}

/* Seatmap designer */
.dpro-seatmap-designer{margin-top:12px;padding:16px;border:1px dashed rgba(36,54,255,0.2);border-radius:14px;background:rgba(36,54,255,0.06);display:flex;flex-direction:column;gap:12px;}
.dpro-seatmap-toggle{display:flex;align-items:center;gap:12px;font-weight:600;color:#0f172a;}
.dpro-seatmap-toggle input{width:20px;height:20px;}
.dpro-seatmap-helper{margin:0;color:#475569;font-size:13px;}
.dpro-seatmap-validation{display:flex;gap:12px;align-items:flex-start;padding:10px 12px;border:1px dashed rgba(15,23,42,0.12);border-radius:12px;background:#f1f5f9;}
.dpro-seatmap-validation__message{margin:0;color:#475569;font-size:13px;line-height:1.5;}
.dpro-seatmap-body{display:none;}
.dpro-seatmap-modal{position:fixed;inset:0;padding:40px;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,0.48);z-index:9999;}
.dpro-seatmap-modal[hidden]{display:none;}
.dpro-seatmap-modal__inner{background:#fff;border-radius:22px;box-shadow:0 38px 80px -28px rgba(15,23,42,0.55);width:min(1200px,96vw);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;}
.dpro-seatmap-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 26px;border-bottom:1px solid rgba(15,23,42,0.08);}
.dpro-seatmap-modal__header h3{margin:0;font-size:20px;color:#0f172a;font-weight:700;}
.dpro-seatmap-modal__close{background:none;border:none;font-size:28px;line-height:1;color:#475569;cursor:pointer;}
.dpro-seatmap-modal__body{display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding:22px 26px;overflow:auto;background:linear-gradient(145deg,rgba(239,246,255,0.82),#fff);} 
.dpro-seatmap-layout{display:flex;gap:20px;align-items:flex-start;width:100%;} 
.dpro-seatmap-steps{display:flex;gap:12px;flex-wrap:wrap;color:#1d4ed8;font-weight:700;font-size:13px;padding:6px 12px;border-radius:12px;background:rgba(59,130,246,0.08);border:1px solid rgba(59,130,246,0.2);} 
.dpro-seatmap-step{display:inline-flex;align-items:center;gap:6px;color:#1e293b;opacity:0.75;} 
.dpro-seatmap-step.is-active{opacity:1;color:#0f172a;} 
.dpro-seatmap-workspace{flex:2 1 620px;display:flex;flex-direction:column;gap:16px;} 
.dpro-seatmap-toolbar{display:flex;flex-direction:column;gap:8px;} 
.dpro-seatmap-toolbar__row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;} 
.dpro-seatmap-toolbar__row--secondary{justify-content:space-between;gap:14px;flex-wrap:wrap;border:1px solid rgba(15,23,42,0.06);padding:10px 12px;border-radius:12px;background:#fff;box-shadow:0 10px 26px -18px rgba(15,23,42,0.35);} 
.dpro-seatmap-toolbar__actions{display:flex;gap:8px;flex-wrap:wrap;} 
.dpro-seatmap-switch{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a;font-size:13px;} 
.dpro-seatmap-switch input{width:18px;height:18px;} 
.dpro-seatmap-zoom{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a;font-size:13px;} 
.dpro-seatmap-zoom label{font-weight:700;} 
.dpro-seatmap-zoom input[type=range]{width:150px;} 
.dpro-seatmap-zoom__value{min-width:46px;text-align:right;color:#1d4ed8;} 
.dpro-seatmap-stage-wrap{position:relative;border-radius:18px;border:1px solid rgba(36,54,255,0.12);padding:16px;background:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6),0 20px 48px -32px rgba(36,54,255,0.35);} 
.dpro-seatmap-stage-viewport{border-radius:14px;position:relative;overflow:auto;max-height:64vh;width:100%;} 
.dpro-seatmap-stage{position:relative;width:100%;min-height:480px;border-radius:14px;background:rgba(248,250,252,0.92);overflow:hidden;transform-origin:top left;transition:transform .12s ease;} 
.dpro-seatmap-stage::after{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(36,54,255,0.06) 1px,transparent 1px),linear-gradient(0deg,rgba(36,54,255,0.06) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;} 
.dpro-seatmap-stage-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:14px;} 
.dpro-seatmap-stage-bg iframe{width:100%;height:100%;border:0;} 
.dpro-seatmap-stage-overlay{position:absolute;inset:0;}
.dpro-seatmap-stage-hint{margin:0;font-size:13px;color:#1d4ed8;}
.dpro-seatmap-sidebar{flex:1 1 280px;display:flex;flex-direction:column;gap:18px;}
.dpro-seatmap-dimensions,.dpro-seatmap-grid,.dpro-seatmap-inspector{background:#fff;border:1px solid rgba(15,23,42,0.08);border-radius:16px;padding:16px;box-shadow:0 20px 48px -34px rgba(15,23,42,0.25);}
.dpro-seatmap-dimensions h4,.dpro-seatmap-grid h4,.dpro-seatmap-inspector h4{margin:0 0 10px;font-size:15px;color:#0f172a;font-weight:700;}
.dpro-seatmap-dimensions label,.dpro-seatmap-grid label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#0f172a;font-size:13px;}
.dpro-seatmap-dimensions input,.dpro-seatmap-grid input{padding:8px 10px;border:1px solid rgba(15,23,42,0.16);border-radius:10px;}
.dpro-seatmap-inspector-empty{margin:0;color:#475569;font-size:13px;} 
.dpro-seatmap-inspector-fields{display:flex;flex-direction:column;gap:10px;} 
.dpro-seatmap-inspector-fields label{display:flex;flex-direction:column;gap:4px;font-weight:600;color:#0f172a;font-size:13px;} 
.dpro-seatmap-inspector-fields input,.dpro-seatmap-inspector-fields select{padding:8px 10px;border:1px solid rgba(15,23,42,0.16);border-radius:10px;}
.dpro-seatmap-dimension-fields{display:flex;gap:10px;}
.dpro-seatmap-dimension-fields label{flex:1;}
.dpro-seatmap-rotate-field{display:flex;flex-direction:column;gap:6px;}
.dpro-seatmap-rotate-actions{display:flex;align-items:center;gap:8px;}
.dpro-seatmap-icon-btn{width:30px;height:30px;border-radius:999px;border:1px solid rgba(36,54,255,0.5);background:#fff;color:var(--dpro-accent);display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background .18s ease, transform .18s ease;}
.dpro-seatmap-icon-btn:hover{background:rgba(36,54,255,0.12);transform:translateY(-1px);}
.dpro-seatmap-link{background:none;border:none;padding:0 4px;color:var(--dpro-accent);font-size:12px;font-weight:600;cursor:pointer;}
.dpro-seatmap-link:hover{text-decoration:underline;}
.dpro-icon{display:block;width:16px;height:16px;position:relative;}
.dpro-icon--rotate-left::before,.dpro-icon--rotate-right::before{content:"";position:absolute;inset:0;border:2px solid currentColor;border-bottom-color:transparent;border-right-color:transparent;border-radius:50%;}
.dpro-icon--rotate-left::after{content:"";position:absolute;width:0;height:0;border:5px solid transparent;border-top-color:currentColor;left:2px;top:-2px;transform:rotate(-20deg);}
.dpro-icon--rotate-right::before{transform:rotate(180deg);}
.dpro-icon--rotate-right::after{content:"";position:absolute;width:0;height:0;border:5px solid transparent;border-bottom-color:currentColor;right:2px;bottom:-2px;transform:rotate(-20deg);}
.dpro-seatmap-stage .dpro-seatmap-seat{position:absolute;padding:6px 10px;border-radius:12px;background:var(--dpro-accent);color:#fff;font-weight:600;text-align:center;cursor:grab;user-select:none;transform:translate(-50%,-50%) rotate(var(--dpro-seat-rotation,0deg));box-shadow:0 16px 32px -26px rgba(36,54,255,0.6);transition:transform .12s ease, box-shadow .12s ease;width:var(--dpro-seat-width,56px);height:var(--dpro-seat-height,46px);display:flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.03em;z-index:2;}
.dpro-seatmap-stage .dpro-seatmap-seat:active{cursor:grabbing;}
.dpro-seatmap-stage .dpro-seatmap-seat.is-selected{box-shadow:0 0 0 2px #fff,0 0 0 5px rgba(36,54,255,0.35);}
.dpro-seatmap-stage .dpro-seatmap-seat[data-status="blocked"]{background:#475569;}
.dpro-seatmap-stage .dpro-seatmap-seat.is-locked{background:#e2e8f0;color:#475569;cursor:not-allowed;border:1px dashed #cbd5e1;box-shadow:none;}
.dpro-seatmap-stage .dpro-seatmap-seat[data-status="reserved"]{background:#f97316;}
.dpro-seatmap-selection{position:absolute;border:1px dashed rgba(36,54,255,0.55);border-radius:14px;box-shadow:0 14px 32px -26px rgba(7,52,92,0.4);background:rgba(12,74,110,0.06);pointer-events:none;z-index:3;}
.dpro-seatmap-seat-handle{position:absolute;width:12px;height:12px;background:#fff;border:1px solid rgba(36,54,255,0.85);border-radius:4px;pointer-events:auto;cursor:nwse-resize;box-shadow:0 4px 10px -6px rgba(36,54,255,0.45);touch-action:none;}
.dpro-seatmap-seat-handle[data-handle="rotate"],.dpro-seatmap-seat-handle--rotate{top:-26px;left:50%;margin-left:-6px;cursor:grab;border-color:#f97316;background:#fff;width:14px;height:14px;box-shadow:0 4px 12px -6px rgba(249,115,22,0.45);}
.dpro-seatmap-seat-handle[data-handle="rotate"]::after,.dpro-seatmap-seat-handle--rotate::after{content:"";position:absolute;width:0;height:0;border:5px solid transparent;border-top-color:#f97316;top:-8px;left:50%;margin-left:-5px;}
.dpro-seatmap-seat-handle[data-handle="rotate"]:active,.dpro-seatmap-seat-handle--rotate:active{cursor:grabbing;}
.dpro-seatmap-seat-handle[data-handle="e"],.dpro-seatmap-seat-handle[data-handle="w"]{top:50%;margin-top:-6px;}
.dpro-seatmap-seat-handle[data-handle="e"]{right:-10px;}
.dpro-seatmap-seat-handle[data-handle="w"]{left:-10px;}
.dpro-seatmap-seat-handle[data-handle="n"],.dpro-seatmap-seat-handle[data-handle="s"]{left:50%;margin-left:-6px;}
.dpro-seatmap-seat-handle[data-handle="n"]{top:-10px;}
.dpro-seatmap-seat-handle[data-handle="s"]{bottom:-10px;}
.dpro-seatmap-seat-handle[data-handle="ne"],.dpro-seatmap-seat-handle[data-handle="sw"]{cursor:nesw-resize;}
.dpro-seatmap-seat-handle[data-handle="nw"],.dpro-seatmap-seat-handle[data-handle="se"]{cursor:nwse-resize;}
.dpro-seatmap-seat-handle[data-handle="ne"]{top:-10px;right:-10px;}
.dpro-seatmap-seat-handle[data-handle="nw"]{top:-10px;left:-10px;}
.dpro-seatmap-seat-handle[data-handle="se"]{bottom:-10px;right:-10px;}
.dpro-seatmap-seat-handle[data-handle="sw"]{bottom:-10px;left:-10px;}
.dpro-seatmap-marquee{position:absolute;border:1px dashed rgba(36,54,255,0.45);background:rgba(12,74,110,0.08);pointer-events:none;z-index:4;}
.dpro-seatmap-modal__footer{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-top:1px solid rgba(15,23,42,0.08);background:#fff;}
.dpro-seatmap-save-state{font-size:12px;color:#475569;}
.dpro-seatmap-save-state.is-saving{color:#1d4ed8;}

.dpro-tickets-panel{display:flex;flex-direction:column;gap:16px;}
.dpro-tickets-intro{margin:0;color:#5d6b82;}
.dpro-ticket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;}
.dpro-ticket-card{border:1px solid #ebeff5;border-radius:12px;padding:18px;background:#fff;display:flex;flex-direction:column;gap:12px;box-shadow:0 12px 30px -24px rgba(31,45,61,.45);}
.dpro-ticket-card h4{margin:0;font-size:16px;}
.dpro-ticket-card time{display:block;color:#64748b;font-size:13px;}
.dpro-ticket-card .dpro-ticket-actions{display:flex;gap:8px;}
.dpro-ticket-placeholder{border:1px dashed #cbd5f5;border-radius:12px;padding:24px;text-align:center;color:#64748b;}

.dpro-ticket-modal{position:fixed;inset:0;background:rgba(7,19,40,0.55);display:flex;align-items:flex-start;justify-content:center;z-index:9999;padding:24px 16px;overflow:auto;}
.dpro-ticket-modal[hidden]{display:none!important;}
.dpro-ticket-modal__inner{background:rgba(244,249,255,0.96);border-radius:22px;max-width:min(1120px,100%);width:100%;padding:28px;box-shadow:0 48px 110px -54px rgba(7,52,92,0.65);display:flex;flex-direction:column;gap:18px;backdrop-filter:blur(8px);max-height:calc(92vh - 24px);overflow:auto;}
.dpro-ticket-modal__close{align-self:flex-end;border:0;background:transparent;font-size:28px;line-height:1;cursor:pointer;color:#0b1a2b;}
.dpro-ticket-designer__body{display:flex;flex-direction:column;gap:18px;max-height:calc(92vh - 180px);overflow:auto;}
.dpro-ticket-designer__intro{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:#fff;border:1px solid rgba(12,74,110,0.12);padding:14px 16px;border-radius:16px;box-shadow:0 14px 32px -26px rgba(7,52,92,0.45);}
.dpro-ticket-designer__intro-text h3{margin:0;font-size:18px;color:#0b1a2b;}
.dpro-ticket-designer__intro-text p{margin:6px 0 0 0;color:#475569;line-height:1.5;}
.dpro-ticket-designer__badges{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;}
.dpro-badge{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:12px;letter-spacing:.02em;padding:8px 12px;border-radius:999px;background:rgba(13,148,136,0.08);color:#0f172a;border:1px solid rgba(13,148,136,0.25);white-space:nowrap;}
.dpro-badge--muted{background:rgba(99,102,241,0.08);border-color:rgba(99,102,241,0.25);color:#312e81;}
.dpro-ticket-designer__form{display:flex;flex-direction:column;gap:18px;min-width:0;}
.dpro-ticket-designer-main{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,0.85fr);gap:22px;align-items:start;min-width:0;}
.dpro-ticket-template{background:rgba(224,242,255,0.6);border:1px solid rgba(12,74,110,0.15);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:16px;box-shadow:0 22px 48px -38px rgba(7,52,92,0.45);position:relative;}
.dpro-ticket-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:4px;}
.dpro-ticket-tab{border:1px solid rgba(12,74,110,0.14);background:#fff;color:#0b1a2b;border-radius:12px;padding:10px 14px;font-weight:700;cursor:pointer;box-shadow:0 14px 32px -26px rgba(7,52,92,0.25);transition:all .18s ease;}
.dpro-ticket-tab.is-active{background:#0ea5e9;color:#0b172a;border-color:transparent;box-shadow:0 18px 40px -30px rgba(14,165,233,0.55);}
.dpro-ticket-toolbar{display:flex;flex-wrap:wrap;gap:10px;}
.dpro-ticket-layout-toggles{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:6px 0 4px;color:#0b1a2b;font-weight:600;}
.dpro-ticket-layout-toggles input{margin-right:6px;}
.dpro-ticket-stage-header{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;}
.dpro-ticket-view-toggle{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.dpro-ticket-view-toggle .dpro-button{min-width:140px;}
.dpro-ticket-history{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.dpro-ticket-dimensions{font-weight:700;color:#0b1a2b;background:rgba(255,255,255,0.9);border:1px solid rgba(12,74,110,0.12);border-radius:12px;padding:8px 12px;box-shadow:0 16px 38px -32px rgba(7,52,92,0.35);} 
.dpro-ticket-guide{display:flex;flex:1 1 auto;gap:10px;align-items:center;justify-content:space-between;background:#0b79d0;color:#f8fafc;border-radius:14px;padding:10px 12px;box-shadow:0 16px 38px -30px rgba(11,121,208,0.65);border:1px solid rgba(255,255,255,0.16);}
.dpro-ticket-guide__content{display:flex;align-items:center;gap:8px;font-weight:600;}
.dpro-ticket-guide__content span{font-weight:500;opacity:.9;}
.dpro-ticket-guide__actions .dpro-button{background:#fff;color:#0b79d0;border-color:transparent;}
.dpro-ticket-stage-wrap{border-radius:16px;border:1px solid rgba(12,74,110,0.1);background:linear-gradient(135deg,rgba(191,219,254,0.45),rgba(255,255,255,0.96));padding:14px;position:relative;box-shadow:inset 0 1px 0 rgba(255,255,255,0.5);overflow:auto;max-width:100%;max-height:calc(70vh - 140px);}
.dpro-ticket-stage{position:relative;width:100%;min-height:360px;border-radius:12px;background:rgba(255,255,255,0.94);overflow:hidden;}
.dpro-ticket-stage.is-grid .dpro-ticket-stage-overlay{background-image:linear-gradient(rgba(12,74,110,0.08) 1px,transparent 1px),linear-gradient(90deg,rgba(12,74,110,0.08) 1px,transparent 1px);background-size:48px 48px;}
.dpro-ticket-stage-bg{position:absolute;inset:0;z-index:0;}
.dpro-ticket-stage-bg img{width:100%;height:100%;object-fit:cover;display:block;border-radius:12px;pointer-events:none;}
.dpro-ticket-stage-bg iframe{width:100%;height:100%;border:0;pointer-events:none;border-radius:12px;background:#fff;}
.dpro-ticket-stage-overlay{position:absolute;inset:0;z-index:1;}
.dpro-tpl-safe-area{position:absolute;inset:24px;border:2px dashed rgba(11,121,208,0.4);border-radius:12px;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.35);background:linear-gradient(135deg,rgba(14,165,233,0.05),rgba(14,165,233,0.03));}
.dpro-ticket-stage-overlay .dpro-tpl-elem{position:absolute;padding:8px 10px;border:1px dashed #0b79d0;border-radius:12px;background:rgba(255,255,255,0.92);color:#0b1a2b;font-weight:600;cursor:move;box-shadow:0 22px 44px -32px rgba(11,121,208,0.55);user-select:none;display:flex;flex-direction:column;gap:4px;justify-content:space-between;}
.dpro-ticket-stage-overlay .dpro-tpl-elem.is-selected{box-shadow:0 0 0 2px #0b79d0,0 26px 48px -34px rgba(7,52,92,0.55);}
.dpro-ticket-stage-overlay .dpro-tpl-elem .dpro-resize-handle{position:absolute;width:12px;height:12px;border-radius:50%;background:#0b79d0;right:-6px;bottom:-6px;border:2px solid #fff;cursor:nwse-resize;box-shadow:0 2px 6px rgba(7,52,92,0.45);}
.dpro-tpl-label{font-size:12px;letter-spacing:.01em;color:#0f172a;opacity:.8;}
.dpro-tpl-value{font-size:14px;font-weight:700;color:#0b1a2b;line-height:1.3;word-break:break-word;}
.dpro-tpl-qr{position:relative;flex:1 1 auto;border-radius:12px;background:linear-gradient(135deg,rgba(15,23,42,0.08),rgba(11,121,208,0.18));display:flex;align-items:center;justify-content:center;overflow:hidden;}
.dpro-tpl-qr::after{content:"";width:64%;height:64%;border-radius:6px;background:repeating-linear-gradient(45deg,rgba(15,23,42,0.78) 0,rgba(15,23,42,0.78) 6px,transparent 6px,transparent 10px),repeating-linear-gradient(-45deg,rgba(11,121,208,0.45) 0,rgba(11,121,208,0.45) 6px,transparent 6px,transparent 10px);opacity:.75;}
.dpro-tpl-logo{display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.9);border:1px dashed rgba(12,74,110,0.35);border-radius:12px;flex:1 1 auto;overflow:hidden;}
.dpro-tpl-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.dpro-tpl-placeholder-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#0b79d0;background:rgba(11,121,208,0.08);border:1px dashed rgba(11,121,208,0.38);padding:6px 8px;border-radius:10px;}
.dpro-ticket-stage-overlay .dpro-tpl-elem[data-field="brand_logo"]{background:rgba(255,255,255,0.96);}
.dpro-ticket-control{display:flex;flex-direction:column;gap:18px;}
.dpro-ticket-panels{display:flex;flex-direction:column;gap:18px;}
.dpro-ticket-panel{background:rgba(255,255,255,0.98);border-radius:18px;padding:18px;border:1px solid rgba(12,74,110,0.12);box-shadow:0 28px 56px -42px rgba(7,52,92,0.55);display:flex;flex-direction:column;gap:16px;}
.dpro-ticket-panel[hidden]{display:none;}
.dpro-ticket-stage-settings{display:flex;gap:12px;flex-wrap:wrap;}
.dpro-ticket-stage-settings label{display:flex;flex-direction:column;font-weight:600;color:#0b1a2b;gap:4px;}
.dpro-ticket-stage-settings input{padding:8px 10px;border:1px solid rgba(12,74,110,0.2);border-radius:10px;background:#fff;}
.dpro-ticket-branding{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:10px;align-items:flex-end;}
.dpro-ticket-branding label{display:flex;flex-direction:column;font-weight:600;color:#0b1a2b;gap:6px;}
.dpro-ticket-branding input[type="color"]{width:100%;min-height:38px;border:1px solid rgba(12,74,110,0.2);border-radius:10px;padding:4px;background:#fff;}
.dpro-ticket-branding__logo{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.dpro-ticket-logo-preview{min-height:40px;min-width:80px;border:1px dashed rgba(12,74,110,0.25);border-radius:10px;padding:6px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#475569;}
.dpro-ticket-inspector{border:1px solid rgba(12,74,110,0.18);border-radius:16px;padding:16px;background:rgba(255,255,255,0.95);display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 40px -36px rgba(7,52,92,0.45);}
.dpro-ticket-inspector h4{margin:0;font-size:15px;color:#0b1a2b;}
.dpro-ticket-inspector-empty{margin:0;font-size:13px;color:#164e63;}
.dpro-ticket-inspector-fields{display:flex;flex-direction:column;gap:10px;}
.dpro-ticket-inspector-fields label{display:flex;flex-direction:column;font-weight:600;color:#0b1a2b;gap:4px;}
.dpro-ticket-inspector-fields input{padding:8px 10px;border:1px solid rgba(12,74,110,0.2);border-radius:10px;}
.dpro-ticket-preview{background:rgba(255,255,255,0.96);border-radius:18px;border:1px solid rgba(12,74,110,0.12);padding:18px;display:flex;flex-direction:column;gap:16px;box-shadow:0 24px 52px -42px rgba(7,52,92,0.45);}
.dpro-ticket-preview__canvas{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:14px;padding:18px;min-height:200px;display:flex;flex-direction:column;gap:16px;justify-content:flex-start;align-items:stretch;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);}
.dpro-ticket-preview__empty{color:#164e63;text-align:center;margin:0;font-weight:600;}
.dpro-ticket-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;align-items:flex-start;}
.dpro-ticket-types{display:flex;flex-direction:column;gap:16px;}
.dpro-ticket-types h4{margin:0;font-size:16px;color:#0b1a2b;}
.dpro-ticket-types .dpro-ticket-list{display:flex;flex-direction:column;gap:14px;}
.dpro-ticket-template-settings{display:flex;flex-direction:column;gap:18px;}
.dpro-ticket-template-actions{display:flex;flex-direction:column;gap:12px;}
.dpro-ticket-template-library{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0;}
.dpro-ticket-template-library button{flex:0 0 auto;}
.dpro-ticket-template-meta{margin:0;font-size:13px;color:#0b1a2b;font-weight:600;}
.dpro-ticket-template-buttons{display:flex;flex-wrap:wrap;gap:10px;}
.dpro-ticket-preview__frame{position:relative;width:min(100%,640px);margin:0 auto 18px auto;aspect-ratio:var(--ticket-width,1100px)/var(--ticket-height,520px);border-radius:26px;box-shadow:0 28px 60px -28px rgba(11,36,64,0.45);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;}
.dpro-ticket-preview__frame::before{content:"";position:absolute;inset:0;background:var(--ticket-background,linear-gradient(135deg,#cbd5f5,#eef2ff));background-size:cover;background-position:center;filter:saturate(1.05);opacity:.96;transition:opacity .3s ease;}
.dpro-ticket-preview__frame.is-blank::before{background:linear-gradient(135deg,#cbd5f5,#eef2ff);opacity:.75;}
.dpro-ticket-preview__canvas{position:relative;width:100%;height:100%;}
.dpro-ticket-preview__overlay{position:absolute;inset:0;pointer-events:none;}
.dpro-ticket-preview__field{position:absolute;display:flex;flex-direction:column;justify-content:flex-start;gap:6px;padding:10px 12px;background:rgba(255,255,255,0.86);border-radius:18px;box-shadow:0 20px 40px -30px rgba(8,24,48,0.5);backdrop-filter:blur(6px);border:1px solid var(--ticket-brand-accent, rgba(255,255,255,0.45));transform:translateZ(0);transition:transform .3s ease,box-shadow .3s ease;}
.dpro-ticket-preview__field-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ticket-label-color,#334155);opacity:.85;}
.dpro-ticket-preview__field-value{font-size:clamp(14px,1.5vw,20px);font-weight:600;color:var(--ticket-brand-text,#0f172a);line-height:1.2;max-width:100%;word-wrap:break-word;}
.dpro-ticket-preview__field--qr{align-items:center;justify-content:center;padding:14px;background:rgba(15,23,42,0.12);box-shadow:none;border:1px dashed rgba(15,23,42,0.25);}
.dpro-ticket-preview__qr{width:100%;height:100%;border-radius:16px;background-image:repeating-linear-gradient(45deg,rgba(15,23,42,0.28) 0,rgba(15,23,42,0.28) 6px,transparent 6px,transparent 12px);position:relative;overflow:hidden;}
.dpro-ticket-preview__qr::after{content:"";position:absolute;inset:18%;border-radius:12px;border:2px solid rgba(255,255,255,0.7);}
.dpro-ticket-preview__field-logo{display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.9);border-radius:12px;border:1px dashed rgba(11,121,208,0.25);padding:6px;min-height:70px;}
.dpro-ticket-preview__field-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.dpro-ticket-preview__logo{position:absolute;top:12px;right:12px;max-height:48px;max-width:160px;object-fit:contain;border-radius:8px;box-shadow:0 8px 20px -12px rgba(15,23,42,0.45);background:rgba(255,255,255,0.9);padding:6px;}
.dpro-ticket-preview__field-caption{margin-top:8px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#334155;opacity:.85;}
.dpro-ticket-preview__frame:hover{transform:translateY(-4px);box-shadow:0 32px 70px -28px rgba(11,36,64,0.5);}
.dpro-ticket-preview__frame:hover .dpro-ticket-preview__field{box-shadow:0 24px 54px -28px rgba(8,24,48,0.55);}
.dpro-ticket-preview__frame:hover::before{opacity:1;}
@media (max-width:960px){
  .dpro-ticket-designer-main{grid-template-columns:1fr;}
}
@media (max-width:820px){
  .dpro-ticket-preview__frame{width:100%;border-radius:22px;}
  .dpro-ticket-preview__field{padding:8px 10px;border-radius:14px;}
  .dpro-ticket-preview__field-value{font-size:clamp(13px,3.6vw,18px);}
  .dpro-ticket-preview__qr::after{inset:20%;}
  .dpro-ticket-preview-grid{grid-template-columns:1fr;}
}
.dpro-ticket-modal__footer{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap;}


/* Scanner panel */
.dpro-scanner-panel{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:18px;background:rgba(255,255,255,0.95);border-radius:20px;padding:24px;border:1px solid rgba(12,74,110,0.12);box-shadow:0 24px 52px -42px rgba(7,52,92,0.45);}
.dpro-scanner-intro{margin:0;color:#0f3c6e;font-size:15px;}
.dpro-scanner-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.dpro-scanner-select{padding:10px 12px;border-radius:12px;border:1px solid rgba(12,74,110,0.25);min-width:220px;background:#fff;color:#0b1a2b;}
.dpro-scanner-status{min-height:26px;font-size:14px;color:#0b1a2b;}
.dpro-scanner-mount{min-height:320px;border:1px dashed rgba(12,74,110,0.2);border-radius:18px;background:linear-gradient(135deg,rgba(241,245,249,0.8),rgba(224,242,255,0.6));display:flex;align-items:center;justify-content:center;padding:12px;color:#164e63;text-align:center;}
.dpro-scanner-help{margin:0;font-size:13px;color:#0f3c6e;}


.dpro-analytics-controls{margin-bottom:16px;}
.dpro-analytics-controls select{padding:10px 12px;border-radius:8px;border:1px solid #dbe2f2;min-width:240px;}
.dpro-analytics-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;align-items:start;}
.dpro-analytics-card{background:#f8fafc;border-radius:14px;padding:16px;border:1px solid #ebeff5;}
.dpro-analytics-summary p{margin:0;color:#475569;line-height:1.5;}

.dpro-settings-panel form{display:flex;flex-direction:column;gap:24px;max-width:520px;}
.dpro-settings-panel fieldset{border:1px solid #ebeff5;border-radius:12px;padding:18px;display:flex;flex-direction:column;gap:12px;}
.dpro-settings-panel legend{font-weight:700;color:#1f2d3d;padding:0 6px;}
.dpro-settings-panel label{display:flex;flex-direction:column;font-weight:600;color:#334155;gap:6px;}
.dpro-settings-panel input[type="text"],.dpro-settings-panel input[type="password"]{padding:10px 12px;border-radius:8px;border:1px solid #dbe2f2;}
.dpro-toggle{flex-direction:row!important;align-items:center;gap:10px;font-weight:600;color:#475569;}
.dpro-settings-actions{display:flex;gap:12px;align-items:center;}
.dpro-settings-feedback{min-height:24px;font-size:13px;color:#0f766e;}
.dpro-settings-feedback.error{color:#b91c1c;}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

@media (max-width:900px){
    .dpro-ticket-modal{padding:18px 12px;}
    .dpro-ticket-modal__inner{max-height:calc(92vh - 18px);}
    .dpro-ticket-designer-main{grid-template-columns:1fr;}
    .dpro-ticket-preview{margin-top:12px;}
}

@media (max-width:720px){
    .dpro-seatmap-body{flex-direction:column;}
    .dpro-seatmap-layout{flex-direction:column;}
    .dpro-seatmap-stage-wrap,.dpro-seatmap-sidebar{flex:1 1 100%;}
}

@media (max-width:600px){
    .dpro-dashboard-tabs{overflow:auto;}
    .dpro-ticket-row{grid-template-columns:1fr;}
    .dpro-events-listing .dpro-col-actions{text-align:left;}
    .dpro-dashboard-content{padding:16px;}
    .dpro-ticket-modal__inner{padding:22px 18px;}
}
.dpro-panel{display:none;}
.dpro-panel.active{display:block;}
.dpro-events-table{width:100%;border-collapse:collapse;margin-top:10px;}
.dpro-events-table th{background:#f6f9fc;color:#163856;padding:10px;text-align:left;border-bottom:1px solid #e6eef6;font-weight:600;}
.dpro-events-table td{padding:10px;border-bottom:1px solid #f1f6fb;}
.dpro-wizard-step label{display:block;margin:10px 0;}
.dpro-dates-grid{display:flex;gap:12px;}
.dpro-wizard-actions{margin-top:12px;}
.dpro-ticket-row{display:grid;gap:14px;padding:16px;border:1px solid rgba(12,74,110,0.12);border-radius:14px;background:rgba(255,255,255,0.92);box-shadow:0 14px 34px -32px rgba(7,52,92,0.45);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end;position:relative;}
.dpro-ticket-row+.dpro-ticket-row{margin-top:14px;}
.dpro-ticket-field{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#0b1a2b;}
.dpro-ticket-field span{font-size:13px;letter-spacing:.01em;}
.dpro-ticket-field input,.dpro-ticket-field textarea{padding:10px 12px;border-radius:10px;border:1px solid rgba(12,74,110,0.18);background:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);width:100%;box-sizing:border-box;}
.dpro-ticket-field textarea{resize:vertical;min-height:70px;font-size:13px;line-height:1.5;}
.dpro-ticket-preview-actions--card{align-items:flex-start;justify-content:space-between;padding:16px 18px;background:rgba(226,232,240,0.35);border-radius:16px;border:1px solid rgba(148,163,184,0.35);box-shadow:0 14px 30px -26px rgba(7,52,92,0.38);}
.dpro-ticket-preview-actions--card .dpro-ticket-preview-actions__text{display:flex;flex-direction:column;gap:6px;max-width:640px;}
.dpro-ticket-preview-actions--card h4{margin:0;font-size:16px;color:#0b1a2b;}
.dpro-ticket-preview-actions__cta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.dpro-ticket-field--wide{grid-column:1/-1;}
.dpro-ticket-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end;align-items:center;margin-top:2px;}
.dpro-ticket-actions .dpro-button--ghost{padding:8px 14px;border-radius:10px;}
.dpro-ticket-actions .dpro-button--link{position:static;padding:6px;border-radius:999px;font-size:18px;line-height:1;color:#0f3c6e;opacity:.75;}
.dpro-ticket-actions .dpro-button--link:hover{opacity:1;color:#0b79d0;}
.help-text{font-size:13px;color:#66788a;margin-bottom:8px;}
.dpro-dashboard .button{padding:8px 16px;border-radius:999px;background:#1e73be;color:#fff;border:none;cursor:pointer;font-weight:600;box-shadow:0 10px 24px -18px rgba(30,115,190,0.8);transition:transform .12s ease, box-shadow .12s ease;}
.dpro-dashboard .button:hover{transform:translateY(-1px);box-shadow:0 18px 32px -20px rgba(30,115,190,0.65);}
.dpro-dashboard .button:focus{outline:2px solid rgba(30,115,190,0.35);outline-offset:2px;}
.dpro-dashboard .button.button-link{background:transparent;color:#0b79d0;box-shadow:none;padding:0;}
.dpro-dashboard .button.button-secondary{background:#0f3c6e;}
.dpro-dashboard .button.button-primary{background:#0b79d0;}
.dpro-settings-status{margin:0 0 10px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;}
.dpro-settings-status.is-connected{color:#0a7a2e;}
.dpro-settings-status.is-disconnected{color:#b54708;}
.dpro-ticket-preview__header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.dpro-ticket-preview__switcher{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.dpro-ticket-preview__switcher-btn{line-height:1.2;}
.dpro-ticket-preview__switcher-btn.is-active{background:#0ea5e9;color:#0b172a;box-shadow:0 8px 30px -12px rgba(14,165,233,0.55);}

.dpro-review-preview{border:1px solid #e5e7eb;border-radius:12px;padding:12px;min-height:160px;display:flex;align-items:center;justify-content:center;background:#f8fafc;}
.dpro-review-ticket-frame{max-width:100%;box-shadow:0 12px 30px rgba(15,23,42,0.12);border-radius:12px;overflow:hidden;}
.dpro-review-ticket-meta{margin-top:10px;font-size:13px;color:var(--dpro-muted);}
.dpro-review-ticket-summary,.dpro-review-seating-summary{font-size:14px;color:#111827;line-height:1.5;}
.dpro-review-ticket-summary .dpro-review-list,.dpro-review-seating-summary .dpro-review-list{padding-left:16px;}
.dpro-ticket-builder__actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.dpro-ticket-builder__helper{margin:6px 0 0;color:#334155;font-size:14px;}
.dpro-ticketing-mode{border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px;margin:0 0 16px;background:#fafbfc;}
.dpro-ticketing-mode__title{font-weight:600;margin:0 0 8px;}
.dpro-ticketing-mode__choices{display:flex;gap:10px;flex-wrap:wrap;}
.dpro-ticketing-mode__choice{display:flex;gap:10px;align-items:flex-start;border:1px solid #d7dbe0;border-radius:10px;padding:10px 12px;cursor:pointer;background:#fff;position:relative;overflow:hidden;}
.dpro-ticketing-mode__choice.is-disabled{opacity:.6;cursor:not-allowed;}
.dpro-ticketing-mode__choice.is-disabled input{pointer-events:none;}
.dpro-ticketing-mode__choice.has-overlay .dpro-ticketing-mode__overlay{display:flex;}
.dpro-ticketing-mode__overlay{position:absolute;inset:0;background:rgba(15,23,42,0.65);color:#f8fafc;display:none;align-items:center;justify-content:center;font-weight:700;font-size:14px;letter-spacing:.02em;text-transform:uppercase;}
.dpro-ticketing-mode__choice input{margin-top:4px;}
.dpro-ticketing-mode__choice strong{display:block;font-size:14px;}
.dpro-ticketing-mode__choice small{display:block;color:#6b7280;}
.dpro-ticketing-mode__helper{margin:8px 0 0;color:#6b7280;}
.dpro-ticketless-notice{border:1px dashed #d7dbe0;padding:10px 12px;border-radius:10px;background:#f8fafc;color:#475569;margin:0 0 14px;}
.dpro-panel-placeholder{border:1px dashed #d7dbe0;border-radius:12px;padding:22px 18px;background:#f8fafc;color:#0f172a;text-align:left;}
.dpro-panel-placeholder h3{margin:0 0 6px;font-size:18px;}
.dpro-panel-placeholder p{margin:0;color:#475569;}
.dpro-rsvp-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:12px;align-items:flex-end;}
.dpro-rsvp-field{display:flex;flex-direction:column;gap:4px;font-size:14px;}
.dpro-rsvp-field span{color:#0f172a;font-weight:600;}
.dpro-rsvp-field input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;}
.dpro-rsvp-message{grid-column:1/-1;margin:8px 0 0;font-size:14px;color:#0f172a;}
.dpro-rsvp-message.is-error{color:#b91c1c;}
.dpro-ticket-builder.is-ticketless{opacity:.6;pointer-events:none;}
.dpro-ticketless,.dpro-events-card__ticketless,.dpro-calendar-card__cta.is-disabled{background:#e2e8f0;color:#1f2937;}
.dpro-events-card__ticketless{font-weight:600;}
