/* ============================================
   PRICE BASE ORIPA LAB
   Design V2: Light base + Navy + Gold
   ============================================ */

/* --- Tokens --- */
.pb-oripa {
  --navy:          #2a3370;
  --navy-dark:     #1c2355;
  --navy-light:    #3d4a8f;
  --navy-pale:     #e8eaf6;
  --gold:          #c4a24d;
  --gold-light:    #dfc78a;
  --gold-bg:       rgba(196,162,77,0.07);
  --gold-border:   rgba(196,162,77,0.28);
  --cyan:          #0ea5e9;
  --purple:        #7c5cbf;
  --green:         #22a760;
  --amber:         #e8960c;
  --hot:           #e8453c;
  --bg:            #ffffff;
  --bg-alt:        #f5f6fb;
  --bg-hero:       linear-gradient(165deg, #f0f1fa 0%, #f8f7ff 30%, #fff 70%);
  --text:          #1a1a2e;
  --text-sub:      #5a6578;
  --text-muted:    #8c95a8;
  --border:        #e2e5ee;
  --border-light:  #eef0f5;
  --radius:        10px;
  --radius-lg:     14px;
  --radius-sm:     6px;
  --radius-pill:   50px;
  --shadow-sm:     0 1px 3px rgba(30,35,85,0.06);
  --shadow-md:     0 4px 16px rgba(30,35,85,0.08);
  --shadow-lg:     0 8px 32px rgba(30,35,85,0.10);
  --transition:    0.22s ease;

  font-family: 'Noto Sans JP', sans-serif;
  color: var(--text);
  line-height: 1.8;
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}

/* --- Swell Override --- */
.pb-oripa-fullwidth #content.l-content { max-width:100%; padding:0 !important; }
.pb-oripa-fullwidth .l-mainContent { flex:1 1 100%; max-width:100%; margin:0 !important; padding:0 !important; }
.pb-oripa-fullwidth .l-mainContent__inner { max-width:100%; padding:0; margin:0; }
.pb-oripa-fullwidth #sidebar,
.pb-oripa-fullwidth .l-sidebar { display:none; }
.pb-oripa-fullwidth .p-breadcrumb { display:none !important; }
.pb-oripa-fullwidth .l-topTitleArea,
.pb-oripa-fullwidth #top_title_area { display:none !important; }
.pb-oripa-fullwidth .post_content { max-width:100%; padding:0; }
.pb-oripa-fullwidth #content,
.pb-oripa-fullwidth .l-content,
.pb-oripa-fullwidth .l-container,
.pb-oripa-fullwidth .l-article { padding-top:0 !important; margin-top:0 !important; }
.pb-oripa-fullwidth .pb-oripa { padding-top:0; margin-top:0; }
/* ブログパーツ221011 グローバルスタイル上書き（オリパページ限定） */
.pb-oripa-fullwidth .c-infoBar { display: none !important; }
#body_wrap.pb-oripa-fullwidth { margin-top: 0 !important; }
.pb-oripa-fullwidth #header { position: relative !important; }

/* --- Reset --- */
.pb-oripa *, .pb-oripa *::before, .pb-oripa *::after { box-sizing:border-box; }
.pb-oripa img { max-width:100%; height:auto; }

/* --- Container --- */
.pb-oripa-container { max-width:1140px; margin:0 auto; padding:0 1.5rem; }

/* --- Buttons --- */
.pb-oripa-btn {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.72rem 1.6rem; font-size: 0.85rem; font-weight: 700;
  border-radius: var(--radius-sm); border: 2px solid transparent;
  cursor: pointer; transition: all var(--transition); line-height: 1.4;
  text-decoration: none; white-space: nowrap;
}
.pb-oripa-btn--navy { background:var(--navy); color:#fff; border-color:var(--navy); }
.pb-oripa-btn--navy:hover { background:var(--navy-dark); border-color:var(--navy-dark); color:#fff; }
.pb-oripa-btn--outline-navy { background:#fff; color:var(--navy); border-color:var(--border); }
.pb-oripa-btn--outline-navy:hover { border-color:var(--navy); background:var(--navy-pale); color:var(--navy); }
.pb-oripa-btn--cta-gold { background:transparent; color:var(--gold-light); border:2px solid var(--gold); padding:0.8rem 1.8rem; font-size:0.82rem; }
.pb-oripa-btn--cta-gold:hover { background:var(--gold); color:var(--navy-dark); }

/* ============================================
   HERO
   ============================================ */
.pb-oripa-hero {
  position: relative;
  background: var(--bg-hero);
  padding: 3.5rem 0 3rem;
  overflow: hidden;
}
/* Decorative elements */
.pb-oripa-hero__deco { position:absolute; pointer-events:none; }
.pb-oripa-hero__deco--diamond { width:14px; height:14px; background:var(--gold-border); transform:rotate(45deg); border-radius:2px; }
.pb-oripa-hero__deco--diamond-outline { width:18px; height:18px; border:1.5px solid var(--gold-border); transform:rotate(45deg); border-radius:2px; }
.pb-oripa-hero__deco--dot { width:6px; height:6px; background:rgba(42,51,112,0.12); border-radius:50%; }
.pb-oripa-hero__deco--circle { width:22px; height:22px; border:1.5px solid rgba(42,51,112,0.08); border-radius:50%; }
.pb-oripa-deco-1{top:12%;left:8%} .pb-oripa-deco-2{top:25%;left:3%} .pb-oripa-deco-3{top:60%;left:6%}
.pb-oripa-deco-4{top:18%;right:5%} .pb-oripa-deco-5{top:75%;right:8%} .pb-oripa-deco-6{top:40%;left:15%}
.pb-oripa-deco-7{bottom:15%;left:12%} .pb-oripa-deco-8{top:8%;right:30%}

.pb-oripa-hero__inner {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 3rem;
}
.pb-oripa-hero__text { flex:1; min-width:0; }
.pb-oripa-hero__title {
  font-size: clamp(1.7rem,3.5vw,2.4rem); font-weight:900;
  line-height:1.45; color:var(--navy-dark); margin-bottom:1rem;
}
.pb-oripa-hero__title em {
  font-style:normal;
  background:linear-gradient(135deg,#c4a24d,#a8842e);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  font-weight:900; position:relative;
}
.pb-oripa-hero__title em::before,
.pb-oripa-hero__title em::after {
  content:'\2726'; position:absolute; font-size:0.4em; -webkit-text-fill-color:var(--gold);
}
.pb-oripa-hero__title em::before { top:-0.2em; left:-0.6em; }
.pb-oripa-hero__title em::after  { top:-0.3em; right:-0.7em; font-size:0.3em; }
.pb-oripa-hero__desc { font-size:0.88rem; color:var(--text-sub); line-height:1.9; margin-bottom:1.8rem; }
.pb-oripa-hero__ctas { display:flex; gap:0.8rem; flex-wrap:wrap; }

/* Trust badge */
.pb-oripa-hero__trust {
  position:absolute; top:-0.5rem; right:0; z-index:5;
  width:195px; height:auto; pointer-events:none;
}
.pb-oripa-hero__trust img { width:100%; height:auto; display:block; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.08)); }

/* Visual area (placeholder for future imagery) */
.pb-oripa-hero__visual { flex:0 0 380px; height:340px; position:relative; }

/* ============================================
   FILTERS
   ============================================ */
.pb-oripa-filters { padding:1.2rem 0; background:#fff; border-bottom:1px solid var(--border-light); }
.pb-oripa-filters__list {
  display:flex; gap:0.55rem; overflow-x:auto; padding-bottom:0.3rem;
  scrollbar-width:none; justify-content:center; list-style:none; margin:0; padding:0;
}
.pb-oripa-filters__list::-webkit-scrollbar { display:none; }
.pb-oripa-filter-pill {
  display:inline-flex; align-items:center; gap:0.35rem;
  padding:0.5rem 1rem; background:#fff; border:1.5px solid var(--border);
  border-radius:var(--radius-pill); font-size:0.76rem; font-weight:600;
  color:var(--text-sub); transition:all var(--transition); white-space:nowrap; cursor:pointer;
  text-decoration:none;
}
.pb-oripa-filter-pill:hover { border-color:var(--navy); color:var(--navy); background:var(--navy-pale); }
.pb-oripa-filter-pill svg { width:15px; height:15px; flex-shrink:0; color:var(--text-muted); }
.pb-oripa-filter-pill:hover svg { color:var(--navy); }

/* ============================================
   SECTION SHARED
   ============================================ */
.pb-oripa-section { padding:3rem 0; }
.pb-oripa-section--alt { background:var(--bg-alt); }
.pb-oripa-section-heading {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:1.8rem;
}
.pb-oripa-section-heading__title {
  font-size:1.15rem; font-weight:800; color:var(--navy-dark);
  display:flex; align-items:center; gap:0.5rem;
}
.pb-oripa-section-heading__icon { width:22px; height:22px; color:var(--navy); }
.pb-oripa-section-heading__more {
  font-size:0.75rem; font-weight:600; color:var(--text-muted); transition:color var(--transition); text-decoration:none;
}
.pb-oripa-section-heading__more:hover { color:var(--navy); }

/* ============================================
   FEATURED ORIPA — 射幸心フルブースト版
   ============================================ */
.pb-oripa-featured__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }

/* --- Card base --- */
.pb-oripa-fcard {
  background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; transition:all 0.32s ease; position:relative;
}
.pb-oripa-fcard:hover { transform:translateY(-5px); box-shadow:0 12px 40px rgba(30,35,85,0.15); }

/* Pick (1位) card */
.pb-oripa-fcard--pick {
  border-color:var(--gold);
  box-shadow:0 0 0 1px var(--gold), 0 0 24px rgba(196,162,77,0.15), var(--shadow-md);
}
.pb-oripa-fcard--pick:hover {
  box-shadow:0 0 0 2px var(--gold), 0 0 40px rgba(196,162,77,0.25), 0 12px 40px rgba(30,35,85,0.15);
}

/* --- Rank medal --- */
.pb-oripa-fcard__rank {
  position:absolute; top:-4px; left:12px; z-index:3;
  font-size:2rem; filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2));
  line-height:1;
}

/* --- Badge (編集部注目 etc) --- */
.pb-oripa-fcard__badge {
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,#ff6b35,#ff2d78);
  color:#fff; font-size:0.65rem; font-weight:800; padding:0.25rem 1.2rem;
  border-radius:0 0 var(--radius-sm) var(--radius-sm); z-index:4;
  letter-spacing:0.06em; text-shadow:0 1px 2px rgba(0,0,0,0.2);
  animation:badge-glow 2s ease-in-out infinite;
}
@keyframes badge-glow {
  0%,100% { box-shadow:0 2px 8px rgba(255,45,120,0.3); }
  50%     { box-shadow:0 2px 20px rgba(255,45,120,0.5); }
}

/* --- Header (site name + benefits) --- */
.pb-oripa-fcard__header { padding:1.2rem 1.2rem 0.8rem; }
.pb-oripa-fcard__site-name {
  font-size:1.1rem; font-weight:900; color:var(--navy-dark); margin-bottom:0.6rem;
  display:flex; align-items:center; gap:0.4rem;
}
.pb-oripa-fcard__benefits { margin:0; padding:0; list-style:none; }
.pb-oripa-fcard__benefit {
  display:flex; align-items:flex-start; gap:0.4rem;
  font-size:0.78rem; color:var(--text-sub); line-height:1.55; margin-bottom:0.3rem;
}
.pb-oripa-fcard__benefit-check {
  flex-shrink:0; width:16px; height:16px; margin-top:2px;
  color:var(--green); font-weight:900;
}
.pb-oripa-fcard__benefit strong { color:var(--navy-dark); font-weight:700; }
.pb-oripa-fcard__benefit em {
  font-style:normal; color:var(--hot); font-weight:800;
}

/* --- Gacha visual banner --- */
.pb-oripa-fcard__gacha {
  position:relative; height:160px; margin:0 1rem; border-radius:var(--radius);
  overflow:hidden;
}
.pb-oripa-fcard__gacha-bg {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
}
/* Gacha banner image (replaces gradient bg) */
.pb-oripa-fcard__gacha-img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  z-index:0;
}

.pb-oripa-fcard__gacha-bg--navy {
  background:linear-gradient(135deg,#0f1b5e 0%,#1a3a8f 30%,#22d3ee 70%,#4a6cf7 100%);
}
.pb-oripa-fcard__gacha-bg--gold {
  background:linear-gradient(135deg,#1c2355 0%,#c4a24d 40%,#fbbf24 70%,#ff6b35 100%);
}
.pb-oripa-fcard__gacha-bg--purple {
  background:linear-gradient(135deg,#1c2355 0%,#7c3aed 40%,#f43f5e 70%,#fbbf24 100%);
}
/* Shimmer effect */
.pb-oripa-fcard__gacha::after {
  content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%;
  background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,0.07) 45%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.07) 55%,transparent 60%);
  animation:gacha-shimmer 3s infinite;
  pointer-events:none; z-index:1;
}
@keyframes gacha-shimmer {
  0%   { transform:translateX(-100%) translateY(-100%); }
  100% { transform:translateX(100%) translateY(100%); }
}
/* Sparkle particles */
.pb-oripa-fcard__gacha::before {
  content:''; position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 15% 25%, rgba(255,255,255,0.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 45% 60%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 70% 20%, rgba(255,255,255,0.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 85% 75%, rgba(255,255,255,0.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 85%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(2px 2px at 55% 40%, rgba(251,191,36,0.6) 0%, transparent 100%);
  animation:sparkle-twinkle 4s ease-in-out infinite alternate;
}
@keyframes sparkle-twinkle {
  0%   { opacity:0.5; }
  50%  { opacity:1; }
  100% { opacity:0.6; }
}
.pb-oripa-fcard__gacha-text {
  position:relative; z-index:3; text-align:center; color:#fff;
}
.pb-oripa-fcard__gacha-label {
  font-size:0.5rem; letter-spacing:0.2em; color:rgba(255,255,255,0.6);
  text-transform:uppercase; display:block; margin-bottom:0.2rem;
}
.pb-oripa-fcard__gacha-name {
  font-size:1.5rem; font-weight:900; letter-spacing:0.08em;
  text-shadow:0 0 20px rgba(255,255,255,0.3), 0 2px 10px rgba(0,0,0,0.5);
  line-height:1.2;
}
/* Inner border deco */
.pb-oripa-fcard__gacha-border {
  position:absolute; inset:5px; border:1px solid rgba(255,255,255,0.15);
  border-radius:7px; pointer-events:none; z-index:2;
}
/* Urgency ribbon */
.pb-oripa-fcard__urgency-ribbon {
  position:absolute; bottom:8px; right:8px; z-index:3;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
  padding:0.2rem 0.6rem; border-radius:var(--radius-sm);
  font-size:0.6rem; font-weight:700; color:#fff;
  display:flex; align-items:center; gap:0.3rem;
}
.pb-oripa-fcard__urgency-dot {
  width:6px; height:6px; border-radius:50%;
  animation:pulse-dot 1.5s infinite;
}
.pb-oripa-fcard__urgency-dot--hot { background:#f43f5e; box-shadow:0 0 6px rgba(244,63,94,0.6); }
.pb-oripa-fcard__urgency-dot--live { background:#4ade80; box-shadow:0 0 6px rgba(74,222,128,0.6); }
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%     { opacity:0.5; transform:scale(0.8); }
}

/* --- Spec grid --- */
.pb-oripa-fcard__specs {
  display:grid; grid-template-columns:auto 1fr; gap:0; margin:0;
  padding:0 1.2rem; font-size:0.78rem;
}
.pb-oripa-fcard__spec-label {
  padding:0.45rem 0.8rem 0.45rem 0; font-weight:600; color:var(--text-muted);
  border-bottom:1px solid var(--border-light); white-space:nowrap;
}
.pb-oripa-fcard__spec-value {
  padding:0.45rem 0; font-weight:700; color:var(--navy-dark);
  border-bottom:1px solid var(--border-light);
}
.pb-oripa-fcard__spec-value--hot { color:var(--hot); font-weight:800; }
.pb-oripa-fcard__spec-value--gold { color:#96790a; font-weight:800; }
.pb-oripa-fcard__specs > :nth-last-child(-n+2) { border-bottom:none; }

/* --- Promo callout --- */
.pb-oripa-fcard__promo {
  text-align:center; padding:0.5rem 1.2rem 0;
  font-size:0.72rem; font-weight:700; color:var(--navy);
}
.pb-oripa-fcard__promo::before { content:'\＼ '; color:var(--gold); }
.pb-oripa-fcard__promo::after  { content:' ／'; color:var(--gold); }
.pb-oripa-fcard__promo em { font-style:normal; color:var(--hot); }

/* --- CTA Button --- */
.pb-oripa-fcard__cta {
  display:block; margin:0.7rem 1rem 1.2rem; padding:0.85rem 1rem;
  text-align:center; font-size:0.92rem; font-weight:800;
  color:#fff; border-radius:var(--radius-sm); text-decoration:none;
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  box-shadow:0 4px 14px rgba(22,163,74,0.35);
  transition:all 0.25s ease;
  letter-spacing:0.03em;
}
.pb-oripa-fcard__cta:hover {
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(22,163,74,0.45);
  color:#fff;
}
/* Shine sweep animation on CTA */
.pb-oripa-fcard__cta::after {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);
  transition:none; animation:cta-shine 3s infinite;
}
@keyframes cta-shine {
  0%   { left:-100%; }
  30%  { left:150%; }
  100% { left:150%; }
}

/* Gold CTA variant for pick card */
.pb-oripa-fcard--pick .pb-oripa-fcard__cta {
  background:linear-gradient(135deg,#f59e0b,#d97706);
  box-shadow:0 4px 14px rgba(217,119,6,0.35);
}
.pb-oripa-fcard--pick .pb-oripa-fcard__cta:hover {
  box-shadow:0 6px 24px rgba(217,119,6,0.45);
}

/* Tags (shared) */
.pb-oripa-tag {
  font-size:0.62rem; font-weight:600; padding:0.15rem 0.55rem;
  border-radius:var(--radius-pill); border:1px solid var(--border); color:var(--text-sub); background:var(--bg-alt);
}
.pb-oripa-tag--gold   { color:#96790a; border-color:var(--gold-border); background:var(--gold-bg); }
.pb-oripa-tag--cyan   { color:#0b7fad; border-color:rgba(14,165,233,0.25); background:rgba(14,165,233,0.06); }
.pb-oripa-tag--green  { color:#15803d; border-color:rgba(34,167,96,0.25); background:rgba(34,167,96,0.06); }
.pb-oripa-tag--purple { color:#6d28d9; border-color:rgba(124,92,191,0.25); background:rgba(124,92,191,0.06); }

/* Responsive overrides */
@media (max-width:768px) {
  .pb-oripa-featured__grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
}
@media (max-width:480px) {
  .pb-oripa-fcard__gacha { height:130px; }
  .pb-oripa-fcard__gacha-name { font-size:1.2rem; }
}


/* ============================================
   SAFETY CHECKLIST
   ============================================ */
.pb-oripa-safety__grid { display:grid; grid-template-columns:repeat(6,1fr); gap:0.9rem; margin-bottom:1.2rem; }
.pb-oripa-safety-item {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:1.2rem 0.8rem; text-align:center; transition:all var(--transition); position:relative;
}
.pb-oripa-safety-item:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.pb-oripa-safety-item::before, .pb-oripa-safety-item::after {
  content:''; position:absolute; width:14px; height:14px; border-color:var(--gold-light); border-style:solid; border-width:0;
}
.pb-oripa-safety-item::before { top:5px; left:5px; border-top-width:1.5px; border-left-width:1.5px; border-radius:3px 0 0 0; }
.pb-oripa-safety-item::after  { bottom:5px; right:5px; border-bottom-width:1.5px; border-right-width:1.5px; border-radius:0 0 3px 0; }
.pb-oripa-safety-item__icon { width:38px; height:38px; margin:0 auto 0.6rem; display:flex; align-items:center; justify-content:center; color:var(--navy); }
.pb-oripa-safety-item__icon svg { width:28px; height:28px; }
.pb-oripa-safety-item__name { font-size:0.75rem; font-weight:700; color:var(--navy-dark); margin-bottom:0.3rem; }
.pb-oripa-safety-item__desc { font-size:0.62rem; color:var(--text-muted); line-height:1.5; }
.pb-oripa-safety__note { text-align:center; font-size:0.72rem; color:var(--text-muted); padding-top:0.3rem; }

/* ============================================
   SPEC TABLE — オンラインオリパ比較表（射幸心版）
   ============================================ */
.pb-oripa-spec {
  position: relative;
  overflow: hidden;
}
/* Section heading override */
.pb-oripa-spec .pb-oripa-section-heading__title {
  font-size: 1.25rem;
}

/* Comparison table wrapper */
.pb-oripa-spec__wrap {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 2px solid var(--navy);
  box-shadow: 0 4px 20px rgba(42,51,112,0.12);
}
.pb-oripa-spec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
  border: none;
  border-radius: 0;
  overflow: visible;
}
/* Gradient header */
.pb-oripa-spec-table thead th {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-light) 100%);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.85rem 0.9rem;
  text-align: center;
  white-space: nowrap;
  letter-spacing: 0.03em;
  border-bottom: 2px solid var(--gold);
  position: relative;
}
.pb-oripa-spec-table thead th:first-child { text-align: center; width: 50px; }
.pb-oripa-spec-table thead th:nth-child(2) { text-align: left; }

/* Body rows */
.pb-oripa-spec-table tbody tr {
  transition: all 0.2s ease;
  border-bottom: 1px solid var(--border-light);
}
.pb-oripa-spec-table tbody tr:last-child { border-bottom: none; }
.pb-oripa-spec-table tbody tr:hover {
  background: linear-gradient(90deg, rgba(42,51,112,0.03), rgba(196,162,77,0.04));
}
.pb-oripa-spec-table tbody td {
  padding: 0.9rem 0.9rem;
  vertical-align: middle;
  text-align: center;
}
.pb-oripa-spec-table tbody td:nth-child(2) { text-align: left; }

/* Rank 1 row - gold highlight */
.pb-oripa-spec-row--1 {
  background: linear-gradient(90deg, rgba(251,191,36,0.08), rgba(196,162,77,0.04), transparent 80%);
}
.pb-oripa-spec-row--1:hover {
  background: linear-gradient(90deg, rgba(251,191,36,0.14), rgba(196,162,77,0.06), transparent 80%) !important;
}
/* Rank 2 row */
.pb-oripa-spec-row--2 {
  background: linear-gradient(90deg, rgba(192,192,192,0.06), transparent 60%);
}
/* Rank 3 row */
.pb-oripa-spec-row--3 {
  background: linear-gradient(90deg, rgba(205,127,50,0.05), transparent 60%);
}

/* Rank cell */
.pb-oripa-spec__rank {
  font-size: 1.5rem;
  line-height: 1;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.15));
}

/* Site name cell */
.pb-oripa-spec__site {
  font-weight: 800 !important;
  color: var(--navy-dark) !important;
  font-size: 0.88rem !important;
  text-align: left !important;
  white-space: nowrap;
}
.pb-oripa-spec__site-sub {
  display: block;
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--text-muted);
  margin-top: 0.1rem;
}

/* Bonus cell - highlighted */
.pb-oripa-spec__bonus-cell {
  font-weight: 700;
  color: var(--navy);
}
.pb-oripa-spec__bonus-highlight {
  display: inline-block;
  background: linear-gradient(135deg, #fff7ed, #fef3c7);
  color: #92400e;
  font-weight: 800;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(251,191,36,0.3);
  font-size: 0.73rem;
}

/* 還元率 cell */
.pb-oripa-spec__rate {
  font-weight: 900 !important;
  font-size: 0.92rem !important;
}
.pb-oripa-spec__rate--hot {
  color: var(--hot) !important;
  text-shadow: 0 0 8px rgba(232,69,60,0.15);
}
.pb-oripa-spec__rate--gold {
  color: #92400e !important;
}
.pb-oripa-spec__rate--free {
  color: var(--green) !important;
  font-weight: 900 !important;
}

/* Feature cell */
.pb-oripa-spec__feature {
  font-size: 0.73rem !important;
  color: var(--text-sub) !important;
  text-align: left !important;
  max-width: 200px;
  line-height: 1.5;
}

/* Mini CTA in table */
.pb-oripa-spec__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.4rem 0.8rem;
  font-size: 0.68rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
  box-shadow: 0 2px 6px rgba(22,163,74,0.25);
}
.pb-oripa-spec__cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(22,163,74,0.35);
  color: #fff;
}
.pb-oripa-spec-row--1 .pb-oripa-spec__cta {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  box-shadow: 0 2px 6px rgba(217,119,6,0.25);
}
.pb-oripa-spec-row--1 .pb-oripa-spec__cta:hover {
  box-shadow: 0 4px 12px rgba(217,119,6,0.35);
}

/* Note area */
.pb-oripa-spec-table__note {
  display: flex;
  justify-content: space-between;
  margin-top: 0.8rem;
  font-size: 0.65rem;
  color: var(--text-muted);
}

/* Responsive */
@media (max-width: 768px) {
  .pb-oripa-spec-table__note { flex-direction: column; gap: 0.2rem; }
  .pb-oripa-spec__feature { max-width: 150px; }
}


/* ============================================
   ARTICLES
   ============================================ */
.pb-oripa-articles__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.pb-oripa-acard {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; transition:all 0.28s; cursor:pointer; text-decoration:none; display:block;
}
.pb-oripa-acard:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }
.pb-oripa-acard__thumb { height:135px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.pb-oripa-acard__thumb-bg { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.pb-oripa-acard__thumb-bg svg { width:44px; height:44px; opacity:0.2; }
.pb-oripa-acard__thumb-bg--beginner { background:linear-gradient(135deg,#dbeafe 0%,#1c2355 100%); color:#fff; }
.pb-oripa-acard__thumb-bg--feature  { background:linear-gradient(135deg,#fef3c7 0%,#1c2355 100%); color:#fff; }
.pb-oripa-acard__thumb-bg--premium  { background:linear-gradient(135deg,#ede9fe 0%,#1c2355 100%); color:#fff; }
.pb-oripa-acard__thumb-bg--compare  { background:linear-gradient(135deg,#dcfce7 0%,#1c2355 100%); color:#fff; }
.pb-oripa-acard__thumb-text { position:relative; z-index:1; font-size:1.3rem; font-weight:900; color:#fff; letter-spacing:0.06em; text-shadow:0 2px 10px rgba(0,0,0,0.3); text-align:center; line-height:1.2; }
.pb-oripa-acard__label { position:absolute; top:8px; left:8px; font-size:0.58rem; font-weight:700; padding:0.18rem 0.55rem; border-radius:var(--radius-sm); z-index:2; }
.pb-oripa-acard__label--beginner { background:var(--cyan); color:#fff; }
.pb-oripa-acard__label--feature  { background:var(--amber); color:#fff; }
.pb-oripa-acard__label--premium  { background:var(--purple); color:#fff; }
.pb-oripa-acard__label--compare  { background:var(--green); color:#fff; }
.pb-oripa-acard__date { position:absolute; top:8px; right:8px; font-size:0.6rem; color:rgba(255,255,255,0.65); font-family:'Inter',sans-serif; font-weight:500; z-index:2; }
.pb-oripa-acard__body { padding:0.9rem 1rem 1.1rem; }
.pb-oripa-acard__title { font-size:0.82rem; font-weight:700; line-height:1.5; color:var(--navy-dark); margin-bottom:0.3rem; }
.pb-oripa-acard__excerpt { font-size:0.7rem; color:var(--text-muted); line-height:1.6; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pb-oripa-acard__link { display:block; text-decoration:none; color:inherit; }
.pb-oripa-acard__link:hover { color:inherit; }
.pb-oripa-acard__thumb-img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }

/* ============================================
   CTA BANNER
   ============================================ */
.pb-oripa-cta-banner { padding:3rem 0; }
.pb-oripa-cta-banner__inner {
  background:var(--navy); border-radius:var(--radius-lg); padding:2.5rem 3rem;
  display:flex; align-items:center; gap:2.5rem; position:relative; overflow:hidden;
}
.pb-oripa-cta-banner__inner::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,transparent 50%,rgba(196,162,77,0.08) 100%); pointer-events:none;
}
.pb-oripa-cta-banner__text { flex:1; position:relative; z-index:1; }
.pb-oripa-cta-banner__title { font-size:1.35rem; font-weight:900; color:#fff; margin-bottom:0.6rem; line-height:1.4; }
.pb-oripa-cta-banner__desc { font-size:0.78rem; color:rgba(255,255,255,0.65); line-height:1.7; }
.pb-oripa-cta-banner__features { display:flex; gap:2rem; position:relative; z-index:1; }
.pb-oripa-cta-feature { text-align:center; }
.pb-oripa-cta-feature__icon {
  width:44px; height:44px; margin:0 auto 0.5rem; background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--gold-light);
}
.pb-oripa-cta-feature__icon svg { width:20px; height:20px; }
.pb-oripa-cta-feature__name { font-size:0.72rem; font-weight:700; color:#fff; }
.pb-oripa-cta-feature__desc { font-size:0.6rem; color:rgba(255,255,255,0.5); margin-top:0.1rem; }
.pb-oripa-cta-banner__action { flex-shrink:0; position:relative; z-index:1; }

/* ============================================
   ARTICLES LISTING PAGE
   ============================================ */

/* Compact Hero */
.pb-oripa-hero--compact {
  padding:2rem 0 1.8rem;
}
.pb-oripa-hero--compact .pb-oripa-hero__title {
  font-size:clamp(1.4rem,2.8vw,1.8rem);
  margin-bottom:0.5rem;
}
.pb-oripa-hero--compact .pb-oripa-hero__desc {
  margin-bottom:0;
  font-size:0.82rem;
}

/* Breadcrumb */
.pb-oripa-articles__breadcrumb {
  font-size:0.75rem;
  color:var(--text-muted);
  margin-bottom:1rem;
}
.pb-oripa-articles__breadcrumb a {
  color:var(--text-muted);
  text-decoration:none;
  transition:color 0.22s ease;
}
.pb-oripa-articles__breadcrumb a:hover {
  color:var(--navy);
}
.pb-oripa-articles__breadcrumb-sep {
  margin:0 0.4rem;
  opacity:0.4;
}

/* Pagination */
.pb-oripa-pagination {
  display:flex;
  justify-content:center;
  gap:0.4rem;
  margin-top:2.5rem;
  padding-bottom:1rem;
  flex-wrap:wrap;
}
.pb-oripa-pagination .page-numbers {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38px;
  height:38px;
  padding:0 0.5rem;
  border-radius:var(--radius-sm);
  font-size:0.85rem;
  font-weight:600;
  color:var(--navy);
  background:#fff;
  border:1px solid var(--border);
  text-decoration:none;
  transition:all 0.22s ease;
}
.pb-oripa-pagination .page-numbers.current {
  background:var(--navy);
  color:#fff;
  border-color:var(--navy);
}
.pb-oripa-pagination .page-numbers:hover:not(.current):not(.dots) {
  background:var(--navy-pale);
  border-color:var(--navy);
}
.pb-oripa-pagination .page-numbers.dots {
  border:none;
  background:none;
  cursor:default;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:1024px) {
  .pb-oripa-hero__trust { width:160px; top:0; }
  .pb-oripa-hero__visual { flex:0 0 300px; height:280px; }
  .pb-oripa-safety__grid { grid-template-columns:repeat(3,1fr); }
  .pb-oripa-articles__grid { grid-template-columns:repeat(2,1fr); }
  .pb-oripa-cta-banner__inner { flex-direction:column; text-align:center; padding:2rem; }
  .pb-oripa-cta-banner__features { justify-content:center; }
}
@media (max-width:768px) {
  .pb-oripa-hero { padding:2.5rem 0 2rem; }
  .pb-oripa-hero__inner { flex-direction:column; text-align:center; gap:1.5rem; }
  .pb-oripa-hero__trust {
    position:static;
    width:130px;
    margin:0 auto;
    order:-1;
    opacity:0.85;
  }
  .pb-oripa-hero__visual { display:none; }
  .pb-oripa-hero__ctas { justify-content:center; }
  .pb-oripa-hero__desc br { display:none; }
  .pb-oripa-featured__grid { grid-template-columns:1fr; }
  .pb-oripa-safety__grid { grid-template-columns:repeat(2,1fr); }
  .pb-oripa-articles__grid { grid-template-columns:1fr; }
  .pb-oripa-cta-banner__features { flex-direction:column; gap:1rem; }
  .pb-oripa-spec-table__note { flex-direction:column; gap:0.2rem; }
  .pb-oripa-filters__list { justify-content:flex-start; }
}
@media (max-width:480px) {
  .pb-oripa-hero { padding:2rem 0 1.5rem; }
  .pb-oripa-hero__trust { width:110px; }
  .pb-oripa-hero__title { font-size:1.5rem; }
  .pb-oripa-hero__desc { font-size:0.8rem; margin-bottom:1.2rem; }
  .pb-oripa-hero__ctas { gap:0.6rem; }
  .pb-oripa-hero__ctas .pb-oripa-btn { font-size:0.78rem; padding:0.65rem 1.2rem; }
  .pb-oripa-safety__grid { grid-template-columns:repeat(2,1fr); }
}
