.dkpe-shell,
.dkpe-shell * {
  box-sizing: border-box;
}

.dkpe-shell {
  --dkpe-height: 78vh;
  --dkpe-accent: #ff1f2d;
  --dkpe-text: #fff;
  --dkpe-muted: rgba(255,255,255,.72);
  --dkpe-line: rgba(255,255,255,.14);
  --dkpe-overlay: 58%;
  --dkpe-overlay-mobile: 78%;
  --dkpe-content-width: 780px;
  --dkpe-panel-width: 360px;
  position: relative;
  width: 100%;
  min-height: var(--dkpe-height);
  color: var(--dkpe-text);
  font-family: Inter, Arial, sans-serif;
  overflow: hidden;
  background: #050505;
  isolation: isolate;
}

.dkpe-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(transparent 0, rgba(255,255,255,.025) 1px, transparent 2px);
  background-size: 100% 4px;
  mix-blend-mode: screen;
  opacity: .22;
}

.dkpe-shell::after {
  content: "";
  position: absolute;
  z-index: 3;
  inset: auto -12% -22% -12%;
  height: 42%;
  pointer-events: none;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--dkpe-accent) 24%, transparent), transparent 62%);
  filter: blur(18px);
  opacity: .78;
}

.dkpe-swiper {
  width: 100%;
  height: var(--dkpe-height);
  min-height: 520px;
  position: relative;
  overflow: hidden;
  background: #080808;
}

.dkpe-slide {
  position: relative;
  overflow: hidden;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.dkpe-slide::before {
  content: "";
  position: absolute;
  z-index: 2;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0, transparent 42%, rgba(255,255,255,.08) 49%, transparent 57%, transparent 100%);
  transform: translateX(-70%);
  opacity: 0;
}

.dkpe-slide.swiper-slide-active::before {
  animation: dkpeSweep 1200ms ease-out 180ms both;
}

.dkpe-bg {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.035);
  opacity: .92;
  will-change: transform;
  transition: transform 900ms ease, opacity 300ms ease;
}

.dkpe-slide.swiper-slide-active .dkpe-bg {
  transform: scale(1);
}

.dkpe-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 72% 38%, rgba(255,255,255,.08), transparent 30%),
    linear-gradient(90deg, rgba(0,0,0,.9) 0%, rgba(0,0,0,.68) 42%, rgba(0,0,0,calc(var(--dkpe-overlay)/100)) 100%);
}

.dkpe-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0,1fr) var(--dkpe-panel-width);
  gap: 42px;
  align-items: center;
  width: min(1240px, calc(100% - 80px));
  height: 100%;
  margin: 0 auto;
  padding: 70px 0 86px;
}

.dkpe-shell.dkpe-panel-left .dkpe-main {
  grid-column: 2;
}

.dkpe-shell.dkpe-panel-left .dkpe-panel {
  grid-column: 1;
  grid-row: 1;
}

.dkpe-shell.dkpe-panel-hide .dkpe-grid {
  grid-template-columns: minmax(0,1fr);
}

.dkpe-shell.dkpe-panel-hide .dkpe-panel {
  display: none;
}

.dkpe-main {
  max-width: var(--dkpe-content-width);
}

.dkpe-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  max-width: 720px;
  margin-bottom: 16px;
}

.dkpe-kicker {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  font-weight: 800;
  color: rgba(255,255,255,.84);
}

.dkpe-topline .dkpe-kicker {
  margin-bottom: 0;
}

.dkpe-kicker span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--dkpe-accent);
  box-shadow: 0 0 18px var(--dkpe-accent);
}

.dkpe-kicker em {
  font-style: normal;
  color: #fff;
  border: 1px solid rgba(255,255,255,.16);
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  letter-spacing: .08em;
}

.dkpe-slide-count {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(0,0,0,.26);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.dkpe-slide-count b {
  font-size: 14px;
  color: #fff;
}

.dkpe-slide-count span {
  font-size: 11px;
  color: rgba(255,255,255,.48);
}

.dkpe-logo {
  display: block;
  max-width: 230px;
  max-height: 72px;
  object-fit: contain;
  margin: 0 0 20px;
  filter: drop-shadow(0 10px 25px rgba(0,0,0,.45));
}

.dkpe-title {
  position: relative;
  margin: 0;
  font-size: clamp(42px,6vw,92px);
  line-height: .94;
  font-weight: 900;
  letter-spacing: -.07em;
  text-transform: uppercase;
  color: var(--dkpe-text);
  text-shadow: 0 24px 55px rgba(0,0,0,.55);
}

.dkpe-title::after {
  content: "";
  display: block;
  width: min(160px,34vw);
  height: 3px;
  margin-top: 18px;
  background: linear-gradient(90deg, var(--dkpe-accent), rgba(255,255,255,.12), transparent);
  box-shadow: 0 0 22px var(--dkpe-accent);
  border-radius: 999px;
}

.dkpe-subtitle {
  margin-top: 12px;
  font-size: clamp(17px,2vw,25px);
  font-weight: 800;
  letter-spacing: -.03em;
  color: rgba(255,255,255,.82);
}

.dkpe-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 8px 11px;
  border: 1px solid color-mix(in srgb, var(--dkpe-accent) 40%, rgba(255,255,255,.16));
  border-radius: 999px;
  background: rgba(0,0,0,.32);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 10px;
  font-weight: 950;
  box-shadow: 0 0 24px color-mix(in srgb, var(--dkpe-accent) 18%, transparent);
}

.dkpe-badge::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--dkpe-accent);
  box-shadow: 0 0 16px var(--dkpe-accent);
}

.dkpe-desc {
  max-width: 640px;
  margin: 18px 0 0;
  font-size: 15px;
  line-height: 1.7;
  color: var(--dkpe-muted);
}

.dkpe-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.dkpe-actions a,
.dkpe-actions button {
  position: relative;
  overflow: hidden;
  appearance: none;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.08);
  color: #fff;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-size: 12px;
  font-weight: 900;
  padding: 14px 19px;
  border-radius: 999px;
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.dkpe-actions a::before,
.dkpe-actions button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent, rgba(255,255,255,.22), transparent);
  transform: translateX(-120%);
  transition: transform .55s ease;
}

.dkpe-actions a:hover,
.dkpe-actions button:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.45);
}

.dkpe-actions a:hover::before,
.dkpe-actions button:hover::before {
  transform: translateX(120%);
}

.dkpe-case-btn {
  border-color: color-mix(in srgb, var(--dkpe-accent) 70%, #fff 0%) !important;
  background: var(--dkpe-accent) !important;
  box-shadow: 0 0 28px color-mix(in srgb, var(--dkpe-accent) 52%, transparent);
}

.dkpe-panel {
  position: relative;
  overflow: hidden;
  align-self: center;
  border: 1px solid var(--dkpe-line);
  background: linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.045));
  box-shadow: 0 24px 80px rgba(0,0,0,.32);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: 26px;
  padding: 24px;
}

.dkpe-panel::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--dkpe-accent), transparent);
  opacity: .9;
}

.dkpe-panel-title {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 18px;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 11px;
  font-weight: 900;
  color: rgba(255,255,255,.62);
}

.dkpe-panel-title span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #18ff72;
  box-shadow: 0 0 16px #18ff72;
}

.dkpe-metrics {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.dkpe-metrics div {
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,.12);
}

.dkpe-metrics strong {
  display: block;
  font-size: 32px;
  line-height: 1;
  font-weight: 950;
  color: #fff;
  letter-spacing: -.05em;
  text-shadow: 0 0 20px color-mix(in srgb, var(--dkpe-accent) 22%, transparent);
}

.dkpe-metrics span {
  display: block;
  margin-top: 6px;
  color: rgba(255,255,255,.68);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.dkpe-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.dkpe-tags span {
  font-size: 11px;
  color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  border-radius: 999px;
  padding: 7px 9px;
}

.dkpe-terminal {
  width: min(540px,100%);
  margin-top: 24px;
  border: 1px solid rgba(255,255,255,.12);
  border-left: 2px solid var(--dkpe-accent);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(8,8,10,.66), rgba(0,0,0,.42));
  box-shadow: 0 24px 70px rgba(0,0,0,.28), 0 0 30px color-mix(in srgb, var(--dkpe-accent) 12%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}

.dkpe-shell.dkpe-terminal-compact .dkpe-terminal {
  width: min(420px,100%);
  margin-top: 18px;
  border-radius: 14px;
}

.dkpe-shell.dkpe-terminal-hidden .dkpe-terminal {
  display: none !important;
}

.dkpe-terminal-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 10px 13px;
  border-bottom: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.045);
}

.dkpe-shell.dkpe-terminal-compact .dkpe-terminal-head {
  padding: 8px 11px;
}

.dkpe-terminal-head i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--dkpe-accent);
  box-shadow: 0 0 18px var(--dkpe-accent);
}

.dkpe-terminal-head strong {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
  font-weight: 950;
}

.dkpe-terminal-head span {
  margin-left: auto;
  font-size: 9px;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 7px;
}

.dkpe-terminal-lines {
  padding: 12px 14px 14px;
}

.dkpe-shell.dkpe-terminal-compact .dkpe-terminal-lines {
  padding: 10px 12px 12px;
}

.dkpe-terminal-lines p {
  margin: 0;
  color: rgba(255,255,255,.72);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 11px;
  line-height: 1.75;
  letter-spacing: .01em;
}

.dkpe-shell.dkpe-terminal-compact .dkpe-terminal-lines p {
  font-size: 10px;
  line-height: 1.6;
}

.dkpe-slide.swiper-slide-active .dkpe-terminal-lines p:nth-child(1) {
  animation: dkpeType .42s steps(24,end) .46s both;
}

.dkpe-slide.swiper-slide-active .dkpe-terminal-lines p:nth-child(2) {
  animation: dkpeType .48s steps(28,end) .72s both;
}

.dkpe-slide.swiper-slide-active .dkpe-terminal-lines p:nth-child(3) {
  animation: dkpeType .42s steps(24,end) .96s both;
}

.dkpe-filters {
  position: absolute;
  z-index: 6;
  left: 50%;
  bottom: 52px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  max-width: calc(100% - 40px);
  overflow: auto;
  padding: 7px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 999px;
  scrollbar-width: none;
  box-shadow: 0 16px 50px rgba(0,0,0,.26);
}

.dkpe-filters::-webkit-scrollbar {
  display: none;
}

.dkpe-filters button {
  appearance: none;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.68);
  white-space: nowrap;
  border-radius: 999px;
  padding: 9px 13px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  cursor: pointer;
  transition: background .22s ease, color .22s ease, transform .22s ease;
}

.dkpe-filters button:hover {
  transform: translateY(-1px);
  color: #fff;
}

.dkpe-filters button.is-active {
  background: #fff;
  color: #050505;
  box-shadow: 0 0 18px rgba(255,255,255,.12);
}

.dkpe-nav {
  position: absolute;
  z-index: 5;
  top: 50%;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(0,0,0,.35);
  border-radius: 999px;
  cursor: pointer;
  transform: translateY(-50%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.dkpe-prev {
  left: 22px;
}

.dkpe-next {
  right: 22px;
}

.dkpe-nav::before {
  content: "";
  position: absolute;
  inset: 15px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

.dkpe-prev::before {
  transform: rotate(-135deg);
  left: 17px;
}

.dkpe-next::before {
  transform: rotate(45deg);
  right: 17px;
}

.dkpe-pagination {
  position: absolute !important;
  z-index: 4;
  bottom: 18px !important;
  left: 50% !important;
  width: auto !important;
  transform: translateX(-50%);
}

.dkpe-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #fff;
  opacity: .28;
}

.dkpe-pagination .swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--dkpe-accent);
  box-shadow: 0 0 18px var(--dkpe-accent);
}

.dkpe-progress {
  position: absolute;
  z-index: 5;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: rgba(255,255,255,.16);
}

.dkpe-progress span {
  display: block;
  width: 0;
  height: 100%;
  background: var(--dkpe-accent);
  box-shadow: 0 0 18px var(--dkpe-accent);
  transition: width .35s ease;
}

.dkpe-modal {
  position: absolute;
  z-index: 20;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 32px 24px;
}

.dkpe-modal.is-open {
  display: flex;
}

.dkpe-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.dkpe-modal-card {
  position: relative;
  inset: auto;
  width: min(980px,100%);
  max-width: calc(100% - 16px);
  max-height: min(78vh, calc(100% - 64px));
  margin: 0;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(16,16,18,.96), rgba(5,5,5,.96));
  border-radius: 28px;
  box-shadow: 0 40px 120px rgba(0,0,0,.55);
  overflow: auto;
  color: #fff;
  scrollbar-width: thin;
  scrollbar-color: var(--dkpe-accent) rgba(255,255,255,.08);
}

.dkpe-modal-card::-webkit-scrollbar {
  width: 8px;
}

.dkpe-modal-card::-webkit-scrollbar-thumb {
  background: var(--dkpe-accent);
  border-radius: 999px;
}

.dkpe-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  width: 34px;
  height: 34px;
  border: 0;
  background: transparent !important;
  color: var(--dkpe-accent) !important;
  border-radius: 999px;
  font-size: 28px;
  line-height: 34px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: none;
  text-shadow: 0 0 10px color-mix(in srgb, var(--dkpe-accent) 72%, transparent), 0 0 22px color-mix(in srgb, var(--dkpe-accent) 40%, transparent);
  transition: transform .18s ease, color .18s ease, text-shadow .18s ease, opacity .18s ease;
  opacity: .95;
}

.dkpe-modal-close:hover,
.dkpe-modal-close:focus-visible {
  transform: scale(1.08);
  color: #ff4b57 !important;
  text-shadow: 0 0 12px color-mix(in srgb, var(--dkpe-accent) 86%, transparent), 0 0 28px color-mix(in srgb, var(--dkpe-accent) 58%, transparent);
  outline: none;
}

.dkpe-modal-content {
  padding: 40px 38px 34px;
}

.dkpe-modal-content .dkpe-modal-meta {
  color: rgba(255,255,255,.64);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 18px;
}

.dkpe-modal-content h3 {
  font-size: clamp(34px,5vw,70px);
  line-height: .95;
  letter-spacing: -.06em;
  text-transform: uppercase;
  margin: 0 0 8px;
}

.dkpe-modal-content p {
  margin: 0;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  font-size: 14px;
}

.dkpe-modal-content .dkpe-modal-grid {
  display: grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  gap: 16px;
  margin-top: 24px;
  align-items: start;
}

.dkpe-modal-content .dkpe-modal-box {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.055);
  border-radius: 22px;
  padding: 20px;
}

.dkpe-modal-content .dkpe-modal-box::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--dkpe-accent);
  box-shadow: 0 0 16px var(--dkpe-accent);
}

.dkpe-modal-content h4 {
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: 12px;
  color: #fff;
}

.dkpe-modal-content a {
  display: inline-flex;
  margin-top: 28px;
  background: var(--dkpe-accent);
  color: #fff;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-size: 12px;
  font-weight: 900;
  padding: 14px 18px;
  border-radius: 999px;
}

.dkpe-main .dkpe-kicker,
.dkpe-logo,
.dkpe-title,
.dkpe-subtitle,
.dkpe-badge,
.dkpe-desc,
.dkpe-actions,
.dkpe-terminal,
.dkpe-panel {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 520ms ease, transform 520ms ease;
}

.dkpe-slide.swiper-slide-active .dkpe-kicker,
.dkpe-slide.swiper-slide-active .dkpe-logo,
.dkpe-slide.swiper-slide-active .dkpe-title,
.dkpe-slide.swiper-slide-active .dkpe-subtitle,
.dkpe-slide.swiper-slide-active .dkpe-badge,
.dkpe-slide.swiper-slide-active .dkpe-desc,
.dkpe-slide.swiper-slide-active .dkpe-actions,
.dkpe-slide.swiper-slide-active .dkpe-terminal,
.dkpe-slide.swiper-slide-active .dkpe-panel {
  opacity: 1;
  transform: none;
}

.dkpe-slide.swiper-slide-active .dkpe-kicker { transition-delay: 80ms; }
.dkpe-slide.swiper-slide-active .dkpe-logo { transition-delay: 130ms; }
.dkpe-slide.swiper-slide-active .dkpe-title { transition-delay: 160ms; }
.dkpe-slide.swiper-slide-active .dkpe-subtitle { transition-delay: 220ms; }
.dkpe-slide.swiper-slide-active .dkpe-badge { transition-delay: 250ms; }
.dkpe-slide.swiper-slide-active .dkpe-desc { transition-delay: 290ms; }
.dkpe-slide.swiper-slide-active .dkpe-actions { transition-delay: 340ms; }
.dkpe-slide.swiper-slide-active .dkpe-terminal { transition-delay: 400ms; }
.dkpe-slide.swiper-slide-active .dkpe-panel { transition-delay: 260ms; }

@keyframes dkpeSweep {
  0% { opacity: 0; transform: translateX(-78%); }
  28% { opacity: .42; }
  100% { opacity: 0; transform: translateX(78%); }
}

@keyframes dkpeType {
  0% { clip-path: inset(0 100% 0 0); opacity: .25; }
  100% { clip-path: inset(0 0 0 0); opacity: 1; }
}

@media (max-width:1366px), (max-height:860px) {
  .dkpe-modal {
    padding: 24px 18px;
  }

  .dkpe-modal-card {
    max-height: min(74vh, calc(100% - 48px));
    border-radius: 24px;
  }

  .dkpe-modal-content {
    padding: 34px 30px 28px;
  }

  .dkpe-modal-content .dkpe-modal-grid {
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
}

@media (max-width:1024px) {
  .dkpe-shell {
    min-height: 100svh;
  }

  .dkpe-shell::before {
    opacity: .1;
  }

  .dkpe-swiper {
    height: 100svh;
    min-height: 640px;
  }

  .dkpe-grid {
    grid-template-columns: 1fr;
    width: min(100% - 42px,760px);
    gap: 22px;
    padding: 74px 0 82px;
  }

  .dkpe-panel,
  .dkpe-terminal,
  .dkpe-nav,
  .dkpe-slide-count,
  .dkpe-slide::before {
    display: none;
  }

  .dkpe-topline {
    align-items: flex-start;
  }

  .dkpe-title {
    font-size: clamp(42px,13vw,72px);
  }

  .dkpe-title::after {
    width: 116px;
    margin-top: 14px;
  }

  .dkpe-desc {
    font-size: 14px;
  }

  .dkpe-bg {
    transform: none !important;
  }

  .dkpe-overlay {
    background: linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,calc(var(--dkpe-overlay-mobile)/100)));
  }

  .dkpe-filters {
    bottom: 48px;
    justify-content: center;
    max-width: calc(100% - 28px);
  }

  .dkpe-pagination {
    bottom: 14px !important;
  }

  .dkpe-modal {
    padding: 16px 12px;
  }

  .dkpe-modal-card {
    width: min(100%,calc(100% - 8px));
    max-height: calc(100% - 24px);
    border-radius: 22px;
  }

  .dkpe-modal-content {
    padding: 42px 22px 24px;
  }

  .dkpe-modal-content .dkpe-modal-grid {
    grid-template-columns: 1fr;
  }

  .dkpe-main .dkpe-kicker,
  .dkpe-logo,
  .dkpe-title,
  .dkpe-subtitle,
  .dkpe-badge,
  .dkpe-desc,
  .dkpe-actions,
  .dkpe-panel {
    transition-duration: 360ms;
  }
}

@media (max-width:767px), (max-height:700px) {
  .dkpe-modal {
    padding: 12px 8px;
  }

  .dkpe-modal-card {
    max-height: calc(100% - 16px);
    border-radius: 18px;
  }

  .dkpe-modal-content {
    padding: 38px 18px 20px;
  }

  .dkpe-modal-content h3 {
    font-size: clamp(28px,9vw,42px);
  }
}

@media (max-width:767px) {
  .dkpe-swiper {
    min-height: 600px;
  }

  .dkpe-grid {
    width: calc(100% - 32px);
    align-items: end;
  }

  .dkpe-kicker {
    font-size: 10px;
    letter-spacing: .11em;
    flex-wrap: wrap;
  }

  .dkpe-title {
    letter-spacing: -.055em;
  }

  .dkpe-title::after {
    height: 2px;
  }

  .dkpe-subtitle {
    font-size: 16px;
  }

  .dkpe-badge {
    font-size: 9px;
    padding: 7px 9px;
  }

  .dkpe-actions {
    gap: 9px;
  }

  .dkpe-actions a,
  .dkpe-actions button {
    font-size: 10px;
    padding: 12px 13px;
  }

  .dkpe-filters {
    bottom: 40px;
    max-width: calc(100% - 18px);
    padding: 5px 6px;
  }

  .dkpe-filters button {
    font-size: 10px;
    padding: 8px 10px;
  }

  .dkpe-logo {
    max-width: 170px;
    max-height: 54px;
  }

  .dkpe-pagination {
    bottom: 12px !important;
  }

  .dkpe-modal-close {
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    font-size: 26px;
    line-height: 32px;
  }

  .dkpe-shell::after {
    opacity: .48;
  }
}

@supports (height:100dvh) {
  @media (max-width:1024px) {
    .dkpe-shell,
    .dkpe-swiper {
      min-height: 100dvh;
    }

    .dkpe-swiper {
      height: 100dvh;
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  .dkpe-shell *,
  .dkpe-slide::before {
    animation: none !important;
    transition: none !important;
  }

  .dkpe-main .dkpe-kicker,
  .dkpe-logo,
  .dkpe-title,
  .dkpe-subtitle,
  .dkpe-badge,
  .dkpe-desc,
  .dkpe-actions,
  .dkpe-terminal,
  .dkpe-panel {
    opacity: 1 !important;
    transform: none !important;
  }

  .dkpe-bg {
    transition: none !important;
  }
}

body.elementor-editor-active .dkpe-main .dkpe-kicker,
body.elementor-editor-active .dkpe-logo,
body.elementor-editor-active .dkpe-title,
body.elementor-editor-active .dkpe-subtitle,
body.elementor-editor-active .dkpe-badge,
body.elementor-editor-active .dkpe-desc,
body.elementor-editor-active .dkpe-actions,
body.elementor-editor-active .dkpe-terminal,
body.elementor-editor-active .dkpe-panel,
body.elementor-editor-preview .dkpe-main .dkpe-kicker,
body.elementor-editor-preview .dkpe-logo,
body.elementor-editor-preview .dkpe-title,
body.elementor-editor-preview .dkpe-subtitle,
body.elementor-editor-preview .dkpe-badge,
body.elementor-editor-preview .dkpe-desc,
body.elementor-editor-preview .dkpe-actions,
body.elementor-editor-preview .dkpe-terminal,
body.elementor-editor-preview .dkpe-panel {
  opacity: 1;
  transform: none;
}

body.elementor-editor-active .dkpe-slide::before,
body.elementor-editor-preview .dkpe-slide::before {
  display: none;
}


/* v0.3.8 — mobile layout regression hotfix after CSS cleanup */
@media (max-width:1024px){
  .dkpe-shell{
    width:100vw;
    max-width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    overflow:hidden;
  }
  .dkpe-swiper{
    width:100vw;
    max-width:100vw;
  }
  .dkpe-grid{
    width:min(100% - 32px,760px);
    padding-top:96px;
    padding-bottom:150px;
    align-items:center;
  }
  .dkpe-actions{
    margin-top:24px;
    margin-bottom:0;
    gap:12px;
  }
  .dkpe-filters{
    bottom:58px;
    max-width:calc(100% - 24px);
    justify-content:flex-start;
  }
  .dkpe-pagination{
    bottom:20px!important;
  }
  .dkpe-modal{
    position:fixed;
    inset:0;
    z-index:999999;
    padding:18px 12px;
  }
  .dkpe-modal-card{
    width:min(720px,calc(100vw - 24px));
    max-width:calc(100vw - 24px);
    max-height:calc(100dvh - 36px);
  }
  .dkpe-modal-close{
    left:auto!important;
    right:max(14px,calc(env(safe-area-inset-right,0px) + 14px))!important;
    top:max(14px,calc(env(safe-area-inset-top,0px) + 14px))!important;
    z-index:10;
  }
}

@media (max-width:767px){
  .dkpe-shell{
    min-height:100svh;
  }
  .dkpe-swiper{
    height:100svh;
    min-height:640px;
  }
  .dkpe-grid{
    width:calc(100% - 28px);
    padding-top:88px;
    padding-bottom:164px;
    align-items:center;
  }
  .dkpe-title{
    font-size:clamp(38px,12vw,62px);
  }
  .dkpe-desc{
    margin-top:16px;
    line-height:1.55;
  }
  .dkpe-actions{
    gap:11px;
    margin-top:24px;
  }
  .dkpe-actions a,
  .dkpe-actions button{
    padding:12px 14px;
  }
  .dkpe-filters{
    bottom:58px;
    max-width:calc(100% - 18px);
    padding:6px;
  }
  .dkpe-filters button{
    padding:8px 11px;
  }
  .dkpe-pagination{
    bottom:20px!important;
  }
  .dkpe-modal{
    padding:12px 8px;
  }
  .dkpe-modal-card{
    width:calc(100vw - 16px);
    max-width:calc(100vw - 16px);
    max-height:calc(100dvh - 24px);
  }
  .dkpe-modal-content{
    padding:52px 18px 22px;
  }
  .dkpe-modal-close{
    left:auto!important;
    right:max(12px,calc(env(safe-area-inset-right,0px) + 12px))!important;
    top:max(12px,calc(env(safe-area-inset-top,0px) + 12px))!important;
  }
}

@supports (width:100dvw){
  @media (max-width:1024px){
    .dkpe-shell,
    .dkpe-swiper{
      width:100dvw;
      max-width:100dvw;
    }
  }
}


/* v0.3.9 — hard reset for Case Study close button position/size */
.dkpe-shell .dkpe-modal .dkpe-modal-card{
  position:relative!important;
}
.dkpe-shell .dkpe-modal .dkpe-modal-card > button.dkpe-modal-close,
.dkpe-shell .dkpe-modal button.dkpe-modal-close{
  position:absolute!important;
  top:18px!important;
  right:18px!important;
  left:auto!important;
  bottom:auto!important;
  float:none!important;
  clear:none!important;
  z-index:50!important;
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  max-width:44px!important;
  max-height:44px!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  outline:none!important;
  background:transparent!important;
  background-color:transparent!important;
  color:var(--dkpe-accent)!important;
  box-shadow:none!important;
  border-radius:999px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:38px!important;
  line-height:1!important;
  font-weight:800!important;
  font-family:Arial,Helvetica,sans-serif!important;
  text-align:center!important;
  text-indent:0!important;
  opacity:1!important;
  transform:none!important;
  text-shadow:0 0 10px color-mix(in srgb,var(--dkpe-accent) 86%,transparent),0 0 24px color-mix(in srgb,var(--dkpe-accent) 58%,transparent),0 0 46px color-mix(in srgb,var(--dkpe-accent) 34%,transparent)!important;
  cursor:pointer!important;
  appearance:none!important;
  -webkit-appearance:none!important;
}
.dkpe-shell .dkpe-modal .dkpe-modal-card > button.dkpe-modal-close:hover,
.dkpe-shell .dkpe-modal button.dkpe-modal-close:hover,
.dkpe-shell .dkpe-modal .dkpe-modal-card > button.dkpe-modal-close:focus-visible,
.dkpe-shell .dkpe-modal button.dkpe-modal-close:focus-visible{
  color:#ff4b57!important;
  transform:scale(1.08)!important;
  text-shadow:0 0 12px color-mix(in srgb,var(--dkpe-accent) 90%,transparent),0 0 30px color-mix(in srgb,var(--dkpe-accent) 64%,transparent),0 0 58px color-mix(in srgb,var(--dkpe-accent) 42%,transparent)!important;
}
@media (max-width:1024px){
  .dkpe-shell .dkpe-modal .dkpe-modal-card > button.dkpe-modal-close,
  .dkpe-shell .dkpe-modal button.dkpe-modal-close{
    top:max(16px,calc(env(safe-area-inset-top,0px) + 16px))!important;
    right:max(18px,calc(env(safe-area-inset-right,0px) + 18px))!important;
    left:auto!important;
    width:46px!important;
    height:46px!important;
    min-width:46px!important;
    min-height:46px!important;
    max-width:46px!important;
    max-height:46px!important;
    font-size:39px!important;
    z-index:1000001!important;
  }
}
@media (max-width:767px){
  .dkpe-shell .dkpe-modal .dkpe-modal-card > button.dkpe-modal-close,
  .dkpe-shell .dkpe-modal button.dkpe-modal-close{
    top:max(14px,calc(env(safe-area-inset-top,0px) + 14px))!important;
    right:max(18px,calc(env(safe-area-inset-right,0px) + 18px))!important;
    left:auto!important;
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    min-height:44px!important;
    max-width:44px!important;
    max-height:44px!important;
    font-size:37px!important;
  }
}


/* DIGIKROM Portfolio Index */
.dkpe-index-empty{padding:20px;border:1px dashed rgba(255,255,255,.18);border-radius:18px;color:#fff;background:#0b0d12}
.dkpe-index-shell{--dkpei-accent:#ff2b36;--dkpei-text:#fff;--dkpei-muted:rgba(255,255,255,.72);--dkpei-shell-bg:#06070a;--dkpei-item-bg:rgba(20,22,29,.78);--dkpei-item-hover:rgba(40,8,12,.88);--dkpei-radius:22px;--dkpei-columns:1;position:relative;overflow:hidden;padding:28px;border-radius:30px;background:var(--dkpei-shell-bg);color:var(--dkpei-text);isolation:isolate;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 60px rgba(0,0,0,.32)}
.dkpe-index-bg,.dkpe-index-overlay{position:absolute;inset:0;pointer-events:none}.dkpe-index-bg{background-image:var(--dkpei-bg-image);background-size:cover;background-position:center;opacity:.24;transform:scale(1.03)}.dkpe-index-overlay{background:radial-gradient(circle at 15% 15%, rgba(255,43,54,.16), transparent 36%),linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.46))}
.dkpe-index-head,.dkpe-index-list{position:relative;z-index:1}.dkpe-index-head{margin:0 0 22px}.dkpe-index-head h2{margin:0 0 10px;font-size:clamp(28px,4vw,54px);line-height:1.02;color:var(--dkpei-text)}.dkpe-index-head p{margin:0;max-width:900px;color:var(--dkpei-muted);font-size:15px;line-height:1.7}
.dkpe-index-list{display:grid;grid-template-columns:repeat(var(--dkpei-columns),minmax(0,1fr));gap:14px}.dkpe-index-item{display:block;padding:18px 18px 16px;border-radius:var(--dkpei-radius);text-decoration:none;color:var(--dkpei-text);background:var(--dkpei-item-bg);border:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 1px rgba(255,255,255,.03) inset;transition:transform .22s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease}.dkpe-index-item:hover{transform:translateY(-2px);background:var(--dkpei-item-hover);border-color:rgba(255,43,54,.38);box-shadow:0 0 0 1px rgba(255,43,54,.14) inset,0 0 28px rgba(255,43,54,.18)}
.dkpe-index-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dkpei-muted)}.dkpe-index-no{display:inline-flex;align-items:center;justify-content:center;min-width:38px;padding:4px 9px;border-radius:999px;background:rgba(255,255,255,.06);color:var(--dkpei-accent);font-weight:700}.dkpe-index-meta strong{padding:4px 8px;border-radius:999px;background:rgba(255,43,54,.14);color:var(--dkpei-accent);font-weight:700}.dkpe-index-meta em{font-style:normal}
.dkpe-index-title{display:block;font-size:26px;line-height:1.08;font-weight:800;letter-spacing:-.02em;margin-bottom:8px;text-transform:uppercase}.dkpe-index-excerpt{display:block;color:var(--dkpei-muted);font-size:14px;line-height:1.65}.dkpe-index-slug{display:block;margin-top:12px;color:var(--dkpei-accent);font-size:12px;letter-spacing:.08em}
.dkpe-index-style-glass .dkpe-index-item{backdrop-filter:blur(12px);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03))}.dkpe-index-style-terminal .dkpe-index-shell{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.dkpe-index-style-terminal .dkpe-index-title{text-transform:none;font-size:22px}.dkpe-index-style-terminal .dkpe-index-item::before{content:'>';color:var(--dkpei-accent);font-weight:900;margin-right:8px;display:inline-block}
@media (max-width:1024px){.dkpe-index-shell{padding:22px}.dkpe-index-list{grid-template-columns:1fr!important}}@media (max-width:767px){.dkpe-index-shell{padding:18px;border-radius:22px}.dkpe-index-head h2{font-size:30px}.dkpe-index-title{font-size:22px}}
