/* grid */
.gps-icon-grid{--gps-gap:24px;--gps-cols:auto;display:grid;grid-template-columns:repeat(var(--gps-cols,auto-fit),minmax(240px,1fr));gap:var(--gps-gap)}

/* card base */
.gps-flip-card{width:100%;min-height:160px;perspective:1000px;cursor:pointer}
.gps-flip-inner{position:relative;width:100%;min-height:160px;border-radius:16px;background:var(--gps-front-bg,#fff);box-shadow:0 10px 24px rgba(0,0,0,.08);transition:transform .6s cubic-bezier(.2,.6,.2,1),box-shadow .2s ease;transform-style:preserve-3d}
.gps-flip-card:hover .gps-flip-inner{box-shadow:0 16px 36px rgba(0,0,0,.12)}
.gps-flip-card.gps-is-flipped .gps-flip-inner{transform:rotateY(180deg)}

.gps-face{position:absolute;inset:0;border-radius:16px;padding:22px 20px;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}

/* front */
.gps-front{background:var(--gps-front-bg,#fff)}
.gps-badge-wrap{position:relative;margin-bottom:12px}
.gps-badge-wrap::before{content:"";position:absolute;inset:-10px;border-radius:999px;background:radial-gradient(closest-side,rgba(25,147,204,.25),transparent 70%);filter:blur(6px)}
.gps-badge-emoji,.gps-badge-img{display:grid;place-items:center;width:46px;height:46px;border-radius:999px;background:var(--gps-icon-bg,#eaf7ff);font-size:22px}
.gps-badge-img{object-fit:contain;padding:8px}
.gps-title{margin:0;color:var(--gps-front-title, var(--e-global-color-text, #232339));text-align:center;font-weight:var(--gps-title-weight,700);line-height:1.25;font-family: var(--gps-title-font, var(--e-global-typography-text-font-family, inherit));font-size: var(--gps-title-size, inherit);}

/* back */
.gps-back{transform:rotateY(180deg);background:var(--gps-back-bg,#232339);color:var(--gps-back-text, #fff);font-family: var(--gps-text-font, var(--e-global-typography-text-font-family, inherit));font-size: var(--gps-text-size, inherit);font-weight: var(--gps-text-weight, 400);}
.gps-back-title{margin:0 0 8px;font-weight:var(--gps-back-title-weight,700);text-align:center;color:var(--gps-back-title, var(--e-global-color-primary, #ffffff));font-family: var(--gps-back-title-font, var(--e-global-typography-text-font-family, inherit));font-size: var(--gps-back-title-size, inherit);}
.gps-info{margin:0 0 16px;padding-left:18px;font-size:14px;line-height:1.35}
.gps-btn{display:inline-block;padding:10px 16px;border-radius:999px;background:var(--gps-btn-bg, var(--e-global-color-accent, #1993cc));color:var(--gps-btn-color, #fff);text-decoration:none;font-weight:var(--gps-btn-weight,600);transition:transform .15s ease,opacity .15s ease;font-family: var(--gps-btn-font, var(--e-global-typography-text-font-family, inherit));font-size: var(--gps-btn-size, inherit);}
.gps-btn:hover{transform:translateY(-1px);opacity:.95}

/* focus a11y */
.gps-flip-card:focus{outline:none}
.gps-flip-card:focus .gps-flip-inner{box-shadow:0 0 0 3px rgba(25,147,204,.3),0 10px 24px rgba(0,0,0,.1)}

/* small devices */
@media (max-width:480px){.gps-icon-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}

/* v1.4: stronger hover + class-based flip with !important to beat theme/Elementor overrides */
.gps-flip-card.gps-hover .gps-flip-inner,
.gps-flip-card:hover .gps-flip-inner,
.gps-flip-card.gps-is-flipped .gps-flip-inner{
  transform: rotateY(180deg) !important;
}

.gps-face{-webkit-backface-visibility:hidden;backface-visibility:hidden}
.gps-flip-inner{will-change: transform; transform-origin: center center;}

/* ensure inner can receive events if theme sets pointer-events:none somewhere */
.gps-flip-inner, .gps-face{pointer-events:auto}

/* prevent ancestor transforms from flattening perspective in some themes */
.gps-flip-card{transform: translateZ(0)}
