@charset "utf-8";

/* ========================================
   共通設定（レスポンシブ崩れ・画面ハミ出し防止）
======================================== */
.orion-new-wrap, .orion-new-wrap * { box-sizing: border-box; }
.orion-new-section { max-width: 960px; margin: 0 auto 50px; padding: 0 15px; }

/* ========================================
   1. スライダー（PC/SPアスペクト比16:9固定、800x450pxベース対応）
======================================== */
.orion-new-slider { max-width: 960px; margin: 20px auto 40px; position: relative; }
.orion-new-slider .swiper { padding-bottom: 35px !important; }
.orion-new-slider .swiper-slide { width: 100%; aspect-ratio: 16 / 9; border-radius: 8px; overflow: hidden; background: #f4f4f4; }
.orion-new-slider .slider-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }
.orion-new-slider .swiper-slide a:hover .slider-img { transform: scale(1.02); }
.orion-new-slider .swiper-pagination { bottom: 0 !important; }
.orion-new-slider .swiper-pagination-bullet { width: 10px; height: 10px; background: #ccc; opacity: 1; margin: 0 5px !important; }
.orion-new-slider .swiper-pagination-bullet-active { background: #009944 !important; }
.orion-new-slider .swiper-button-next, .orion-new-slider .swiper-button-prev { color: #009944 !important; top: calc(50% - 17px); }
.orion-new-slider .swiper-button-next::after, .orion-new-slider .swiper-button-prev::after { font-size: 24px !important; font-weight: bold; }

/* ========================================
   2. アプリプロモーション
======================================= */
.orion-new-app {
	background: linear-gradient(135deg, #e0f7e9 0%, #ffffff 100%);
	border: 2px solid #009944; border-radius: 12px; box-shadow: 0 4px 10px rgba(0,0,0,0.05);
	display: block; text-decoration: none; color: inherit; padding: 25px 20px; text-align: center; transition: transform 0.2s ease;
}
.orion-new-app:hover { transform: translateY(-2px); }
.orion-new-app-ttl { font-size: 1.5rem; color: #009944; margin-bottom: 10px; font-weight: bold; }
.orion-new-app-desc { font-size: 1rem; color: #333; margin-bottom: 15px; }
.orion-new-app-btn { display: inline-block; background: #009944; color: #fff; padding: 12px 30px; border-radius: 30px; font-weight: bold; box-shadow: 0 3px 6px rgba(0,153,68,0.3); }

/* ========================================
   3. ピックアップ
======================================== */
.orion-new-section-header { text-align: center; margin-bottom: 40px; }
.orion-new-h2 { display: inline-block; font-size: 1.6rem; font-weight: bold; border-bottom: 3px solid #009944; padding-bottom: 10px; color: #333; margin: 0; }
.orion-new-h2 .green { color: #009944; }

.orion-new-pickup-container { background: #ffffff; border-radius: 16px; padding: 40px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04); border: 1px solid #f0f0f0; }
.orion-new-pickup-block { margin-bottom: 50px; }
.orion-new-pickup-block:last-child { margin-bottom: 0; }
.orion-new-pickup-head { margin-bottom: 25px; padding-bottom: 15px; border-bottom: 2px solid #f0f0f0; }
.orion-new-pickup-head.flex-between { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 10px; }
.orion-new-h3 { font-size: 1.4rem; font-weight: bold; color: #111; margin: 0; }

.orion-new-more-link { font-size: 0.95rem; color: #009944; text-decoration: none; font-weight: bold; transition: opacity 0.2s; }
.orion-new-more-link:hover { opacity: 0.7; }
.orion-new-more-link .arrow { margin-left: 5px; font-family: sans-serif; }

.orion-new-arrow {
	width: 20px; height: 20px; background: #f0f0f0; border-radius: 50%; display: flex; align-items: center; justify-content: center;
	position: relative; flex-shrink: 0; margin-left: 15px; transition: background 0.2s;
}
.orion-new-arrow::after { content: ""; width: 6px; height: 6px; border-top: 2px solid #999; border-right: 2px solid #999; transform: rotate(45deg); margin-left: -2px; transition: border-color 0.2s; }

.orion-new-trend-list { display: flex; flex-direction: column; gap: 15px; }
.orion-new-trend-item { display: flex; align-items: center; padding: 20px; border-radius: 12px; background: #fafafa; border: 1px solid #eee; text-decoration: none; color: inherit; transition: all 0.3s cubic-bezier(0.1, 0.7, 0.1, 1); }
.orion-new-trend-item:hover { background: #fff; border-color: #009944; box-shadow: 0 5px 15px rgba(0, 153, 68, 0.08); transform: translateY(-2px); }
.orion-new-trend-item:hover .orion-new-arrow { background: #009944; }
.orion-new-trend-item:hover .orion-new-arrow::after { border-color: #fff; }

.orion-new-badge { font-size: 0.75rem; font-weight: bold; color: #fff; padding: 4px 10px; border-radius: 4px; margin-right: 15px; white-space: nowrap; align-self: flex-start; }
.bg-orange { background: #ff7300; }
.bg-red { background: #e60012; }

.orion-new-trend-content { flex-grow: 1; display: flex; flex-direction: column; }
.orion-new-trend-ttl { font-size: 1.1rem; font-weight: bold; color: #333; margin-bottom: 6px; }
.orion-new-trend-desc { font-size: 0.85rem; color: #666; line-height: 1.4;}

.orion-new-event-list { display: flex; flex-direction: column; gap: 15px; }
.orion-new-event-item { display: flex; align-items: center; padding: 15px; border-radius: 12px; background: #fff; border: 1px solid #eee; text-decoration: none; color: inherit; transition: all 0.3s ease; }
.orion-new-event-item:hover { border-color: #009944; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05); }
.orion-new-event-item:hover .orion-new-arrow { background: #009944; }
.orion-new-event-item:hover .orion-new-arrow::after { border-color: #fff; }

.orion-new-event-date {
	background: #f8fcf9; border: 1px solid #dcf0e3; border-radius: 8px; width: 65px; height: 65px;
	display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; margin-right: 20px;
}
.orion-new-event-date .month { font-size: 0.75rem; color: #009944; font-weight: bold; }
.orion-new-event-date .day { font-size: 1.2rem; color: #333; font-weight: 900; line-height: 1; margin-top: 2px; }
.orion-new-event-date .day small { font-size: 0.7rem; font-weight: normal; }

.orion-new-event-content { flex-grow: 1; display: flex; flex-direction: column; }
.orion-new-event-ttl { font-size: 1.1rem; font-weight: bold; color: #333; margin-bottom: 6px; }
.orion-new-event-desc { font-size: 0.85rem; color: #666; line-height: 1.4;}

/* ========================================
   4. テーマ＆エリア（800x450px比率画像 完全固定・同期）
======================================== */
.orion-new-theme-wrapper { background: #f7f9f8; border-radius: 12px; padding: 40px 30px; max-width: 1000px; margin: 0 auto 50px; }
.orion-new-theme-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; margin-top: 30px; }
.orion-new-theme-card { background: #fff; border-radius: 10px; overflow: hidden; box-shadow: 0 4px 15px rgba(0,0,0,0.06); display: flex; flex-direction: column; border: 1px solid #eee; }
.orion-new-theme-main { display: flex; flex-direction: column; text-decoration: none; color: #333; flex-grow: 1; }
.orion-new-theme-imgbox { width: 100%; aspect-ratio: 16 / 9; overflow: hidden; background: #fafafa; }
.orion-new-theme-imgbox img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.orion-new-theme-main:hover .orion-new-theme-imgbox img { transform: scale(1.08); }
.orion-new-theme-main:hover .orion-new-theme-ttl { color: #007a36; }
.orion-new-theme-body { padding: 20px; flex-grow: 1; }
.orion-new-theme-ttl { font-size: 1.25rem; font-weight: bold; color: #009944; margin-bottom: 8px; display: block; transition: color 0.2s; }
.orion-new-theme-ttl::after { content: "▶"; font-size: 0.85rem; margin-left: 8px; }
.orion-new-theme-desc { font-size: 0.95rem; color: #555; line-height: 1.6; display: block; }
.orion-new-theme-sub { display: flex; flex-wrap: wrap; padding: 15px 20px 20px; gap: 10px; border-top: 1px dashed #e0e0e0; background: #fff; }
.orion-new-theme-btn { display: inline-block; padding: 6px 14px; font-size: 0.9rem; color: #009944; border: 1px solid #009944; border-radius: 30px; text-decoration: none; transition: all 0.2s; background: #fff; }
.orion-new-theme-btn:hover { background: #009944; color: #fff; box-shadow: 0 2px 5px rgba(0,153,68,0.2); }

/* ========================================
   5. キーワード（ハッシュタグ型）
======================================== */
.orion-new-keyword-tags { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 25px; }
.orion-new-keyword-tag { display: inline-block; padding: 10px 20px; background: #f0f0f0; color: #444; font-weight: bold; border-radius: 30px; text-decoration: none; font-size: 0.95rem; transition: all 0.2s; }
.orion-new-keyword-tag:hover { background: #009944; color: #fff; }

/* ========================================
   【★新規拡張★】6. YouTube横スクロール型ギャラリー
======================================== */
.orion-new-youtube-carousel {
	width: 100%;
	overflow-x: auto; /* 横スクロールを可能にする */
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch; /* iOSでの慣性スクロールを有効化 */
	padding: 10px 5px 25px 5px;
	margin-top: 25px;
}

/* スクロールバーのカスタマイズ（無骨なバーを隠し、モダンに） */
.orion-new-youtube-carousel::-webkit-scrollbar {
	height: 6px;
}
.orion-new-youtube-carousel::-webkit-scrollbar-track {
	background: #f1f1f1;
	border-radius: 10px;
}
.orion-new-youtube-carousel::-webkit-scrollbar-thumb {
	background: #009944;
	border-radius: 10px;
}
.orion-new-youtube-carousel::-webkit-scrollbar-thumb:hover {
	background: #007a36;
}

/* カルーセル内の直線トラック */
.orion-new-youtube-track {
	display: flex;
	gap: 20px;
	width: max-content; /* 内包する子要素の合計幅に自動拡張 */
}

/* 動画カード単体設定 */
.orion-new-youtube-card {
	width: 320px; /* PC/スマホともにバランスの良い動画幅 */
	background: #ffffff;
	border: 1px solid #eef2f0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0,0,0,0.04);
	display: flex;
	flex-direction: column;
	transition: transform 0.2s ease;
}
.orion-new-youtube-card:hover {
	transform: translateY(-3px);
}

/* iframeの16:9比率固定維持 */
.orion-new-video-wrapper {
	position: relative;
	width: 100%;
	padding-top: 56.25%; /* 16:9比率 */
	background: #000;
}
.orion-new-video-wrapper iframe {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	border: none;
}

/* 動画タイトル文章 */
.orion-new-video-title {
	padding: 12px 15px 15px 15px;
	font-size: 0.92rem;
	font-weight: bold;
	color: #333;
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3; /* タイトルが長い場合は3行で三点リーダー省略 */
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex-grow: 1;
}

/* ========================================
   7. 公式SNSセクション
======================================== */
.orion-new-sns-container { background: #ffffff; border-radius: 16px; padding: 35px 30px; box-shadow: 0 4px 20px rgba(0,0,0,0.03); border: 1px solid #eaeaea; }
.orion-new-sns-intro { font-size: 1rem; color: #555; line-height: 1.6; text-align: center; margin-bottom: 30px; }
.orion-new-sns-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }

.orion-new-sns-card { display: block; padding: 20px; border-radius: 12px; text-decoration: none; color: #333; border: 1px solid #e0e0e0; background: #fafafa; transition: all 0.3s ease; }
.orion-new-sns-card:hover { transform: translateY(-3px); background: #ffffff; }
.orion-new-sns-icon { font-size: 1.8rem; display: block; margin-bottom: 8px; }
.orion-new-sns-name { display: block; font-size: 1.2rem; font-weight: bold; margin-bottom: 6px; }
.orion-new-sns-text { display: block; font-size: 0.88rem; color: #666; line-height: 1.5; }

.orion-new-sns-card.-instagram:hover { border-color: #d62976; box-shadow: 0 5px 15px rgba(214,41,118,0.08); }
.orion-new-sns-card.-instagram:hover .orion-new-sns-name { color: #d62976; }
.orion-new-sns-card.-tiktok:hover { border-color: #000000; box-shadow: 0 5px 15px rgba(0,0,0,0.08); }
.orion-new-sns-card.-tiktok:hover .orion-new-sns-name { color: #000000; }
.orion-new-sns-card.-x:hover { border-color: #111111; box-shadow: 0 5px 15px rgba(0,0,0,0.08); }
.orion-new-sns-card.-x:hover .orion-new-sns-name { color: #111111; }
.orion-new-sns-card.-youtube:hover { border-color: #ff0000; box-shadow: 0 5px 15px rgba(255,0,0,0.08); }
.orion-new-sns-card.-youtube:hover .orion-new-sns-name { color: #ff0000; }

.orion-new-sns-blog-box { margin-top: 30px; text-align: center; border-top: 1px dashed #ddd; padding-top: 25px; }
.orion-new-sns-blog-link { display: inline-block; color: #333; text-decoration: none; font-size: 0.95rem; line-height: 1.5; transition: color 0.2s; }
.orion-new-sns-blog-link strong { color: #009944; }
.orion-new-sns-blog-link:hover { color: #009944; text-decoration: underline; }

/* ========================================
   8. Q&Aセクション
======================================== */
.orion-new-faq-wrap { background: #f9f9f9; padding: 50px 15px; margin-bottom: 50px; }
.orion-new-faq-inner { max-width: 960px; margin: 0 auto; }
.orion-new-faq-list { list-style: none; padding: 0; margin-top: 30px; }
.orion-new-faq-item { background: #fff; border-radius: 8px; margin-bottom: 20px; padding: 25px; border: 1px solid #eee; box-shadow: 0 2px 6px rgba(0,0,0,0.03); }
.orion-new-faq-q { font-weight: bold; color: #009944; margin-bottom: 15px; font-size: 1.15rem; display: flex; align-items: flex-start; line-height: 1.4; margin-top: 0;}
.orion-new-faq-q::before { content: "Q."; margin-right: 12px; font-size: 1.4rem; font-weight: 900; line-height: 1; }
.orion-new-faq-a { color: #333; line-height: 1.7; display: flex; align-items: flex-start; margin: 0; }
.orion-new-faq-a::before { content: "A."; margin-right: 12px; color: #888; font-size: 1.4rem; font-weight: 900; line-height: 1; }

/* ========================================
   スマートフォン対応（メディアクエリ）
======================================== */
@media screen and (max-width: 768px) {
	.orion-new-slider { width: 92%; margin: 15px auto 30px; }
	.orion-new-slider .swiper-button-next::after, .orion-new-slider .swiper-button-prev::after { font-size: 18px !important; }
	
	.orion-new-app { padding: 20px 15px; margin: 20px 15px 40px; }
	.orion-new-app-ttl { font-size: 1.15rem; }
	.orion-new-app-btn { width: 100%; padding: 12px 0; }
	
	.orion-new-pickup-container { padding: 25px 15px; border-radius: 12px; margin: 0 15px; }
	.orion-new-h2 { font-size: 1.25rem; }
	.orion-new-h3 { font-size: 1.15rem; }
	.orion-new-pickup-head.flex-between { flex-direction: column; align-items: flex-start; }
	.orion-new-trend-item { flex-direction: column; align-items: flex-start; padding: 15px; position: relative; }
	.orion-new-badge { margin-bottom: 10px; }
	.orion-new-trend-ttl { font-size: 1rem; line-height: 1.4; }
	.orion-new-arrow { position: absolute; right: 15px; bottom: 15px; }
	.orion-new-event-item { padding: 15px; }
	.orion-new-event-date { width: 55px; height: 55px; margin-right: 15px; }
	.orion-new-event-date .day { font-size: 1rem; }
	.orion-new-event-ttl { font-size: 1rem; line-height: 1.4; padding-right: 20px;}
	.orion-new-event-desc { display: none; }
	
	.orion-new-theme-wrapper { padding: 30px 15px; margin: 0 0 40px; border-radius: 0; }
	.orion-new-theme-grid { grid-template-columns: 1fr; gap: 20px; }
	.orion-new-theme-body { padding: 15px; }
	.orion-new-theme-ttl { font-size: 1.15rem; margin-bottom: 8px; }
	.orion-new-theme-desc { font-size: 0.9rem; }
	.orion-new-theme-sub { padding: 12px 15px 15px; }
	.orion-new-theme-btn { font-size: 0.85rem; padding: 5px 12px; }
	
	.orion-new-keyword-tags { justify-content: flex-start; gap: 8px; }
	.orion-new-keyword-tag { font-size: 0.85rem; padding: 8px 15px; }
	
	/* YouTubeカルーセルのスマホ対応（はみ出しを許容してフリックをスムーズに） */
	.orion-new-youtube-carousel { padding-left: 15px; margin-left: -15px; margin-right: -15px; width: calc(100% + 30px); }
	.orion-new-youtube-card { width: 260px; } /* スマホ画面用に少しコンパクトに */
	.orion-new-video-title { font-size: 0.85rem; padding: 10px; }

	/* SNSスマホ最適化 */
	.orion-new-sns-container { padding: 20px 15px; }
	.orion-new-sns-grid { grid-template-columns: 1fr; gap: 12px; }
	.orion-new-sns-card { padding: 15px; }
	.orion-new-sns-name { font-size: 1.1rem; }
	
	.orion-new-faq-wrap { padding: 35px 0; }
	.orion-new-faq-item { padding: 20px 15px; margin: 0 15px 15px; }
	.orion-new-faq-q { font-size: 1.05rem; margin-bottom: 10px; }
	.orion-new-faq-q::before, .orion-new-faq-a::before { font-size: 1.2rem; margin-right: 10px; }
	.orion-new-faq-a { font-size: 0.95rem; }
}