/* =====================================================================
   VESPERS — Testimonies (/testimonies)
   Inherits tokens from main.css. Mobile-first.
   ===================================================================== */

/* ---------------------------------------------------------------------
   Hero
   --------------------------------------------------------------------- */
.tg-hero{position:relative; overflow:hidden; isolation:isolate; color:var(--on-dark-1);
  background:var(--ink-900); text-align:center;
  padding-top:clamp(118px,15vw,158px); padding-bottom:clamp(48px,7vw,84px);}
.tg-hero-bg{position:absolute; inset:0; z-index:0;}
.tg-hero-bg img{width:100%; height:100%; object-fit:cover; opacity:.5;}
.tg-hero-scrim{position:absolute; inset:0; z-index:1; background:
  linear-gradient(180deg, rgba(20,22,46,.78) 0%, rgba(20,22,46,.62) 46%, rgba(20,22,46,.9) 100%),
  radial-gradient(60% 60% at 50% 14%, rgba(226,203,148,.20), transparent 62%);}
.tg-hero .hero-arch{bottom:-28%; opacity:.5;}
.tg-hero-inner{position:relative; z-index:2; max-width:60ch; margin-inline:auto;}
.tg-hero h1{color:var(--on-dark-1); font-size:clamp(2.6rem,6vw,4.6rem); line-height:1.02; margin:14px 0 0; text-shadow:0 2px 50px rgba(20,22,46,.6);}
.tg-hero h1 em{font-style:italic; color:var(--gilt-300);}
.tg-hero .lead{color:var(--on-dark-2); margin:18px auto 0; max-width:56ch;}
.tg-stats{display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin:24px 0 28px; font:500 .92rem/1.4 var(--font-body); color:var(--on-dark-2);}
.tg-stats b{font:600 1.15rem/1 var(--font-display); color:var(--gilt-300); margin-right:5px;}
.tg-stats .dot{width:4px; height:4px; border-radius:50%; background:var(--border-on-dark,rgba(251,248,240,.3));}

/* ---------------------------------------------------------------------
   Wall / grid
   --------------------------------------------------------------------- */
.tg-wall{background:var(--parchment-50);}
.tg-wall-head{max-width:56ch;}
.tg-grid{display:grid; grid-template-columns:1fr; gap:clamp(16px,2vw,24px); margin-top:clamp(26px,3.4vw,44px);}
@media (min-width:560px){ .tg-grid{grid-template-columns:repeat(2,1fr);} }
@media (min-width:840px){ .tg-grid{grid-template-columns:repeat(3,1fr);} }
@media (min-width:1120px){ .tg-grid{grid-template-columns:repeat(4,1fr);} }

.tg-card{position:relative; display:flex; flex-direction:column; background:var(--surface);
  border:1px solid var(--border-soft); border-radius:18px; padding:26px 22px 22px; box-shadow:var(--shadow-sm);
  cursor:pointer; transition:transform .4s var(--ease), box-shadow .4s var(--ease);}
/* full-card click target → opens the slideshow modal (keeps markup accessible) */
.tg-card-trigger{position:absolute; inset:0; z-index:4; border-radius:inherit; background:none; cursor:pointer;}
.tg-card-trigger:focus-visible{outline:2px solid var(--gilt-500); outline-offset:2px;}
.tg-card > :not(.tg-card-trigger){position:relative; z-index:1;}
.tg-flag{font-size:1em; line-height:1; margin-right:1px;}
.tg-card::before{content:""; position:absolute; left:0; top:0; width:100%; height:3px; border-radius:18px 18px 0 0;
  background:linear-gradient(90deg, var(--gilt-500), transparent 70%);}
.tg-tag{align-self:flex-start; font:700 .6rem/1 var(--font-body); letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent-strong); background:var(--gilt-100); padding:6px 12px; border-radius:999px;}
.tg-qmark{color:var(--gilt-500); opacity:.85; margin:14px 0 2px;}
.tg-quote{margin:0; font:italic 500 1.06rem/1.55 var(--font-display); color:var(--fg1); letter-spacing:-.01em; flex:1 1 auto;}
.tg-who{display:flex; align-items:center; gap:12px; margin-top:18px; padding-top:16px; border-top:1px solid var(--border);}
.tg-portrait{flex:0 0 auto; width:50px; height:56px; border-radius:var(--arch); box-shadow:var(--shadow-sm);}
.tg-who-txt{min-width:0;}
.tg-name{display:block; font:700 .92rem/1.2 var(--font-body); color:var(--fg1);}
.tg-loc{display:block; font:500 .78rem/1.3 var(--font-body); color:var(--fg2); margin-top:3px;}
@media (hover:hover){
  .tg-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-lg);}
}

/* appended (load-more) fade-in */
.tg-card.is-new{animation:tgIn .55s var(--ease) both;}
@keyframes tgIn{from{opacity:0; transform:translateY(16px) scale(.98);} to{opacity:1; transform:none;}}
@media (prefers-reduced-motion:reduce){ .tg-card.is-new{animation:none;} .tg-card{transition:none;} }

/* load more */
.tg-more{display:flex; flex-direction:column; align-items:center; gap:12px; margin-top:clamp(30px,4vw,48px);}
.tg-more[hidden]{display:none;}
.tg-more-status{font:600 .85rem/1.4 var(--font-body); color:var(--fg3); min-height:1em;}

/* ---------------------------------------------------------------------
   Share CTA
   --------------------------------------------------------------------- */
.tg-share{position:relative; overflow:hidden; isolation:isolate; color:var(--on-dark-1); text-align:center;
  background:linear-gradient(165deg, var(--indigo-600), var(--ink-900) 74%);}
.tg-share-glow{position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(54% 54% at 50% 0%, rgba(226,203,148,.22), transparent 64%);}
.tg-share-inner{position:relative; z-index:2; max-width:58ch; margin-inline:auto; display:flex; flex-direction:column; align-items:center;}
.tg-share-mark{color:var(--gilt-300); margin-bottom:8px;}
.tg-share .kicker{color:var(--on-dark-1);}
.tg-share .kicker em{font-style:italic; color:var(--gilt-300);}
.tg-share p{font:400 1.06rem/1.7 var(--font-body); color:var(--on-dark-2); margin:14px auto 0; max-width:48ch;}
.tg-share-cta{display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:26px;}

/* =====================================================================
   Share Your Testimony (/share-testimony)  — pairs with prayer.css helpers
   ===================================================================== */
.st-hero{position:relative; overflow:hidden; isolation:isolate; color:var(--on-dark-1); text-align:center;
  background:radial-gradient(120% 90% at 50% -10%, #2b2f5c 0%, var(--ink-900) 48%, var(--ink-950) 100%);
  padding-top:clamp(116px,15vw,150px); padding-bottom:clamp(40px,6vw,68px);}
.st-hero-bg{position:absolute; inset:0; z-index:0; pointer-events:none;}
.st-hero-bg img{width:100%; height:100%; object-fit:cover; object-position:center 32%; opacity:.32;}
.st-hero-bg::after{content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,22,46,.45) 0%, rgba(20,22,46,.66) 55%, var(--ink-950) 100%);}
.st-hero-glow{position:absolute; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(46% 40% at 50% 26%, rgba(226,203,148,.26), transparent 64%);}
.st-hero .hero-arch{bottom:-30%; opacity:.5;}
.st-hero-inner{position:relative; z-index:2; max-width:58ch; margin-inline:auto;}
.st-hero h1{color:var(--on-dark-1); font-size:clamp(2.3rem,5.2vw,3.7rem); line-height:1.05; margin:12px 0 0;}
.st-hero h1 em{font-style:italic; color:var(--gilt-300);}
.st-hero .lead{color:var(--on-dark-2); margin:16px auto 0; max-width:52ch;}

.st-body{background:var(--parchment-50);}
.st-shell{display:grid; grid-template-columns:1fr; gap:clamp(24px,3.4vw,40px); align-items:start;}
@media (min-width:920px){ .st-shell{grid-template-columns:1.7fr .9fr;} }

.st-card{position:relative; background:var(--surface); border:1px solid var(--hairline-gold); border-radius:20px;
  padding:clamp(26px,3.6vw,44px); box-shadow:var(--shadow-lg);}
.st-card::before{content:""; position:absolute; inset:0; border-radius:inherit; box-shadow:inset 0 0 0 1px rgba(255,255,255,.6); pointer-events:none;}
.st-card-head{text-align:center; margin-bottom:18px;}
.st-seal{display:inline-flex; align-items:center; justify-content:center; width:58px; height:64px; border-radius:var(--arch);
  color:var(--accent-strong); background:var(--gilt-100); border:1px solid var(--hairline-gold); margin-bottom:12px;}
.st-card-head h2{font:600 clamp(1.6rem,2.6vw,2.1rem)/1.1 var(--font-display); color:var(--fg1);}
.st-card-head p{font:400 1rem/1.6 var(--font-body); color:var(--fg2); margin-top:8px;}
.st-grid2{display:grid; grid-template-columns:1fr; gap:0 18px;}
@media (min-width:560px){ .st-grid2{grid-template-columns:minmax(0,1fr) minmax(0,1fr);} }

/* location: a city text field + a country dropdown side by side in one group */
.st-loc-group{display:flex; gap:10px; align-items:stretch;}
.st-loc-city{flex:1 1 auto; min-width:0;}
.st-loc-sel{position:relative; flex:0 0 auto; width:46%; max-width:230px; display:flex;}
.st-loc-country{width:100%; appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:36px; text-overflow:ellipsis;}
.st-loc-caret{position:absolute; right:12px; top:50%; transform:translateY(-50%); color:var(--gilt-700); pointer-events:none;}
@media (max-width:430px){ .st-loc-group{flex-direction:column;} .st-loc-sel{width:100%; max-width:none;} }

/* location: city + country sharing ONE bordered field (like card-number + logo) */
.st-locfield{display:flex; align-items:stretch; background:var(--surface);
  border:1px solid var(--border-strong); border-radius:12px; overflow:hidden;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);}
.st-locfield:focus-within{border-color:var(--gilt-500); box-shadow:0 0 0 3px rgba(198,164,92,.16);}
.st-locfield-city{flex:1.2 1 0; min-width:0; border:0; background:transparent; outline:none;
  font:500 1rem/1.4 var(--font-body); color:var(--fg1); padding:12px 14px;}
.st-locfield-city::placeholder{color:var(--fg3);}
.st-locfield-div{flex:0 0 auto; width:1px; background:var(--border); margin:9px 0;}
.st-locfield-sel{position:relative; flex:1 1 0; min-width:0; display:flex; align-items:center;}
.st-locfield-sel select{flex:1 1 0; min-width:0; width:100%; appearance:none; -webkit-appearance:none; border:0; background:transparent; outline:none;
  font:500 1rem/1.4 var(--font-body); color:var(--fg1); padding:12px 32px 12px 14px; cursor:pointer; text-overflow:ellipsis;}
.st-locfield-sel select:invalid{color:var(--fg3);}
.st-locfield-caret{position:absolute; right:12px; top:50%; transform:translateY(-50%); color:var(--gilt-700); pointer-events:none;}
.st-actions{display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:24px;}
.st-privacy{display:flex; align-items:flex-start; gap:7px; margin-top:16px; font:500 .82rem/1.5 var(--font-body); color:var(--fg3);}
.st-privacy vm-icon{color:var(--accent-strong); flex:0 0 auto; margin-top:1px;}

.st-success{text-align:center; background:var(--surface); border:1px solid var(--hairline-gold); border-radius:20px;
  padding:clamp(36px,5vw,60px) clamp(24px,4vw,48px); box-shadow:var(--shadow-lg); grid-column:1 / -1; max-width:620px; margin-inline:auto;}
.st-success-mark{display:inline-flex; align-items:center; justify-content:center; width:78px; height:78px; border-radius:50%;
  color:var(--accent-strong); background:var(--gilt-100); border:1px solid var(--hairline-gold); margin-bottom:18px;}
.st-success h2{font:600 clamp(1.8rem,3vw,2.4rem)/1.1 var(--font-display); color:var(--fg1);}
.st-success p{font:400 1.05rem/1.65 var(--font-body); color:var(--fg2); margin:12px auto 0; max-width:48ch;}
.st-success-cta{display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:22px;}
.st-aside{display:flex; flex-direction:column; gap:18px;}
@media (min-width:920px){ .st-aside{position:sticky; top:96px;} }

/* Latest testimonies on the share page — 2×4 grid (desktop) → swipe carousel (mobile) */
.st-testi{background:var(--surface-warm); border-top:1px solid var(--border-soft);}
.st-testi-head{text-align:center; max-width:62ch; margin:0 auto;}
.st-testi-head .mvt{justify-content:center;}
.st-testi-grid{list-style:none; margin:clamp(26px,4vw,42px) 0 0; padding:0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;}
.st-tcard{position:relative; display:flex; flex-direction:column; background:var(--surface);
  border:1px solid var(--border); border-radius:18px; padding:24px 22px 22px; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);}
.st-tcard:hover{transform:translateY(-3px); box-shadow:var(--shadow-md);}
.st-tcard .fruit{align-self:flex-start; font:700 .62rem/1 var(--font-body); letter-spacing:.14em; text-transform:uppercase;
  color:var(--gilt-800); background:var(--gilt-100); border:1px solid var(--hairline-gold); padding:5px 10px; border-radius:999px;}
.st-tcard .qmark{color:var(--gilt-300); margin:14px 0 2px;}
.st-tcard blockquote{flex:1 1 auto; margin:0 0 18px; font:500 .96rem/1.55 var(--font-body); color:var(--fg1);}
.st-tcard .who{display:flex; align-items:center; gap:12px; padding-top:16px; border-top:1px solid var(--border-soft);}
.st-tcard .who .ph{flex:0 0 auto; width:46px; height:54px; border-radius:var(--arch); overflow:hidden; box-shadow:var(--shadow-sm); background:var(--surface-sunken);}
.st-tcard .who .ph img{width:100%; height:100%; object-fit:cover;}
.st-tcard .who-txt{min-width:0; display:flex; flex-direction:column;}
.st-tcard .nm{font:700 .9rem/1.2 var(--font-body); color:var(--fg1);}
.st-tcard .ro{font:500 .78rem/1.3 var(--font-body); color:var(--fg3); margin-top:2px;}
.st-tcard .ro-flag{margin-right:3px;}
.st-testi-act{text-align:center; margin-top:clamp(24px,4vw,36px);}
@media (max-width:980px){ .st-testi-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){
  .st-testi-grid{display:flex; grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory;
    gap:14px; padding-bottom:14px; -webkit-overflow-scrolling:touch; scrollbar-width:none;}
  .st-testi-grid::-webkit-scrollbar{display:none;}
  .st-tcard{flex:0 0 84%; scroll-snap-align:center;}
}
@media (prefers-reduced-motion:reduce){ .st-tcard{transition:none;} }

/* upload UI (public share-testimony) */
.st-upload{margin-top:16px;}
.st-drop{position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; text-align:center;
  padding:22px 16px; border:1.5px dashed var(--border-strong); border-radius:14px; background:var(--parchment-50);
  color:var(--fg2); cursor:pointer; transition:border-color .25s, background-color .25s, color .25s;}
.st-drop vm-icon{color:var(--gilt-700);}
.st-drop-t{font:700 .9rem/1 var(--font-body); color:var(--fg1);}
.st-drop small{font:500 .76rem/1.3 var(--font-body); color:var(--fg3);}
.st-drop input[type="file"]{position:absolute; width:1px; height:1px; opacity:0; overflow:hidden; clip:rect(0 0 0 0);}
.st-drop:hover, .st-drop:focus-within{border-color:var(--gilt-500); background:var(--surface); color:var(--accent-strong);}
/* unified media drop zone — photo + video in one field, drag & drop aware */
.st-media{margin-top:16px;}
.st-drop-icons{display:flex; gap:10px; margin-bottom:6px;}
.st-drop-ic{display:grid; place-items:center; width:44px; height:44px; border-radius:50%;
  background:var(--surface-warm); border:1px solid var(--hairline-gold); color:var(--gilt-700);
  transition:transform .25s var(--ease), background-color .25s, color .25s;}
.st-drop:hover .st-drop-ic, .st-drop.is-drag .st-drop-ic{background:var(--gilt-100); color:var(--gilt-800);}
.st-drop.is-drag{border-color:var(--gilt-500); border-style:solid; background:var(--gilt-100); color:var(--accent-strong);
  box-shadow:0 0 0 3px rgba(198,164,92,.18);}
.st-drop.is-drag .st-drop-ic{transform:translateY(-2px) scale(1.06);}
@media (prefers-reduced-motion:reduce){ .st-drop-ic{transition:none;} }
.st-previews{display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; align-items:center;}
.st-thumb{position:relative; width:74px; height:84px; border-radius:12px; overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--border);}
.st-thumb img{width:100%; height:100%; object-fit:cover;}
.st-thumb-rm{position:absolute; top:4px; right:4px; width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font:700 16px/1 var(--font-body); color:#fff; background:rgba(20,22,46,.72); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); transition:background-color .2s;}
.st-thumb-rm:hover{background:#B5523C;}
.st-thumb-count{font:700 .74rem/1 var(--font-body); letter-spacing:.04em; color:var(--fg3); margin-left:2px;}
.st-up-err{font:600 .8rem/1.4 var(--font-body); color:#B5523C; margin-top:8px;}
.st-up-err[hidden]{display:none;}
.st-video-preview{margin-top:12px;}
.st-video-preview[hidden]{display:none;}
.st-vrow{display:flex; align-items:center; gap:12px; padding:10px 14px; border:1px solid var(--border); border-radius:12px; background:var(--surface);}
.st-vname{flex:1; min-width:0; font:600 .85rem/1.3 var(--font-body); color:var(--fg1); overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.st-vrm{font:700 .78rem/1 var(--font-body); color:#B5523C;}

/* =====================================================================
   Testimony slideshow modal — an immersive, reverent storytelling view
   ===================================================================== */
.ts-modal{position:fixed; inset:0; z-index:220; display:flex; align-items:center; justify-content:center;
  padding:clamp(12px,3vw,40px); opacity:0; visibility:hidden; transition:opacity .35s var(--ease-veil), visibility .35s;}
.ts-modal.open{opacity:1; visibility:visible;}
.ts-modal-backdrop{position:absolute; inset:0; background:rgba(11,12,26,.9); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);}
.ts-modal-card{position:relative; z-index:2; width:min(960px,100%); max-height:calc(100dvh - 24px); overflow:hidden;
  display:grid; grid-template-columns:1fr; background:var(--parchment-50); border:1px solid var(--hairline-gold); border-radius:22px;
  box-shadow:var(--shadow-xl); transform:translateY(16px) scale(.98); transition:transform .42s var(--ease);}
.ts-modal.open .ts-modal-card{transform:none;}
.ts-handle{display:block; width:42px; height:5px; border-radius:999px; background:rgba(251,248,240,.5); margin:10px auto 0; position:relative; z-index:6;}
@media (min-width:820px){ .ts-modal-card{grid-template-columns:.92fr 1.08fr; align-items:stretch;} .ts-handle{display:none;} }

.ts-media{position:relative; margin:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px;
  padding:clamp(24px,3.2vw,38px); background:linear-gradient(165deg, var(--indigo-600), var(--ink-900) 82%); overflow:hidden;}
.ts-media-glow{position:absolute; inset:0; background:radial-gradient(60% 50% at 50% 14%, rgba(226,203,148,.26), transparent 64%); pointer-events:none;}
.ts-photo{position:relative; z-index:1; width:min(72%,250px); aspect-ratio:4/5; object-fit:cover; border-radius:var(--arch);
  border:1px solid var(--hairline-gold); box-shadow:var(--shadow-lg); background:var(--gilt-100);}
.ts-media.is-empty{min-height:120px;}
.ts-media.is-empty .ts-photo{display:none;}
.ts-thumbs{position:relative; z-index:1; display:flex; gap:8px; flex-wrap:wrap; justify-content:center; max-width:100%;}
.ts-thumb{width:46px; height:52px; border-radius:10px; overflow:hidden; border:2px solid transparent; opacity:.65; padding:0;
  transition:opacity .25s, border-color .25s, transform .2s var(--ease);}
.ts-thumb img{width:100%; height:100%; object-fit:cover;}
.ts-thumb.is-active{opacity:1; border-color:var(--gilt-300);}
.ts-thumb:hover{opacity:1; transform:translateY(-2px);}

.ts-body{position:relative; padding:clamp(24px,3.4vw,42px); display:flex; flex-direction:column; overflow:auto;}
.ts-tag{align-self:flex-start; font:700 .62rem/1 var(--font-body); letter-spacing:.16em; text-transform:uppercase; color:var(--accent-strong);
  background:var(--gilt-100); padding:7px 13px; border-radius:999px;}
.ts-qmark{color:var(--gilt-500); opacity:.8; margin:16px 0 4px;}
.ts-quote{margin:0; font:italic 500 clamp(1.25rem,2.1vw,1.6rem)/1.5 var(--font-display); color:var(--fg1); letter-spacing:-.01em;}
.ts-who{margin-top:20px;}
.ts-name{display:block; font:700 1.05rem/1.2 var(--font-body); color:var(--fg1);}
.ts-loc{display:block; font:500 .85rem/1.3 var(--font-body); color:var(--fg2); margin-top:4px;}
.ts-loc .ts-flag{font-size:1.05em; margin-right:2px;}
.ts-verse{margin-top:18px; font:italic 500 .92rem/1.55 var(--font-display); color:var(--fg2);}
.ts-verse-rule{display:block; width:34px; height:1px; background:var(--hairline-gold); margin-bottom:12px;}
.ts-verse em{font-style:normal; font-family:var(--font-body); font-weight:700; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-strong); margin-left:4px;}
.ts-actions{display:flex; align-items:center; gap:14px; margin-top:auto; padding-top:22px;}
.ts-count{font:600 .78rem/1 var(--font-body); letter-spacing:.06em; color:var(--fg3);}

.ts-modal-close{position:absolute; z-index:6; top:12px; right:12px; width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--on-dark-1); background:rgba(20,22,46,.45);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); transition:background-color .25s;}
.ts-modal-close:hover{background:rgba(20,22,46,.75);}
.ts-nav{position:absolute; z-index:6; top:50%; transform:translateY(-50%); width:46px; height:46px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--ink-900); background:var(--surface);
  border:1px solid var(--hairline-gold); box-shadow:var(--shadow-md); transition:background-color .25s;}
.ts-prev{left:8px;} .ts-next{right:8px;}
.ts-nav:hover{background:var(--gilt-100);}
@media (max-width:560px){ .ts-nav{width:40px; height:40px;} }

.ts-modal-card.ts-in .ts-body{animation:tsBody .4s var(--ease) both;}
@keyframes tsBody{from{opacity:.35; transform:translateY(8px);} to{opacity:1; transform:none;}}
@media (prefers-reduced-motion:reduce){
  .ts-modal, .ts-modal-card{transition:none !important;}
  .ts-modal-card.ts-in .ts-body{animation:none;}
}
