/*
 * TAB Media Homepage styles
 * Loaded only on homepage via functions.php (is_front_page || is_home)
 */

/* ═══════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════ */
@keyframes tabmedia-float-up{
  0%  {transform:translateY(100vh) rotate(0deg);  opacity:0;}
  10% {opacity:.4;}
  90% {opacity:.4;}
  100%{transform:translateY(-100px) rotate(720deg);opacity:0;}
}
@keyframes tabmedia-pulse-dot{
  0%  {box-shadow:0 0 0 0 rgba(37,99,235,.5);}
  70% {box-shadow:0 0 0 7px rgba(37,99,235,0);}
  100%{box-shadow:0 0 0 0 rgba(37,99,235,0);}
}
@keyframes tabmedia-aura-pulse{
  0%,100%{transform:scale(1);   opacity:.78;}
  50%    {transform:scale(1.12);opacity:1;}
}
@keyframes tabmedia-float-y{
  0%,100%{transform:translateY(0);}
  50%    {transform:translateY(-12px);}
}
@keyframes tabmedia-core-pulse{
  0%,100%{transform:scale(1);}
  50%    {transform:scale(1.06);}
}
@keyframes tabmedia-expand-ring{
  0%  {transform:scale(.7); opacity:.9;}
  100%{transform:scale(1.3);opacity:0;}
}
@keyframes tabmedia-pill-float{
  0%,100%{transform:translateY(0);}
  50%    {transform:translateY(-7px);}
}
@keyframes tabmedia-bar-wave{
  0%,100%{transform:scaleY(.6); opacity:.65;}
  50%    {transform:scaleY(1.12);opacity:1;}
}
@keyframes tabmedia-hud-float{
  0%,100%{transform:translateY(0);}
  50%    {transform:translateY(-9px);}
}
@keyframes tabmedia-meter-fill{
  0%,100%{width:56%;}
  50%    {width:86%;}
}
@keyframes tabmedia-led-green{
  0%  {box-shadow:0 0 0 0 rgba(16,185,129,.4);}
  75% {box-shadow:0 0 0 8px rgba(16,185,129,0);}
  100%{box-shadow:0 0 0 0 rgba(16,185,129,0);}
}
@keyframes tabmedia-led-blue{
  0%  {box-shadow:0 0 0 0 rgba(37,99,235,.4);}
  75% {box-shadow:0 0 0 8px rgba(37,99,235,0);}
  100%{box-shadow:0 0 0 0 rgba(37,99,235,0);}
}
@keyframes tabmedia-ring-cw {from{transform:rotate(0deg);}  to{transform:rotate(360deg);}}
@keyframes tabmedia-ring-ccw{from{transform:rotate(0deg);}  to{transform:rotate(-360deg);}}
@keyframes tabmedia-orb-1{
  from{transform:rotate(0deg)   translateX(140px) rotate(0deg);}
  to  {transform:rotate(360deg) translateX(140px) rotate(-360deg);}
}
@keyframes tabmedia-orb-2{
  from{transform:rotate(72deg)  translateX(140px) rotate(-72deg);}
  to  {transform:rotate(432deg) translateX(140px) rotate(-432deg);}
}
@keyframes tabmedia-orb-3{
  from{transform:rotate(144deg) translateX(140px) rotate(-144deg);}
  to  {transform:rotate(504deg) translateX(140px) rotate(-504deg);}
}
@keyframes tabmedia-orb-4{
  from{transform:rotate(216deg) translateX(140px) rotate(-216deg);}
  to  {transform:rotate(576deg) translateX(140px) rotate(-576deg);}
}
@keyframes tabmedia-orb-5{
  from{transform:rotate(288deg) translateX(140px) rotate(-288deg);}
  to  {transform:rotate(648deg) translateX(140px) rotate(-648deg);}
}
@keyframes tabmedia-orb-fb{
  from{transform:rotate(0deg)   translateX(120px) rotate(0deg);}
  to  {transform:rotate(360deg) translateX(120px) rotate(-360deg);}
}
@keyframes tabmedia-orb-tt{
  from{transform:rotate(180deg) translateX(120px) rotate(-180deg);}
  to  {transform:rotate(540deg) translateX(120px) rotate(-540deg);}
}
@keyframes tabmedia-orb-yt{
  from{transform:rotate(60deg)  translateX(175px) rotate(-60deg);}
  to  {transform:rotate(420deg) translateX(175px) rotate(-420deg);}
}
@keyframes tabmedia-orb-ig{
  from{transform:rotate(240deg) translateX(225px) rotate(-240deg);}
  to  {transform:rotate(600deg) translateX(225px) rotate(-600deg);}
}
@keyframes tabmedia-orb-gg{
  from{transform:rotate(120deg) translateX(265px) rotate(-120deg);}
  to  {transform:rotate(480deg) translateX(265px) rotate(-480deg);}
}
@keyframes tabmedia-panel-in{
  from{opacity:0;transform:translateY(8px);}
  to  {opacity:1;transform:translateY(0);}
}
@keyframes tabmedia-spin-decor{
  0%  {transform:scale(1)   rotate(0deg);}
  50% {transform:scale(1.1) rotate(180deg);}
  100%{transform:scale(1)   rotate(360deg);}
}

/* ═══════════════════════════════════════════
   HERO PARTICLES
═══════════════════════════════════════════ */
.tabmedia-particle{
  position:absolute;
  width:6px;height:6px;
  border-radius:50%;
  background:linear-gradient(135deg,#0061ff,#00c2ff);
  opacity:.4;pointer-events:none;
  animation:tabmedia-float-up 15s linear infinite;
}
.tabmedia-particle:nth-child(1){left:10%;animation-duration:20s;animation-delay:0s;}
.tabmedia-particle:nth-child(2){left:20%;animation-duration:18s;animation-delay:-3s; width:8px;height:8px;}
.tabmedia-particle:nth-child(3){left:35%;animation-duration:22s;animation-delay:-5s;}
.tabmedia-particle:nth-child(4){left:50%;animation-duration:17s;animation-delay:-8s; width:4px;height:4px;}
.tabmedia-particle:nth-child(5){left:65%;animation-duration:19s;animation-delay:-2s;}
.tabmedia-particle:nth-child(6){left:75%;animation-duration:21s;animation-delay:-6s; width:10px;height:10px;}
.tabmedia-particle:nth-child(7){left:85%;animation-duration:16s;animation-delay:-4s;}
.tabmedia-particle:nth-child(8){left:90%;animation-duration:23s;animation-delay:-9s; width:5px;height:5px;}

/* ═══════════════════════════════════════════
   BADGE PULSE DOT
═══════════════════════════════════════════ */
.tabmedia-pulse-dot{animation:tabmedia-pulse-dot 2s ease-in-out infinite;}

/* ═══════════════════════════════════════════
   HERO VISUAL
═══════════════════════════════════════════ */
.tabmedia-vis-aura{
  position:absolute;
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.25) 0%,rgba(14,165,233,.16) 40%,transparent 70%);
  filter:blur(2px);pointer-events:none;
  animation:tabmedia-aura-pulse 6s ease-in-out infinite;
}
.tabmedia-vis-floor{
  position:absolute;
  width:420px;height:220px;bottom:72px;
  border-radius:20px;border:1px solid rgba(59,130,246,.22);
  opacity:.72;pointer-events:none;
  background:
    repeating-linear-gradient(90deg,rgba(37,99,235,.15) 0 1px,transparent 1px 26px),
    repeating-linear-gradient(0deg, rgba(37,99,235,.15) 0 1px,transparent 1px 26px);
  transform:perspective(650px) rotateX(66deg);
  transform-origin:center;
}
.tabmedia-vis-frame{
  position:relative;
  width:330px;height:330px;
  border-radius:28px;
  border:1px solid rgba(59,130,246,.28);
  background:linear-gradient(145deg,rgba(255,255,255,.56),rgba(224,242,254,.2));
  backdrop-filter:blur(4px);
  box-shadow:0 22px 68px rgba(37,99,235,.24);
  animation:tabmedia-float-y 5.8s ease-in-out infinite;
  overflow:visible;
}
.tabmedia-vis-frame::before{
  content:'';position:absolute;
  inset:14px;border:1px dashed rgba(59,130,246,.28);
  border-radius:20px;pointer-events:none;
}
.tabmedia-vis-frame::after{
  content:'';position:absolute;
  inset:36px;border:1px solid rgba(147,197,253,.42);
  border-radius:20px;pointer-events:none;
}
.tabmedia-vis-pulse-ring{
  position:absolute;inset:0;margin:auto;
  width:180px;height:180px;border-radius:50%;
  border:2px solid rgba(59,130,246,.35);pointer-events:none;
  animation:tabmedia-expand-ring 3.4s ease-out infinite;
}
.tabmedia-vis-core{
  position:absolute;inset:0;margin:auto;
  width:128px;height:128px;border-radius:26px;
  background:linear-gradient(145deg,#1d4ed8,#2563eb,#0ea5e9);
  color:#fff;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  box-shadow:
    0 20px 54px rgba(29,78,216,.42),
    0 0 0 12px rgba(37,99,235,.16),
    0 0 0 24px rgba(125,211,252,.2);
  animation:tabmedia-core-pulse 4.4s ease-in-out infinite;
}
/* Pills */
.tabmedia-vis-pill{
  position:absolute;
  min-width:56px;height:30px;border-radius:9999px;
  padding:0 12px;font-size:11px;font-weight:700;color:#fff;
  display:inline-flex;align-items:center;gap:5px;
  box-shadow:0 10px 26px rgba(15,23,42,.2);
  animation:tabmedia-pill-float 4.2s ease-in-out infinite;white-space:nowrap;
}
.tabmedia-vis-pill-fb {top:24px;  right:18px;  background:linear-gradient(135deg,#1877f2,#0d5bcd);}
.tabmedia-vis-pill-ig {top:120px; left:-18px;  background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af);animation-delay:-.8s;}
.tabmedia-vis-pill-tt {right:-14px;bottom:62px;background:linear-gradient(135deg,#111827,#0f172a);animation-delay:-1.4s;}
.tabmedia-vis-pill-ads{left:16px; bottom:18px; background:linear-gradient(135deg,#0284c7,#0ea5e9);animation-delay:-2s;}
/* Bar chart */
.tabmedia-vis-bar{
  width:8px;border-radius:999px;
  background:linear-gradient(180deg,#38bdf8,#2563eb);
  animation:tabmedia-bar-wave 2.2s ease-in-out infinite;
}
.tabmedia-vis-bar:nth-child(1){height:18px;animation-delay:0s;}
.tabmedia-vis-bar:nth-child(2){height:30px;animation-delay:-.2s;}
.tabmedia-vis-bar:nth-child(3){height:22px;animation-delay:-.5s;}
.tabmedia-vis-bar:nth-child(4){height:36px;animation-delay:-.8s;}
.tabmedia-vis-bar:nth-child(5){height:26px;animation-delay:-.35s;}
/* HUD animations */
.tabmedia-vis-hud-a{animation:tabmedia-hud-float 3.6s ease-in-out infinite;}
.tabmedia-vis-hud-b{animation:tabmedia-hud-float 4.1s ease-in-out infinite;animation-delay:-1.2s;}
.tabmedia-vis-hud-c{animation:tabmedia-hud-float 3.9s ease-in-out infinite;animation-delay:-1.8s;}
.tabmedia-vis-meter-fill{
  display:block;height:100%;border-radius:999px;
  background:linear-gradient(90deg,#2563eb,#38bdf8);
  animation:tabmedia-meter-fill 3s ease-in-out infinite;
}
.tabmedia-vis-led-g{animation:tabmedia-led-green 2s ease-in-out infinite;}
.tabmedia-vis-led-b{animation:tabmedia-led-blue  2.3s ease-in-out infinite;}

/* ═══════════════════════════════════════════
   DECOR CIRCLES (hero bg)
═══════════════════════════════════════════ */
.tabmedia-decor-c1{
  position:absolute;width:300px;height:300px;
  top:-100px;right:-100px;
  border:1px solid rgba(0,97,255,.08);border-radius:50%;pointer-events:none;
  animation:tabmedia-spin-decor 30s linear infinite;
}
.tabmedia-decor-c2{
  position:absolute;width:200px;height:200px;
  bottom:-50px;left:-100px;
  border:1px solid rgba(0,97,255,.08);border-radius:50%;pointer-events:none;
  animation:tabmedia-spin-decor 25s linear infinite reverse;
}

/* ═══════════════════════════════════════════
   STATS CIRCLE
═══════════════════════════════════════════ */
.tabmedia-ring-outer{animation:tabmedia-ring-cw  18s linear infinite;}
.tabmedia-ring-inner{animation:tabmedia-ring-ccw 12s linear infinite;}

/* ═══════════════════════════════════════════
   PRIDE GRID – Corner Masks
═══════════════════════════════════════════ */
.tabmedia-pride-card{
  position:relative;background:#e8f0fe;
  min-height:240px;padding:32px 28px;
  display:flex;flex-direction:column;
  justify-content:flex-start;gap:12px;overflow:visible;
}
.tabmedia-pride-mask-tl{
  border-radius:20px 0 0 0;
  -webkit-mask:radial-gradient(circle 75px at calc(100% + 6px) calc(100% + 6px),transparent 74.5px,#000 75px);
  mask:radial-gradient(circle 75px at calc(100% + 6px) calc(100% + 6px),transparent 74.5px,#000 75px);
}
.tabmedia-pride-mask-tr{
  border-radius:0 20px 0 0;align-items:flex-end;text-align:right;
  -webkit-mask:radial-gradient(circle 75px at -6px calc(100% + 6px),transparent 74.5px,#000 75px);
  mask:radial-gradient(circle 75px at -6px calc(100% + 6px),transparent 74.5px,#000 75px);
}
.tabmedia-pride-mask-bl{
  border-radius:0 0 0 20px;
  -webkit-mask:radial-gradient(circle 75px at calc(100% + 6px) -6px,transparent 74.5px,#000 75px);
  mask:radial-gradient(circle 75px at calc(100% + 6px) -6px,transparent 74.5px,#000 75px);
}
.tabmedia-pride-mask-br{
  border-radius:0 0 20px 0;align-items:flex-end;text-align:right;
  -webkit-mask:radial-gradient(circle 75px at -6px -6px,transparent 74.5px,#000 75px);
  mask:radial-gradient(circle 75px at -6px -6px,transparent 74.5px,#000 75px);
}

/* ═══════════════════════════════════════════
   COMMUNITY ORBITAL
═══════════════════════════════════════════ */
.tabmedia-ring-spin-cw {animation:tabmedia-ring-cw  24s linear infinite;}
.tabmedia-ring-spin-ccw{animation:tabmedia-ring-ccw 18s linear infinite;}
.tabmedia-ring-spin-cw3{animation:tabmedia-ring-cw  12s linear infinite;}
.tabmedia-orb-sat-1{animation:tabmedia-orb-1 13s linear infinite;}
.tabmedia-orb-sat-2{animation:tabmedia-orb-2 13s linear infinite;}
.tabmedia-orb-sat-3{animation:tabmedia-orb-3 13s linear infinite;}
.tabmedia-orb-sat-4{animation:tabmedia-orb-4 13s linear infinite;}
.tabmedia-orb-sat-5{animation:tabmedia-orb-5 13s linear infinite;}
.tabmedia-cv-core-pulse{animation:tabmedia-core-pulse 4.6s ease-in-out infinite;}
.tabmedia-cv-card-a{animation:tabmedia-hud-float 3.5s ease-in-out infinite;}
.tabmedia-cv-card-b{animation:tabmedia-hud-float 3.9s ease-in-out infinite;animation-delay:-1.3s;}

/* ═══════════════════════════════════════════
   SERVICE TAB
═══════════════════════════════════════════ */
.tabmedia-htab-panel{display:none;flex-direction:column;height:100%;padding:36px;animation:tabmedia-panel-in .25s ease;}
.tabmedia-htab-panel.is-active{display:flex;}
.tabmedia-htab-btn{
  display:flex;align-items:center;gap:14px;
  padding:18px 20px;background:none;border:none;
  border-left:3px solid transparent;
  cursor:pointer;text-align:left;font-family:'Inter',sans-serif;
  transition:all .2s;width:100%;
}
.tabmedia-htab-btn:hover,.tabmedia-htab-btn.is-active{background:#eff6ff;border-left-color:#2563eb;}
.tabmedia-htab-ico{
  width:44px;height:44px;border-radius:12px;
  background:#eff6ff;color:#2563eb;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .2s,color .2s,transform .22s;
}
.tabmedia-htab-btn:hover .tabmedia-htab-ico{transform:scale(1.08);}
.tabmedia-htab-btn.is-active .tabmedia-htab-ico{background:#2563eb;color:#fff;}
.tabmedia-htab-plat{font-size:10px;font-weight:700;letter-spacing:2px;color:#94a3b8;text-transform:uppercase;display:block;margin-bottom:2px;}
.tabmedia-htab-name{font-size:14px;font-weight:700;color:#1e293b;display:block;line-height:1.3;}
.tabmedia-htab-btn.is-active .tabmedia-htab-plat{color:#93c5fd;}
.tabmedia-htab-btn.is-active .tabmedia-htab-name{color:#1e40af;}

/* ═══════════════════════════════════════════
   PHONE SHELL – lấy từ test.html (Desert Titanium)
═══════════════════════════════════════════ */
.tabmedia-phone-shell{
  position:relative;width:100%;aspect-ratio:340/690;
  border-radius:54px;
background: linear-gradient(
    90deg,
    #0b1e63 0%,
    #2356e8 12%,
    #69b8ff 25%,
    #2a62ee 50%,
    #87d1ff 75%,
    #0a1a57 100%
);
  padding:7px;
}
/* viền đen trong frame */
.tabmedia-phone-shell::before{
  content:'';position:absolute;
  inset:3px;border-radius:52px;
  border:3px solid #050505;
  pointer-events:none;z-index:0;
}
.tabmedia-phone-shell::after{display:none;}
.tabmedia-phone-screen{
  width:100%;height:100%;
  border-radius:48px;
  background:#fff;
  border:4px solid #050505;
  overflow:hidden;
  position:relative;
}
/* Dynamic Island – bên trong screen */
.tabmedia-phone-island{
  width:88px;height:25px;
  background:#000;
  border-radius:999px;
  position:absolute;
  top:16px;left:50%;
  transform:translateX(-50%);
  z-index:5;
}
/* camera "mắt" qua ::after */
.tabmedia-phone-island::after{
  content:'';
  width:13px;height:13px;
  border-radius:50%;
  position:absolute;
  right:8px;top:6px;
  background:radial-gradient(circle,#173d85 0%,#071326 60%,#000 100%);
}
.tabmedia-phone-homebar{
  position:absolute;bottom:9px;left:50%;
  transform:translateX(-50%);
  width:34%;height:4px;border-radius:9999px;
  background:rgba(100,116,139,.4);z-index:2;
}
/* Swiper inside phone */
.tabmedia-phone-swiper{width:100%;height:100%;}
.tabmedia-phone-swiper .swiper-slide{
  background:linear-gradient(145deg,#e0e7f0,#f1f5f9);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:8px;color:#64748b;
  font-size:12px;font-family:'Inter',sans-serif;
  text-align:center;padding:20px;position:relative;
}
.tabmedia-phone-swiper .swiper-slide img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;display:block;
}

/* ═══════════════════════════════════════════
   MOBILE NAV
═══════════════════════════════════════════ */
.tabmedia-mobile-menu{
  transition:max-height .3s ease,opacity .3s ease;
  max-height:0;opacity:0;overflow:hidden;
}
.tabmedia-mobile-menu.open{max-height:420px;opacity:1;}

/* ═══════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════ */
.tabmedia-reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .65s ease,transform .65s ease;
}
.tabmedia-reveal.visible{opacity:1;transform:translateY(0);}

/* ═══════════════════════════════════════════
   FLOATING ZALO BUTTON
═══════════════════════════════════════════ */
.tabmedia-zalo-float{
  position:fixed;bottom:28px;right:28px;z-index:999;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#0068ff,#00a8ff);
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(0,104,255,.45);text-decoration:none;
  transition:transform .2s,box-shadow .2s;
  animation:tabmedia-pulse-dot 2.5s ease-in-out infinite;
}
.tabmedia-zalo-float:hover{transform:scale(1.1);box-shadow:0 12px 36px rgba(0,104,255,.55);}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:900px){
  .tabmedia-pride-mask-tl,
  .tabmedia-pride-mask-tr,
  .tabmedia-pride-mask-bl,
  .tabmedia-pride-mask-br{
    border-radius:14px;
    align-items:flex-start!important;text-align:left!important;
    -webkit-mask:none;mask:none;
  }
  .tabmedia-pride-card{min-height:80px;padding:18px 16px;}
}
/* Single-column: all cards fully rounded */
@media(max-width:639px){
  .tabmedia-pride-mask-tl,
  .tabmedia-pride-mask-tr,
  .tabmedia-pride-mask-bl,
  .tabmedia-pride-mask-br{border-radius:16px!important;}
  .tabmedia-pride-card{min-height:auto;padding:20px 18px;}
}
@media(max-width:768px){
  .tabmedia-vis-frame{width:280px;height:280px;}
  .tabmedia-vis-aura {width:340px;height:340px;}
  .tabmedia-vis-floor{width:340px;}
  .tabmedia-vis-pill {min-width:46px;height:26px;font-size:9.5px;padding:0 9px;}
  .tabmedia-vis-pill-fb {top:14px;right:10px;}
  .tabmedia-vis-pill-ig {top:90px;left:-10px;}
  .tabmedia-vis-pill-tt {right:-8px;bottom:48px;}
  .tabmedia-vis-pill-ads{left:10px;bottom:12px;}
  .tabmedia-vis-core{width:106px;height:106px;border-radius:22px;}
}
@media(max-width:640px){
  .tabmedia-htab-panel{
    display:flex!important;
    border:1px solid #e2e8f0;border-radius:18px;
    background:#fff;box-shadow:0 12px 28px rgba(15,23,42,.06);
    overflow:hidden;position:relative;padding:22px 18px 20px;
  }
  .tabmedia-htab-panel::before{
    content:'';position:absolute;left:0;top:0;bottom:0;
    width:4px;background:linear-gradient(180deg,#2563eb,#1d4ed8);
  }
}


.tabmedia-form-label{font-size:13px;font-weight:700;color:#334155;}
/* Vertical centering for sections that have short content */
.tabmedia-section-center{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
/* Hero fills 100vh and centers its main grid */
.tabmedia-hero-inner{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* ═══════════════════════════════════════════
   FORM FIELDS – Contact/Consultation
═══════════════════════════════════════════ */
.tabmedia-input{
  width:100%;
  padding:11px 15px;
  border:1.5px solid #e2e8f0;
  border-radius:12px;
  font-size:14px;
  font-family:'Inter',sans-serif;
  background:#fff;
  color:#0f172a;
  transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;appearance:none;
}
.tabmedia-input::placeholder{color:#94a3b8;}
.tabmedia-input:focus{
  outline:none;
  border-color:#2563eb;
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
}
.tabmedia-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%2394a3b8' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:36px;
  cursor:pointer;
}
.tabmedia-textarea{resize:vertical;min-height:96px;line-height:1.6;}

/* ═══════════════════════════════════════════
   TEAM BENTO GRID
═══════════════════════════════════════════ */
.tabmedia-bento-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 0.8fr;
  grid-template-rows:220px 200px 170px;
  grid-template-areas:
    "A A B C"
    "A A D E"
    "F G G H";
  gap:10px;
}
.tabmedia-bento-a{grid-area:A;}
.tabmedia-bento-b{grid-area:B;}
.tabmedia-bento-c{grid-area:C;}
.tabmedia-bento-d{grid-area:D;}
.tabmedia-bento-e{grid-area:E;}
.tabmedia-bento-f{grid-area:F;}
.tabmedia-bento-g{grid-area:G;}
.tabmedia-bento-h{grid-area:H;}
.tabmedia-bento-cell{
  border-radius:18px;
  overflow:hidden;
  position:relative;
  transition:transform .3s,box-shadow .3s;
}
.tabmedia-bento-cell:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(15,23,42,.14);
}
.tabmedia-bento-photo{
  background-color:#cbd5e1;
  background-size:cover;
  background-position:center;
}
.tabmedia-bento-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,23,42,.62) 0%,transparent 55%);
}
.tabmedia-bento-label{
  position:absolute;bottom:14px;left:16px;
  color:#fff;font-size:13px;font-weight:700;
  z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.tabmedia-bento-label-lg{font-size:16px;}
.tabmedia-bento-dark{
  background:linear-gradient(145deg,#1e3a8a,#1d4ed8);
  color:#fff;
  display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;
  padding:20px;gap:8px;
}
.tabmedia-bento-amber{
  background:linear-gradient(145deg,#f59e0b,#d97706);
  color:#fff;
  display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;
  padding:20px;gap:6px;
}
@media(max-width:768px){
  .tabmedia-bento-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:200px 160px 160px 140px 140px;
    grid-template-areas:
      "A A"
      "B C"
      "D E"
      "F F"
      "G H";
  }
}
@media(max-width:480px){
  .tabmedia-bento-grid{
    grid-template-columns:1fr;
    grid-template-rows:repeat(8,180px);
    grid-template-areas:"A""B""C""D""E""F""G""H";
  }
}
