/*
Theme Name: Lightning Child
Template: lightning
Version: 1.0.0
*/

/* サイトタイトル/ロゴのテキストを2周り大きく */
.container.siteHeadContainer .navbar-brand,
.container.siteHeadContainer .siteHeader_logo {
  font-size: 120%; /* 2周り大きく */
  font-weight: bold;
  margin-right: auto; /* ロゴを左に寄せるための追加 */
}

/* メニュー項目のサイズを大きくする - より具体的なセレクタを使用 */
.gMenu_outer ul.menu li a .gMenu_name,
.gMenu_outer ul.gMenu li a .gMenu_name,
#menu-%e3%83%a1%e3%82%a4%e3%83%b3%e3%83%a1%e3%83%8b%e3%83%a5%e3%83%bc li a .gMenu_name {
  font-size: 14px !important; /* 固定サイズで指定 */
  font-weight: bold !important;
}

/* サイトロゴが画像の場合でも少し大きくする */
.container.siteHeadContainer .navbar-brand img,
.container.siteHeadContainer .siteHeader_logo img {
  max-height: none; /* 元の高さ制限を解除 */
  height: auto;
  width: auto;
  max-width: 0%;
}

/* メニュー項目のサイズを画面幅に応じて調整 */
.gMenu_outer ul.menu li a .gMenu_name,
.gMenu_outer ul.gMenu li a .gMenu_name,
#menu-%e3%83%a1%e3%82%a4%e3%83%b3%e3%83%a1%e3%83%8b%e3%83%a5%e3%83%bc li a .gMenu_name {
  font-weight: bold !important;
  font-size: clamp(10px, 1.5vw, 18px) !important; /* 画面幅に応じて12px〜18pxの間で自動調整 */
  letter-spacing: -0.05em !important; /* 文字間を少し詰める */
}

.container.siteHeadContainer {
  width: 100%;
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
  margin-left: 0;
  margin-right: 0;
}

/* 内部の要素も端から端まで表示するように調整 */
.siteHeader .container {
  width: 100%;
  max-width: 100%;
}

/*以下ロゴフォントアニメーション項目*/
/* サイバー風の光るエフェクト */
@keyframes safetyWave {
  0%, 100% {
    text-shadow: 
      0 0 5px rgba(255, 255, 255, 0.7), 
      0 0 10px rgba(0, 120, 255, 0.4), 
      -5px 0 15px rgba(0, 153, 255, 0.1),
      0 0 2px rgba(0, 255, 255, 0.3);
  }
  25% {
    text-shadow: 
      0 0 8px rgba(255, 255, 255, 0.8), 
      0 0 15px rgba(0, 120, 255, 0.5), 
      -8px 0 20px rgba(0, 153, 255, 0.15),
      0 0 5px rgba(0, 255, 255, 0.4);
  }
  50% {
    text-shadow: 
      0 0 12px rgba(255, 255, 255, 0.9), 
      0 0 25px rgba(0, 120, 255, 0.7), 
      -12px 0 35px rgba(0, 153, 255, 0.25),
      0 0 10px rgba(0, 255, 255, 0.6);
  }
  75% {
    text-shadow: 
      0 0 8px rgba(255, 255, 255, 0.8), 
      0 0 15px rgba(0, 120, 255, 0.5), 
      -8px 0 20px rgba(0, 153, 255, 0.15),
      0 0 5px rgba(0, 255, 255, 0.4);
  }
}

/* .slide-text-title クラスにアニメーション適用 */
.slide-text-title {
  /* フォント設定 */
  font-family: 'Orbitron', 'Rajdhani', sans-serif !important;
  font-weight: 500 !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  
  /* 疑似要素のための位置指定 */
  position: relative !important;
  
  /* 下線エフェクト用の背景設定 */
  background-image: linear-gradient(90deg, 
    transparent 0%, 
    rgba(255, 255, 255, 0.9) 30%,
    rgba(0, 190, 255, 1) 50%,
    rgba(255, 255, 255, 0.9) 70%,
    transparent 100%) !important;
  background-size: 200% 4px !important; /* 線を4pxに太く */
  background-repeat: no-repeat !important;
  background-position: 200% 100% !important; /* 右端からスタート */
  padding-bottom: 8px !important; /* パディングも少し増やす */
  
  /* アニメーション設定 */
  animation: 
    slideInRight 1.5s ease-out forwards,
    safetyWave 5s ease-in-out infinite 1.5s,
    speedGlow 3s infinite ease-in-out 1.5s,
    highlightLine 2.5s ease-out 1.5s forwards !important;
}

/* テキストが左から右にスライドしながら現れるアニメーション - 光るエフェクト付き */
@keyframes slideInRight {
  0% {
    opacity: 0;
    transform: translateX(-50px);
    filter: blur(8px);
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.9), 
                 0 0 20px rgba(0, 120, 255, 0.8), 
                 -10px 0 30px rgba(0, 153, 255, 0.4),
                 0 0 15px rgba(0, 255, 255, 0.7);
  }
  30% {
    opacity: 0.7;
    filter: blur(5px);
    text-shadow: 0 0 15px rgba(255, 255, 255, 1.0), 
                 0 0 25px rgba(0, 120, 255, 0.9), 
                 -10px 0 35px rgba(0, 153, 255, 0.5),
                 0 0 18px rgba(0, 255, 255, 0.8);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
    filter: blur(0);
  }
}

/* ハイライト線が右から左にスライドするアニメーション */
@keyframes highlightLine {
  0% {
    background-position: 200% 100%; /* 右端からスタート */
  }
  100% {
    background-position: -100% 100%; /* 左端へ移動して消える */
  }
}

/* 光のエフェクト（ライトニングのような走る光） */
@keyframes speedGlow {
  0%, 100% {
    text-shadow: 
      0 0 5px rgba(255, 255, 255, 0.5),
      0 0 10px rgba(0, 120, 255, 0.3),
      0 0 15px rgba(0, 153, 255, 0.2);
  }
  50% {
    text-shadow: 
      0 0 10px rgba(255, 255, 255, 0.8),
      0 0 20px rgba(0, 120, 255, 0.6),
      0 0 30px rgba(0, 153, 255, 0.4),
      5px 0 40px rgba(0, 200, 255, 0.3);
  }
}

/* 追加: 文字のクリッピング効果 */
.slide-text-title::before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: linear-gradient(90deg, 
    transparent, 
    rgba(0, 210, 255, 0.2), 
    transparent);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  transform: translateX(-10px);
  filter: blur(2px);
  animation: glitchEffect 8s infinite linear 2s;
}

@keyframes glitchEffect {
  0%, 100% { transform: translateX(-5px); }
  25% { transform: translateX(0); }
  35% { transform: translateX(-2px); opacity: 0.8; }
  45% { transform: translateX(0); opacity: 1; }
  50% { transform: translateX(5px); }
  75% { transform: translateX(0); }
  85% { transform: translateX(2px); opacity: 0.8; }
  95% { transform: translateX(0); opacity: 1; }
}

/*アニメーションここまで*/

/* レスポンシブ対応 */
@media (max-width: 500px) {
  .siteHeader .container {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/*以下スライド設定*/

/* スライド変更時の高度なエフェクト */
.carousel.fancy-transition .carousel-inner .carousel-item {
    transform: scale(0.98) translateY(10px);
    opacity: 0;
    transition: all 1.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.carousel.fancy-transition .carousel-inner .active {
    transform: scale(1) translateY(0);
    opacity: 1;
}

/* すべてのスライド画像に確実に適用するためのCSS */
.carousel-item img,
.carousel-item .slide-item-img,
.carousel-item picture img,
.item picture img,
.item .slide-item-img,
.carousel.slide.slide-main.carousel-fade .item picture img,
.carousel.slide.slide-main.carousel-fade .carousel-item picture img {
    height: 700px !important;
    object-fit: cover !important;
    object-position: center 40% !important;
    width: 100% !important;
}

/* picture要素にも設定を適用 */
.carousel-item picture,
.item picture {
    display: block;
    width: 100%;
    height: 700px;
}

/* アイテムコンテナにも適用 */
.carousel-item,
.item,
.carousel.slide.slide-main.carousel-fade .carousel-item,
.carousel.slide.slide-main.carousel-fade .item {
    height: 700px !important;
    overflow: hidden;
}

/* カルーセルの内部要素にも設定を適用 */
.carousel-inner,
.carousel.slide.slide-main.carousel-fade .carousel-inner {
    height: 700px !important;
    overflow: hidden;
}

/* すべてのスライドに対応するため、クラス名の組み合わせをカバー */
.carousel.slide .carousel-item .slide-item-img,
.carousel.slide.carousel-fade .carousel-item .slide-item-img,
.carousel.slide.slide-main .carousel-item .slide-item-img,
.carousel.slide.slide-main.carousel-fade .carousel-item .slide-item-img,
.carousel.slide .item .slide-item-img,
.carousel.slide.carousel-fade .item .slide-item-img,
.carousel.slide.slide-main .item .slide-item-img,
.carousel.slide.slide-main.carousel-fade .item .slide-item-img {
    height: 700px !important;
    object-fit: cover !important;
    object-position: center 40% !important;
}

/* d-block w-100クラスの画像に対して特定の設定を適用 */
.slide-item-img.d-block.w-100 {
    height: 700px !important;
    object-fit: cover !important;
    object-position: center 40% !important;
}

/*ナビゲーションメニュー*/
.gMenu > li > a .gMenu_name {
    font-size: 18px;
    font-family:  'Orbitron', 'Rajdhani', sans-serif;
    font-weight: bold;
	  justify-content: flex-start;
}

/* メニューコンテナを左寄せに調整 */
.gMenu_outer {
  margin-left: 30px !important;
  justify-content: flex-start !important;
}

/* メニュー全体の左寄せ */
.gMenu_outer nav {
  justify-content: flex-start !important;
}

/* メニューアイテムの左寄せ */
.gMenu_outer ul.gMenu,
.gMenu_outer ul.menu,
#menu-%e3%83%a1%e3%82%a4%e3%83%b3%e3%83%a1%e3%83%8b%e3%83%a5%e3%83%bc {
  justify-content: flex-start !important;
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* siteHeadContainerの調整 - flexboxを活用 */
.container.siteHeadContainer {
  display: flex !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  align-items: center !important;
}

/* ロゴのサイズコントロール */
.navbar-brand.siteHeader_logo img {
  max-width: 300px !important;
  width: auto !important;
  height: auto !important;
}

/* navbar-headerの調整 */
.navbar-header {
  flex: 0 0 auto !important;
}

/* スローガン及びread Moreの文字位置修正 - 全スライド対応 */
.mini-content-container-1 h3.slide-text-title,
.mini-content-container-2 h3.slide-text-title,
.mini-content-container-3 h3.slide-text-title,
.slide-text-set .mini-content-container h3.slide-text-title,
.mini-content h3.slide-text-title {
    margin-top: 150px;
    margin-bottom: 330px;
    font-size: 220%;
}

/* 元のReadmore枠線を強制的に削除 - 全スライド対応 */
.mini-content-container-1 .btn.btn-ghost,
.mini-content-container-2 .btn.btn-ghost,
.mini-content-container-3 .btn.btn-ghost,
.slide-text-set .mini-content-container .btn.btn-ghost,
.mini-content .btn.btn-ghost {
    border: none !important;
    border-top: none !important;
    border-right: none !important;
    border-left: none !important;
    border-bottom: 2px solid #ffffff !important;
    border-radius: 0;
    padding: 8px 15px 6px;
    background: transparent;
    font-weight: bold;
    font-size: 150%;
    letter-spacing: 5px;
    position: relative;
    box-shadow: none !important;
}

/* 2本目の下線を疑似要素で追加 - 全スライド対応 */
.mini-content-container-1 .btn.btn-ghost::after,
.mini-content-container-2 .btn.btn-ghost::after,
.mini-content-container-3 .btn.btn-ghost::after,
.slide-text-set .mini-content-container .btn.btn-ghost::after,
.mini-content .btn.btn-ghost::after {
    content: "";
    position: absolute;
    bottom: -11px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #ffffff;
}

/* ホバー時のスタイル - 全スライド対応 */
.mini-content-container-1 .btn.btn-ghost:hover,
.mini-content-container-2 .btn.btn-ghost:hover,
.mini-content-container-3 .btn.btn-ghost:hover,
.slide-text-set .mini-content-container .btn.btn-ghost:hover,
.mini-content .btn.btn-ghost:hover {
    border-bottom: 2px solid #339900 !important;
    background: transparent;
    color: #339900 !important;
}

/* ホバー時の2本目の線も変更 */
.mini-content-container-1 .btn.btn-ghost:hover::after,
.mini-content-container-2 .btn.btn-ghost:hover::after,
.mini-content-container-3 .btn.btn-ghost:hover::after,
.slide-text-set .mini-content-container .btn.btn-ghost:hover::after,
.mini-content .btn.btn-ghost:hover::after {
    background-color: #339900;
}

/* さらに汎用的なセレクタも追加 */
.carousel-item .btn.btn-ghost,
.carousel .btn.btn-ghost {
    border: none !important;
    border-top: none !important;
    border-right: none !important;
    border-left: none !important;
    border-bottom: 2px solid #ffffff !important;
    border-radius: 0;
    padding: 8px 15px 6px;
    background: transparent;
    font-weight: bold;
    font-size: 150%;
    letter-spacing: 5px;
    position: relative;
    box-shadow: none !important;
}

.carousel-item .btn.btn-ghost::after,
.carousel .btn.btn-ghost::after {
    content: "";
    position: absolute;
    bottom: -11px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #ffffff;
}

.carousel-item .btn.btn-ghost:hover,
.carousel .btn.btn-ghost:hover {
    border-bottom: 2px solid #339900 !important;
    background: transparent;
    color: #339900 !important;
}

.carousel-item .btn.btn-ghost:hover::after,
.carousel .btn.btn-ghost:hover::after {
    background-color: #339900;
}

/* wp-block-coverのホバーエフェクト */
.wp-block-cover {
    transition: transform 0.3s ease, filter 0.3s ease !important;
    overflow: hidden !important;
    position: relative;
}

/* ホバー時にカバーブロック全体を少し浮かせる */
.wp-block-cover:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

/* 背景ディム層に対する追加効果 */
.wp-block-cover:hover .wp-block-cover__background.has-background-dim {
    opacity: 0.7;
}

/* グループリンクを持つグループ全体にホバーエフェクトを適用 */
.wp-block-group.has-link {
    position: relative !important;
    overflow: hidden !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

.wp-block-group.has-link:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2) !important;
}

/* ロゴの基本スタイルをさらに大きく */
.navbar-brand.siteHeader_logo {
    margin: 0;
    padding: 0;
    width: auto;
    display: inline-block;
}

.navbar-brand.siteHeader_logo img {
    max-width: none;
    height: auto;
    display: block;
    width: 150%;
    min-width: 300px;
}

/* ヘッダーコンテナのレイアウト調整 */
.container.siteHeadContainer {
    padding-left: 0;
    display: flex;
    align-items: center;
}

/* レスポンシブ対応 */
@media (max-width: 991px) {
    .navbar-brand.siteHeader_logo {
        padding-left: 15px;
        width: 85%;
        max-width: 400px;
    }
    
    .navbar-brand.siteHeader_logo img {
        width: 100%;
        min-width: 250px;
    }
}

@media (max-width: 576px) {
    .navbar-brand.siteHeader_logo {
        width: 90%;
        max-width: 320px;
    }
    
    .navbar-brand.siteHeader_logo img {
        min-width: 200px;
    }
}

/* 最新投稿の画像ホバーエフェクト */
.wp-block-latest-posts__featured-image {
    overflow: hidden;
    position: relative;
}

/* より強力なセレクタで確実に適用 */
.wp-block-image.size-full.is-resized.icon,
figure.wp-block-image.size-full.is-resized.icon {
    overflow: hidden !important;
    position: relative !important;
    transition: all 0.3s ease !important;
    display: inline-block !important;
}

/* ホバー時の効果 */
.wp-block-image.size-full.is-resized.icon:hover,
figure.wp-block-image.size-full.is-resized.icon:hover {
    transform: scale(1.05) !important; 
    filter: brightness(1.1) !important;
    box-shadow: 0 5px 15px rgba(0,0,0,0.2) !important;
}

/* 画像自体にもエフェクトを追加 */
.wp-block-image.size-full.is-resized.icon img,
figure.wp-block-image.size-full.is-resized.icon img {
    transition: all 0.3s ease !important;
}

.wp-block-image.size-full.is-resized.icon:hover img,
figure.wp-block-image.size-full.is-resized.icon:hover img {
    transform: scale(1.02) !important;
}

.wp-block-latest-posts__featured-image img {
    transition: transform 0.2s ease;
}

.wp-block-latest-posts__featured-image:hover img {
    transform: scale(1.01);
    z-index: 10;
}

.NEWS .wp-block-latest-posts__featured-image img {
    transition: transform 0.5s ease;
}

.NEWS .wp-block-latest-posts__featured-image:hover img {
    transform: scale(1.2);
    z-index: 10;
}

/* フッタークレジットを非表示にする */
.copySection p:last-child {
    display: none;
}

.postNextPrev {
	display:none;
}

/*NEWS項目の画像サイズを均一に設定*/
.wp-block-latest-posts__featured-image.aligncenter img {
    width: 300px;
    height: 200px;
    object-fit: cover;
}

/*LINK画像のスマホ対応*/
@media screen and (max-width: 768px) {
  .links.is-style-default a,
  .links.is-style-default .wp-block-cover-text,
  .links.is-style-default .wp-block-cover__inner-container {
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
    display: block !important;
  }
  
  .links.is-style-default .wp-block-cover,
  .links.is-style-default .wp-block-cover img {
    width: auto !important;
    height: auto !important;
  }
}

/* 会員専用ページのアイコンブロックサイズ統一 */
.wp-block-group.icon.is-style-vk-group-alert-warning,
.wp-block-group.icon.is-style-vk-group-alert-success,
.wp-block-group.icon.is-style-vk-group-alert-info {
    width: 300px !important;
    height: 300px !important;
    margin: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;
    padding: 20px !important;
    box-sizing: border-box !important;
}

/* すべての画像のサイズを統一 */
.wp-block-group.icon.is-style-vk-group-alert-warning figure.wp-block-image img,
.wp-block-group.icon.is-style-vk-group-alert-success figure.wp-block-image img,
.wp-block-group.icon.is-style-vk-group-alert-info figure.wp-block-image img {
    width: 200px !important;
    height: auto !important;
    margin-bottom: 15px !important;
}

/* ボタンのスタイルを統一 */
.wp-block-group.icon .wp-block-vk-blocks-button {
    margin-top: auto !important;
    width: 100% !important;
}

/* 親コンテナの調整（フレックスボックスで中央揃え） */
.wp-block-group.is-content-justification-center.is-nowrap {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: stretch !important;
    width: 100% !important;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
    .wp-block-group.icon.is-style-vk-group-alert-warning,
    .wp-block-group.icon.is-style-vk-group-alert-success,
    .wp-block-group.icon.is-style-vk-group-alert-info {
        width: 90% !important;
        margin: 10px auto !important;
    }
    
    .wp-block-group.is-content-justification-center.is-nowrap {
        flex-direction: column !important;
    }
}

/* レスポンシブカレンダー用CSS改良版 */
.responsive-calendar-container {
    position: relative;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding-bottom: 75%;
    height: 0;
    overflow: hidden;
}

.responsive-calendar-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    border: 1px solid #e4e4e4;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

@media (max-width: 767px) {
    .responsive-calendar-container {
        padding-bottom: 180%;
    }
    
    .responsive-calendar-container iframe {
        font-size: 12px !important;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .responsive-calendar-container {
        padding-bottom: 100%;
    }
}

@media (max-width: 400px) {
    .responsive-calendar-container {
        padding-bottom: 220%;
    }
}

.responsive-calendar-container iframe::-webkit-scrollbar {
    display: none;
}

.responsive-calendar-container iframe {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

@media (min-width: 768px) {
    .gMenu > li:before, 
    .gMenu > li.menu-item-has-children::after {
        display: none !important;
    }
    
    .gMenu > li {
        position: relative;
        transition: all 0.3s ease;
        box-shadow: 0 0 0 0 transparent, 0 0 0 0 transparent;
    }
    
    .gMenu > li:hover {
        box-shadow: 
            -2px 0 0 0 #339900,
            0 -2px 0 0 #339900;
    }
    
    .gMenu > li > a:hover .gMenu_name {
        color: #339900 !important;
        transition: color 0.3s ease;
    }
    
    .gMenu li li {
        background-color: #339900;
    }
    
    .gMenu li li:hover,
    .gMenu li li a:hover {
        background-color: #225500 !important;
        transition: background-color 0.3s ease;
    }
    
    .gMenu li li a {
        color: #ffffff !important;
    }
    
    .gMenu li li a:hover {
        color: #ffffff !important;
    }
}

/* サイバーなGoogleフォントの読み込み */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Audiowide&display=swap');

.kaiga {
  display: inline-block;
  transition: transform 0.6s ease; 
}

.kaiga:hover {
  transform: scale(1.01);
}

/*会員一覧*/
.company-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
    padding: 20px 0;
    margin: 0;
}

.company-tile {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 20px;
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
}

.company-tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

.company-thumbnail {
    width: 100%;
    overflow: hidden;
    border-radius: 6px;
    margin-bottom: 15px;
    background: #f5f5f5;
}

.company-thumbnail a {
    display: block;
}

.company-thumbnail img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}

.company-title {
    margin: 10px 0 8px;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
}

.company-title a {
    text-decoration: none;
    color: #333;
    transition: color 0.2s;
}

.company-title a:hover {
    color: #0073aa;
}

.company-excerpt {
    color: #666;
    font-size: 14px;
    line-height: 1.6;
    margin-top: auto;
}

.company-excerpt p {
    margin: 0;
}

@media (max-width: 768px) {
    .company-tiles {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
}

@media (max-width: 480px) {
    .company-tiles {
        grid-template-columns: 1fr;
    }
}