/*
Theme Name: nexpro
Description: nexproテーマ
Version: 1.0
Author: anzu_02
*/
/* ============================================================
   White 70% / Black 20% / Purple 10%
   Purple: #8B5CF6 (aespa supernova violet)
   ============================================================ */

:root {
  --white:        #ffffff;
  --off-white:    #f8f7fc;
  --gray-50:      #f3f2f8;
  --gray-100:     #e8e5f4;
  --gray-200:     #cdc9e0;
  --gray-400:     #9990b8;
  --dark-2:       #252239;

  --purple-light: #a78bfa;
  --purple-pale:  #ede9fe;
  --purple-dark:  #6d28d9;
  --purple-glow:  rgba(139,92,246,0.22);
  --purple-border:rgba(139,92,246,0.25);

  --green:        #10b981;
  --gold:         #f59e0b;
  --red:          #ef4444;

  --font:         'Noto Sans JP','Zen Kaku Gothic New',sans-serif;
  --font-disp:    'Bebas Neue',sans-serif;

  --r-lg: 20px; --r-xl: 28px;
  --sh-sm: 0 2px 8px rgba(17,15,30,0.07);
  --sh-md: 0 8px 32px rgba(17,15,30,0.11);
  --sh-lg: 0 20px 60px rgba(17,15,30,0.16);
  --sh-pur: 0 6px 28px rgba(139,92,246,0.28);
  --t: 0.24s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--white);color:#110f1e;line-height:1.75;overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}
button,select,input,textarea{font-family:var(--font);cursor:pointer}

.container{
  max-width:1160px;
  margin:0 auto;
  padding:0 24px;
}

/* ============================================================ HEADER */
#site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--gray-100);
  transition:box-shadow var(--t);
}
#site-header.scrolled{box-shadow:var(--sh-md)}
.header-inner{
  padding:0 40px;
  height:66px;
  display:flex;
  align-items:center;
  gap:20px;
}
.logo{
  display:flex;
  flex-direction:column;
  line-height:1;
  flex-shrink:0;
  gap:2px;
}
.logo-mark{
  font-family:var(--font-disp);
  font-size:26px;
  letter-spacing:2px;
  color:#110f1e;
}
.logo-tagline{
  font-size:9px;
  color:var(--gray-400);
  letter-spacing:.1em;
}
.footer-logo 
.logo-mark{
  font-size:22px;
  color:var(--white);
}
.footer-logo 
.logo-tagline{
  color:var(--gray-400);
}

.global-nav{
  flex:1;
  display:flex;
  justify-content: flex-end;
}
.global-nav a{
  padding:8px 10px;
  font-size:13.5px;
  font-weight:700;
  color:#5c5575;
  border-radius:6px;
  transition:color var(--t),background var(--t);
}
.global-nav a:hover{
  color:#8B5CF6;
  background:var(--purple-pale);
}

.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-line-sm{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;background:#06c755;color:var(--white);
  font-size:13px;font-weight:700;border-radius:6px;
  transition:opacity var(--t),transform var(--t);
}
.btn-line-sm:hover{opacity:.88;transform:translateY(-1px)}
.line-icon{display:inline-block;background:var(--white);color:#06c755;font-size:9px;font-weight:900;padding:1px 4px;border-radius:3px;letter-spacing:.04em}
.btn-post-sm{
  padding:8px 16px;background:#110f1e;color:var(--white);
  font-size:13px;font-weight:700;border-radius:6px;
  transition:background var(--t),transform var(--t);
}
.btn-post-sm:hover,.btn-post-sm.active-btn{background:#8B5CF6;transform:translateY(-1px)}

.hamburger{
  display:flex;
  position: relative;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:4px;
  margin-left:auto;
  z-index: 1000;
}
.hamburger span{display:block;width:24px;height:2px;background:#110f1e;border-radius:2px;transition:var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{
  position: fixed;
  top: 0;
  right: -100%; /* 右側に隠す */
  width: 100%;
  height: 100vh;
  background: #fff;
  transition: right 0.4s ease; /* スライドのアニメーション */
  z-index: 999;
  padding-top: 80px; /* ボタンと重ならないように */
  display: flex;
  flex-direction: column;
}
.mobile-nav.is-active {
    right: 0; /* 画面内に現れる */
}
.mobile-nav.open{
  max-height:500px;
}
.mobile-nav a{
  display:block;
  padding:14px 24px;
  font-size:15px;
  font-weight:700;
  border-bottom:1px solid var(--gray-50);
}
.mobile-nav .mobile-line{
  color:#06c755;
}
.mobile-nav .mobile-post{
  color:#8B5CF6;
}
body.noscroll {
    overflow: hidden;
}

/* ============================================================ HERO */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  align-items:center;
  padding:120px 0 80px;
  overflow:hidden;
  background:var(--white);
}
.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.hero-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
}
.hero-text {
  display: flex;
}
.o1{
  width:560px;
  height:560px;
  background:radial-gradient(circle,rgba(139,92,246,.15) 0,transparent 70%);
  top:-140px;
  right:-80px;
}
.o2{
  width:320px;
  height:320px;
  background:radial-gradient(circle,rgba(167,139,250,.12) 0,transparent 70%);
  bottom:-60px;
  left:8%;
}
.o3{width:180px;height:180px;background:radial-gradient(circle,rgba(139,92,246,.1) 0,transparent 70%);top:40%;right:30%}
.hero-dots{
  position:absolute;inset:0;
  background-image:radial-gradient(var(--gray-200) 1px,transparent 1px);
  background-size:28px 28px;opacity:.45;
}

.hero-badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:30px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--purple-pale);color:var(--purple-dark);
  font-size:12px;font-weight:700;padding:5px 13px;
  border-radius:999px;border:1px solid var(--purple-border);
}
.hero-badge.pulse{animation:badge-pulse 2.4s ease-in-out infinite}
@keyframes badge-pulse{0%,100%{box-shadow:0 0 0 0 var(--purple-glow)}50%{box-shadow:0 0 0 7px transparent}}

.hero-headline{
  font-size:clamp(36px,5.5vw,68px);
  font-weight:900;
  line-height: 1.5;
  letter-spacing:-.02em;
  margin-right:80px;
}
.hero-detail {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hero-headline em{font-style:normal;color:#8B5CF6}
.headline-accent{
  display:inline-block;
  background:linear-gradient(135deg,#8B5CF6 0%,var(--purple-light) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-checks{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:32px;
}
.sp-br {
  display: none;
}
.hero-checks li{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:15px;
  font-weight:700;
  color:#5c5575;
}
.chk{
  width:22px;
  height:22px;
  background:#8B5CF6;
  color:white;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  flex-shrink:0;
}

.hero-cta-group{
  display:flex;
  gap:10px;
  white-space: nowrap;
  width: 100%;
}
.btn-hero-primary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:17px 30px;
  margin-bottom:15px;
  background:#110f1e;color:var(--white);
  font-size:15px;
  font-weight:700;
  border-radius:6px;
  border:2px solid #110f1e;
  transition:background var(--t),border-color var(--t),transform var(--t),box-shadow var(--t);
}
.btn-hero-primary:hover{background:#8B5CF6;border-color:#8B5CF6;transform:translateY(-2px);box-shadow:var(--sh-pur)}
.btn-hero-ghost{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 26px;
  background:transparent;
  color:#110f1e;
  font-size:15px;
  font-weight:700;
  border-radius:6px;
  border:2px solid var(--gray-200);
  transition:border-color var(--t),color var(--t),transform var(--t);
}
.btn-hero-ghost:hover{
  border-color:#8B5CF6;
  color:#8B5CF6;
  transform:translateY(-2px);
}

.line-cta{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:#06c755;
  color:var(--white);
  padding:10px 22px;
  border-radius: 6px;
  transition:opacity var(--t),transform var(--t),box-shadow var(--t);
  box-shadow:0 4px 20px rgba(6,199,85,.28);
}
.line-cta:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 28px rgba(6,199,85,.35)}
.line-icon-lg{background:var(--white);color:#06c755;font-weight:900;font-size:12px;padding:4px 7px;border-radius:5px;letter-spacing:.05em}
.line-text-block{display:flex;flex-direction:column;gap:1px}
.line-label{font-size:11px;opacity:.85}
.line-cta strong{font-size:14px}

/* Hero Card Stack */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-card-stack{position:relative;width:100%;max-width:360px}
.hcard{
  background:var(--white);
  border-radius:12px;
  border:1.5px solid var(--gray-100);padding:18px 20px;
  box-shadow:var(--sh-md);position:relative;
  transition:transform var(--t);
}

@keyframes scrl{0%,100%{opacity:1}50%{opacity:.3}}

/* ============================================================ CLIENTS */
.clients{
  padding:20px 0;background:var(--gray-50);
  border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);
  display:flex;align-items:center;gap:0;overflow:hidden;
}
.clients-label{flex-shrink:0;padding:0 24px;font-size:11px;font-weight:900;color:var(--gray-400);letter-spacing:.1em;white-space:nowrap}
.clients-track-wrap{flex:1;overflow:hidden}
.clients-track{display:flex;overflow:hidden}
.cl-logos{
  display:flex;
  align-items:center;
  gap:0;animation:logos 28s linear infinite;
  white-space:nowrap;
}
.cl-logo{
  padding:0 28px;
  font-size:13px;
  font-weight:700;
  color:var(--gray-400);
  border-right:1px solid var(--gray-200);
  flex-shrink:0;
}
.carry {
  filter: brightness(0);
}
.fecility {
  filter: brightness(0);
}
.inc321 {
  filter: brightness(0);
}
.influencer {
  filter: brightness(0);
}
.thecoo {
  filter: brightness(0);
}
@keyframes logos{
  0%{
    transform:translateX(0)
  }
  100%{
    transform:translateX(-50%)
  }
}

/* ============================================================ SECTION COMMON */
section{padding:84px 0}
.section-header{margin-bottom:44px}
.section-header.split{display:flex;justify-content:space-between;align-items:flex-end}
.section-header.center{text-align:center}
.section-label{font-size:11px;font-weight:900;letter-spacing:.2em;color:#8B5CF6;margin-bottom:6px}
.white-label{color:var(--purple-light)}
.earn-label{color:var(--gold)}
.white-title{color:var(--white)}
.title-sub{font-size:.55em;font-weight:400;color:var(--gray-400)}
.section-sub{margin-top:12px;font-size:14px;color:var(--gray-400);line-height:1.8}
.link-more{font-size:13px;font-weight:700;color:#8B5CF6;white-space:nowrap;margin-bottom:2px;transition:opacity var(--t)}
.link-more:hover{opacity:.7}
.earn-more{color:var(--gold)}

/* ============================================================ TAG SEARCH */
.tag-search{
  background:#110f1e;
  padding:56px 0;
}
.tag-search-header{
  text-align:center;
  margin-bottom:36px;
}
.tag-search-title{
  font-size:clamp(20px,2.8vw,28px);
  font-weight:900;color:var(--white);
  margin-bottom:6px;
}
.tag-search-sub{
  font-size:14px;
  color:var(--gray-400);
}
.tag-groups{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.tg-label{
  font-size:11px;
  font-weight:900;
  letter-spacing:.1em;
  color:var(--gray-400);
  margin-bottom:12px;
}
.tg-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.tag-pill{
  display:inline-block;
  padding:7px 15px;
  background:rgba(255,255,255,.07);
  color:var(--white);
  font-size:13px;
  font-weight:700;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  transition:background var(--t),border-color var(--t),transform var(--t);
}
.tag-pill:hover{
  background:#8B5CF6;
  border-color:#8B5CF6;
  transform:translateY(-1px);
}

.tag-audition {
  display: flex;
  color: white;
}

/* ============================================================ PICK UP BANNERS */
.pickup-banners{background:var(--off-white)}
.banner-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.banner-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  padding:40px 28px;display:flex;flex-direction:column;
  min-height:220px;transition:transform var(--t),box-shadow var(--t);
}
.banner-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.banner-bg-text{
  position:absolute;top:-10px;right:-10px;
  font-family:var(--font-disp);font-size:90px;letter-spacing:.05em;
  opacity:.07;line-height:1;pointer-events:none;color:var(--white);
}
.banner-inner{position:relative;z-index:1}
.banner-flag{font-size:36px;margin-bottom:12px;display:block}
.banner-title{font-size:22px;font-weight:900;color:var(--white);margin-bottom:8px}
.banner-desc{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:16px;line-height:1.7}
.banner-link{font-size:13px;font-weight:700;color:var(--white);opacity:.85}

.banner-korea{background:linear-gradient(135deg,#4c1d95 0%,#7c3aed 50%,#8B5CF6 100%)}
.banner-highpay{background:linear-gradient(135deg,#111018 0%,#2a2738 60%,#3d2c6b 100%)}
.banner-novice{background:linear-gradient(135deg,#065f46 0%,#047857 60%,#10b981 100%)}

/* ============================================================ POPULAR / SCROLL CARDS */
.popular{
  background:var(--white);
  padding-bottom:0;
}
.scroll-cards-outer{
  position:relative;
  margin-top:28px;
  padding-bottom:84px;
}
.scroll-cards{
  display:flex;
  flex-wrap: nowrap;
  gap:20px;
  overflow-x:auto;
  padding:8px 24px 16px;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  max-width:100%;
}
.scroll-cards::-webkit-scrollbar{
  display:none;
}

.audi-card{
  flex:0 0 335px;
  display: inline-block;
  background:var(--white);
  border:1.5px solid var(--gray-100);
  border-radius:12px;
  overflow:hidden;
  scroll-snap-align:start;
  transition:box-shadow var(--t),transform var(--t),border-color var(--t);
  height: fit-content;
  min-height: 383px;
  position: relative;
}
.audi-card:hover{
  box-shadow:var(--sh-md);
  transform:translateY(-4px);
  border-color:var(--gray-200);
}
.stretched-link::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1; /* カード全体を覆う */
}
.ac-img{
  height:180px;
  width: 100%;
  position:relative;
  overflow:hidden;
}
.ac-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.ac-badge{
  position:absolute;
  top:10px;
  right:10px;
  font-size:10px;
  font-weight:700;
  padding:3px 9px;
  border-radius:999px;
  color:var(--white);
}
.badge-hot{
  background:#e11d48;
}
.badge-new{
  background:var(--green);
}
.ac-img-purple{background:linear-gradient(135deg,#c4b5fd,#7c3aed)}

.ac-body{
  padding:16px;
}
.ac-tags{
  display:flex;
  gap:6px;
  margin-bottom:8px;
  flex-wrap:wrap;
}
.ac-title{
  font-size:18px;
  font-weight:700;
  color:#110f1e;
  line-height:1.4;
  margin-bottom:10px;
}
.ac-sub {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ac-icon {
  width: 14px;
  height: 14px;
}
.ac-company{
  font-size:12px;
}
.ac-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top: 8px;
}
.ac-dl{
  font-size:12px;
  background-color: #5b21b6;
  border-radius: 15px;
  padding: 3px 15px;
  color: white;
}
.ac-dl em {
  font-weight: 700;
  font-style: normal;
}
.ac-btn{
  font-size:12px;
  font-weight:700;
  color:#8B5CF6;
  transition:opacity var(--t);
}
.ac-btn:hover{
  opacity:.7;
}


.scroll-nav{position:absolute;bottom:24px;right:24px;display:flex;gap:8px}
.snav-btn{
  width:40px;height:40px;border-radius:50%;background:#110f1e;color:var(--white);
  border:none;font-size:20px;display:flex;align-items:center;justify-content:center;
  transition:background var(--t),transform var(--t);
}
.snav-btn:hover{background:#8B5CF6;transform:scale(1.08)}

/* Tags */
.tag{
  font-size:11px;
  font-weight:700;
  padding:3px 9px;
  border-radius:999px;
  letter-spacing:.04em;
  white-space:nowrap;
}
.tag.tag-kpop{
  background:#ede9fe;
  color:#5b21b6;
}
.tag.tag-novice{background:#d1fae5;color:#065f46}
.tag.tag-online{background:#dbeafe;color:#1e40af}
.tag.tag-actor {
    background: #dbeafe;
    color: #1e40af;
}

.tag.tag-model { background: #d1fae5; color: #065f46; }
.tag.tag-inexperienced { background: #ede9fe; color: #5b21b6; }
.tag.tag-influencer { background: #fef9c3; color: #713f12; }
.tag.tag-new { background: #8B5CF6; color: var(--white); }
.tag.tag-high-income { background: #fee2e2; color: #991b1b; }
.tag.auto-color-0 { background: #f3f4f6; color: #4b5563; }
.tag.auto-color-1 { background: #fff7ed; color: #c2410c; }
.tag.auto-color-2 { background: #f0fdf4; color: #15803d; }
.tag.auto-color-3 { background: #eff6ff; color: #1d4ed8; }
.tag.auto-color-4 { background: #fdf2f8; color: #be185d; }

/* ============================================================ CATEGORY NAV */
.cat-nav{
  background:var(--off-white);
}
.cat-nav-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.cnav-card{
  background:var(--white);
  border:1.5px solid var(--gray-100);
  border-radius:12px;
  padding:24px 20px;
  display:grid;
  grid-template-columns:1fr auto;
  grid-template-rows:auto auto;
  gap:4px 0;
  align-items:center;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.cnav-card:hover{
  border-color:#8B5CF6;
  box-shadow:var(--sh-pur);
  transform:translateY(-3px);
}

.cnav-emoji{
  font-size:28px;
  grid-row:1/3;
  line-height:1;
}
.cnav-name{
  font-size:13px;
  font-weight:700;
  color:#110f1e;
  grid-column:2;
}
.cnav-count{
  font-size:11px;
  color:#8B5CF6;
  font-weight:700;
  grid-column:2;
}
.cnav-arrow{
  grid-row:1/3;
  margin-left:8px;
  font-size:16px;
  color:var(--gray-200);
  transition:color var(--t),transform var(--t);
}
.cnav-card:hover 
.cnav-arrow{
  color:#8B5CF6;
  transform:translateX(3px);
}

/* Actually let me redo cnav grid to 4-col proper */
.cat-nav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cnav-card{
  background:var(--white);border:1.5px solid var(--gray-100);
  border-radius:12px;padding:22px 18px;
  display:flex;flex-direction:column;gap:6px;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  position:relative;
}
.cnav-card:hover{border-color:#8B5CF6;box-shadow:var(--sh-pur);transform:translateY(-3px)}
.cnav-emoji{font-size:28px;line-height:1}
.cnav-name{font-size:13px;font-weight:700;color:#110f1e}
.cnav-count{font-size:11px;color:#8B5CF6;font-weight:700}
.cnav-arrow{position:absolute;bottom:18px;right:18px;font-size:16px;color:var(--gray-200);transition:color var(--t),transform var(--t)}
.cnav-card:hover .cnav-arrow{color:#8B5CF6;transform:translateX(3px)}

/* ============================================================ SERVICE */
.service{
  background:var(--off-white)l;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.sv-item{
  background:var(--white);
  border-radius:12px;
  padding:28px 22px;
  border:1.5px solid var(--gray-100);
  transition:box-shadow var(--t),transform var(--t);
}
.sv-item:hover{
  box-shadow:var(--sh-md);
  transform:translateY(-3px);
}
.sv-icon{
  font-size:32px;
  margin-bottom:14px;
  text-align: center;
}
.sv-title{
  font-size:15px;
  font-weight:700;
  color:#110f1e;
  margin-bottom:10px;
  text-align: center;
}
.sv-desc{
  font-size:13px;
  color:#5c5575;
  line-height:1.75;
}
/* ============================================================ CTA BAND */
.cta-band{
  padding:0;
}
.cta-band-bg{
  background:linear-gradient(135deg,#110f1e 0%,#2a1f5e 50%,#1a1729 100%);
  padding:50px 0;
  position:relative;
  overflow:hidden;
}
.cta-band-bg::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(139,92,246,.2) 0,transparent 65%);
}
.cta-band-inner{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:32px;
  flex-wrap:wrap;
}
.cta-band-title{
  font-size:25px;
  font-weight:900;
  color:var(--purple-light);
}

.cta-band-sub{
  font-size:30px;
  color:white;
  font-weight:700;
}
.cta-band-btns{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  flex-shrink:0;
}
.btn-line-lg{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:15px 26px;
  background:#06c755;
  color:var(--white);
  font-size:15px;
  font-weight:700;
  border-radius:6px;
  transition:opacity var(--t),transform var(--t);
}
.btn-line-lg:hover{
  opacity:.9;
  transform:translateY(-2px);
}
.line-icon-md{
  background:var(--white);
  color:#06c755;
  font-size:10px;
  font-weight:900;
  padding:2px 6px;
  border-radius:4px;
}
.btn-search-lg{
  display:inline-flex;align-items:center;
  padding:15px 26px;background:transparent;color:var(--white);
  font-size:15px;font-weight:700;border-radius:6px;
  border:2px solid rgba(255,255,255,.3);
  transition:border-color var(--t),background var(--t),transform var(--t);
}
.btn-search-lg:hover{
  border-color:var(--white);
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
}

.site-footer{
  background:#110f1e;
}
.footer-biz-bar{
  padding:20px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-biz-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.footer-biz-label{
  font-size:13px;
  color:var(--gray-400);
}
.footer-biz-btns{
  display:flex;
  gap:10px;
}
.btn-post-outline{
  padding:8px 18px;
  border:1.5px solid rgba(255,255,255,.2);
  color:var(--white);
  font-size:12px;
  font-weight:700;
  border-radius:6px;
  transition:border-color var(--t),background var(--t);
}
.btn-post-outline:hover{
  border-color:var(--purple-light);
  background:rgba(139,92,246,.15);
}
.btn-contact-outline{
  padding:8px 18px;
  border:1.5px solid rgba(255,255,255,.1);
  color:var(--gray-400);
  font-size:12px;
  font-weight:700;
  border-radius:6px;
  transition:border-color var(--t),color var(--t);
}
.btn-contact-outline:hover{
  border-color:var(--gray-400);
  color:var(--white);
}
.footer-main{
  padding:40px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  padding: 0 40px;
  gap:10px;
}
.footer-logo {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer-col h4{
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  color:var(--gray-200);
  margin-bottom:8px;
}
.footer-col ul{
  display:flex;
  flex-direction:column;
}
.footer-col ul li {
  height: 21px;
}
.footer-col ul li a{
  font-size:13px;
  color:var(--gray-400);
  transition:color var(--t);
}
.footer-col ul li a:hover{
  color:var(--purple-light);
}
.footer-bottom{
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-bottom 
.container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.copyright{
  font-size:12px;
  color:#5c5575;
}
.footer-legal{
  display:flex;
  gap:18px;
}
.footer-legal a{
  font-size:12px;
  color:#5c5575;
  transition:color var(--t);
}
.footer-legal a:hover{
  color:var(--white);
}

/* ============================================================ BACK TO TOP */
.back-top{
  position:fixed;bottom:28px;right:28px;
  width:44px;height:44px;border-radius:50%;
  background:#110f1e;color:var(--white);border:none;font-size:16px;
  box-shadow:var(--sh-md);opacity:0;pointer-events:none;
  transition:opacity var(--t),background var(--t),transform var(--t);z-index:999;
}
.back-top.visible{opacity:1;pointer-events:all}
.back-top:hover{background:#8B5CF6;transform:translateY(-2px)}

/* ============================================================ DETAIL PAGE */
.detail-page #site-header{border-bottom:1px solid var(--gray-200)}
.detail-hero{padding:48px 0;background:var(--white)}
.detail-hero-inner{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.detail-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.detail-badge-hot{background:#fef3c7;color:#b45309;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.detail-title{font-size:clamp(22px,3vw,34px);font-weight:900;line-height:1.25;margin-bottom:8px;color:#110f1e}
.detail-company{font-size:14px;color:var(--gray-400);margin-bottom:24px}
.detail-highlights{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;background:var(--gray-50);border-radius:12px;padding:20px}
.dh-item{display:flex;flex-direction:column;gap:3px}
.dh-label{font-size:11px;font-weight:700;color:var(--gray-400)}
.dh-val{font-size:14px;font-weight:700;color:#110f1e}
.dl-red{color:var(--red)}

.lp-block{border-radius:12px;padding:22px 24px;margin-bottom:20px}
.lp-green{background:#ecfdf5;border:1.5px solid #6ee7b7}
.lp-gold{background:#fffbeb;border:1.5px solid #fde68a}
.lp-purple{background:var(--purple-pale);border:1.5px solid rgba(139,92,246,.3)}
.lp-blue{background:#eff6ff;border:1.5px solid #93c5fd}
.lp-block-title{font-size:15px;font-weight:700;margin-bottom:12px;color:#110f1e}
.lp-checklist{display:flex;flex-direction:column;gap:8px}
.lp-checklist li{font-size:14px;color:#110f1e;padding-left:4px}

.income-table{display:flex;flex-direction:column;gap:8px}
.income-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--white);border-radius:6px}
.income-stage{font-size:13px;color:#5c5575}
.income-amt{font-size:14px;font-weight:700;color:#110f1e}
.income-high{color:#8B5CF6}

/* Sidebar */
.sticky-card{position:sticky;top:84px}
.btn-apply-lg{display:block;text-align:center;padding:15px;background:#8B5CF6;color:var(--white);font-size:15px;font-weight:700;border-radius:6px;margin-bottom:10px;transition:background var(--t),transform var(--t)}
.btn-apply-lg:hover{background:var(--purple-dark);transform:translateY(-1px)}
.btn-line-detail{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;background:#06c755;color:var(--white);font-size:13px;font-weight:700;border-radius:6px;margin-bottom:16px;transition:opacity var(--t)}
.btn-line-detail:hover{opacity:.9}


.detail-content{
  background:var(--off-white);
  padding:48px 0;
}
.detail-content-inner{
  max-width:720px;
}
.detail-main-content{
  display:flex;
  flex-direction:column;
  gap:0;
}
.dc-block{
  background:var(--white);
  border-radius:12px;
  padding:28px;
  margin-bottom:20px;
  border:1.5px solid var(--gray-100);
  width: 100%;
}
.dc-table{
  width:100%;
  border-collapse:collapse;
}
.dc-table th,
.dc-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--gray-100);
  font-size:14px;
  text-align:left;
}
.dc-table th{
  width:120px;
  font-weight:700;
  color:#5c5575;
  background:var(--gray-50);
}
.dc-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.dc-list li{
  font-size:14px;
  color:#110f1e;
  padding-left:20px;
  position:relative;
}
.dc-list li::before{
  content:'▸';
  position:absolute;
  left:0;color:#8B5CF6;
  font-size:12px;
  top:2p;
}
.dc-flow{
  display:flex;
  flex-direction:column;
  gap:0;
}
.df-step{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:14px 0;
}
.df-num{
  width:28px;
  height:28px;
  background:#8B5CF6;
  color:var(--white);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;
}
.df-arrow{
  font-size:18px;
  color:var(--gray-200);
  text-align:left;
  padding-left:8px;
  line-height:1.2;
}

/* ============================================================ FADE IN */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:none}



/* 詳細ページ全体のレイアウト */
.single-audition {
  background: #f8f9fa;
}

.c-button {
  color: #5b21b6;
  font-size: 14px;
  font-weight: 700;
  transition: all 0.3s ease;
  display: inline-block;
}
.c-button:hover {
    color: #8B5CF6;
    transform: translateX(-5px); /* 少し左に動かして「戻る感」を出す */
}
.entry-title {
  font-size: 28px;
  margin: 15px 0 7px;
  font-weight: 700;
}

.audi-main-visual img {
  width: 90%;
  height: auto;
  border-radius: 10px;
  margin:  30px auto 0; 
}
.firstview {
  max-width:1160px;
  margin:0 auto 45px;
}
.entry-content {
  margin-bottom: 28px;
}

.dc-h2 {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  padding-bottom:12px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom:2px solid var(--gray-100);
}
.dc-h2::before {
    content: '';
    width: 4px;
    height: 24px;
    background: var(--purple-dark);
    border-radius: 2px;
}
.dc-h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--dark-2);
    margin-bottom: 12px;
}

.dc-text, .entry-content p {
    font-size: 15px;
    font-weight: 400;
    line-height: 1.8;
    color: #4b5563;
}

/* --- テーブルのブラッシュアップ --- */
.detail-table {
  border-radius: 10px;
}

.detail-table th {
  background: var(--off-white);
  font-weight: 500; /* 見出しは少しだけ太く */
  color: var(--gray-400);
  font-size: 14px;
  width: 140px;
}

.detail-table td {
  font-weight: 600;
  font-size: 16px;
  padding: 0 20px;
}

/* --- サイドバーの固定カードをより「kyampus」風に --- */
.sticky-card {
  background: #fff;
  padding: 25px;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
  text-align: center;
}
.btn-apply-large {
  display: block;
  background: #06c755; /* LINEカラー */
  color: #fff;
  padding: 15px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 700;
  margin: 15px 0;
}
.card-label {
  font-family: var(--font-disp);
  color: var(--purple-dark);
  font-size: 12px;
  letter-spacing: 0.2em;
  margin-bottom: 8px;
}
.card-note {
  font-size: 12px;
  color: #9990b8;
}


/* --- ページ全体 --- */
.audition-list-page {
  background-color: var(--white);
}

/* --- ヘッダー --- */
.list-page-header {
  background: var(--off-white);
  padding: 80px 0 60px;
  text-align: center;
  border-bottom: 1px solid var(--gray-100);
}
.list-page-title {
  font-size: 42px;
  font-weight: 900;
  margin-top: 10px;
  color: var(--dark-2);
}

/* --- カテゴリーナビ --- */
.category-nav {
  padding: 40px 0;
  border-top: 1px solid var(--gray-50);
}
.category-title {
  font-size: 20px;
  text-align: center;
  margin-bottom: 25px;
}
.category-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.tag-pill {
  padding: 10px 24px;
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  transition: all 0.3s;
  color: black;
}
.tag-pill:hover {
  border-color: var(--purple-dark);
  background: var(--purple-pale);
  color: var(--purple-dark);
}

/* --- ブログセクション --- */
.blog-pickup {
  padding: 80px 0;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 30px;
}
.blog-thumb-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 8px;
  margin-bottom: 12px;
  background: var(--gray-100);
}
.blog-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.blog-item h3 {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
}

/* --- オーディショングリッド --- */
.audition-loop {
  padding: 100px 0;
  background: var(--off-white);
}
.audi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 40px;
}

.more-btn-area {
  margin-top: 60px;
  text-align: center;
}
.btn-more {
  display: inline-block;
  padding: 18px 60px;
  background: #110f1e;
  color: #fff;
  border-radius: 6px;
  font-weight: 700;
}

/* --- LINE CTA --- */
.line-footer-cta {
  padding: 100px 0;
  color: #05a647;
  text-align: center;
}
.btn-line-white {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #05a647;
  color: #fff;
  padding: 18px 40px;
  border-radius: 999px;
  font-weight: 900;
  text-decoration: none;
  margin-top: 25px;
}
/* --- 並べ替えボタン --- */
.sort-nav {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-bottom: 30px;
}

.sort-btn {
  padding: 8px 20px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: 4px;
  font-size: 14px;
  font-weight: 700;
  color: var(--gray-400);
  transition: all 0.3s;
}

.sort-btn:hover {
  border-color: var(--purple-dark);
  color: var(--purple-dark);
}

/* 現在選択中のボタン */
.sort-btn.active {
  background: var(--purple-dark);
  color: var(--white);
  border-color: var(--purple-dark);
  box-shadow: var(--sh-pur);
}

/* --- PR案件一覧ページ全体 --- */
.pr-list-page { background-color: var(--white); }

.list-page-sub {
  margin-top: 15px;
  color: var(--gray-400);
  line-height: 1.6;
}
.pr-filters-nav {
  padding: 40px 0 20px;
  border-bottom: 1px solid var(--gray-50);
}
.filter-group {
  margin: 25px;
}
.filter-label {
  display: block;
  font-size: 11px;
  font-weight: 900;
  color: var(--purple-dark);
  margin-bottom: 12px;
  letter-spacing: 0.1em;
}
.pr-tag-link {
  font-size: 14px;
  font-weight: 700;
  color: var(--gray-400);
  margin-right: 20px;
  text-decoration: none;
  transition: 0.3s;
}
.pr-tag-link:hover {
  color: var(--purple-dark);
}
.quick-tags-nav { padding: 40px 0 20px; }
.tag-flex { display: flex; justify-content: center; gap: 15px; flex-wrap: wrap; }
.tag-pill.lg {
  padding: 12px 28px;
  background: #fff;
  border: 2px solid var(--gray-100);
  border-radius: 999px;
  font-weight: 700;
  transition: 0.3s;
  color: var(--dark-2);
}
.tag-pill.lg:hover { border-color: var(--purple-dark); color: var(--purple-dark); }

.pr-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:20px;
}
.pr-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05); 
  transition: all 0.3s ease;
  border: 1px solid #f0f0f0;
  height: 100%;
  padding:24px;
}
.pr-card:hover {
  transform: translateY(-8px); /* 上に少し浮き上がる */
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12); /* 影を強くして浮遊感を出す */
  border-color: #ddd;
}

/* --- 画像エリア --- */
.pr-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.pr-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.pr-card:hover 
.pr-img img {
    transform: scale(1.1);
}
.pr-body {
    padding: 20px 0;
}
.ac-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.tag.tag-korea { background: #fdf2f8; color: #db2777; border: 1px solid #fbcfe8; }
.tag.tag-beauty { background: #fff1f2; color: #e11d48; border: 1px solid #fecdd3; }
.tag.tag-travel { background: #f0f9ff; color: #0284c7; border: 1px solid #bae6fd; }
.tag.tag-app { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }

.auto-color-0 { background: #f3f4f6; color: #4b5563; }
.auto-color-1 { background: #fff7ed; color: #c2410c; }
.auto-color-2 { background: #eff6ff; color: #1d4ed8; }
.auto-color-3 { background: #faf5ff; color: #7c3aed; }
.auto-color-4 { background: #fefce8; color: #854d0e; }

/* タイトル */
.pr-title {
    font-size: 18px;
    font-weight: 800;
    line-height: 1.4;
    color: #1a1a1a;
    margin-bottom: 10px;
    /* 2行以上は「...」で省略する設定 */
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

/* クライアント名 */
.pr-brand {
    font-size: 13px;
    color: #777;
    margin-bottom: 15px;
}
/* 報酬エリアの装飾を削る */
.pr-reward-simple {
    border-top: 1px solid #eee; /* 区切り線だけ入れる */
    padding-top: 12px;
    margin-bottom: 15px;
}
.pr-reward-simple .label {
    font-size: 11px;
    color: #999;
}
.pr-reward-simple .price {
    font-size: 15px;
    font-weight: 700;
    color: #444; /* 落ち着いた色 */
}

/* ボタンも「塗り」から「枠線」にすると大人っぽくなります */
.btn-detail-outline {
    display: block;
    border: 1px solid #110f1e;
    color: #110f1e;
    text-align: center;
    padding: 10px;
    border-radius: 6px;
    font-weight: 700;
}

/* --- ボタン --- */
.btn-detail {
    display: block;
    background: #110f1e;
    color: #fff;
    text-align: center;
    padding: 14px;
    border-radius: 8px;
    font-weight: 700;
    text-decoration: none;
    font-size: 14px;
    transition: background 0.3s;
}

.btn-detail:hover {
    background: #6200ea; /* ホバーで色を変える */
    color: #fff;
}

/* --- 4. サービス説明 --- */
.service-intro-section { padding: 100px 0; background: var(--off-white); }
.service-desc-box { max-width: 800px; margin: 0 auto; text-align: center; }
.desc-title { font-size: 28px; font-weight: 900; margin-bottom: 25px; }
.desc-text { line-height: 2; color: var(--gray-400); }

/* --- 5. CTA (LINE & 応募) --- */
.final-cta-section { 
  padding: 80px 0; 
}
.cta-card {
    padding: 60px 40px;
    border-radius: 20px;
    text-align: center;
    color: #fff;
}
.cta-headline { 
  font-size: 26px; 
  font-weight: 900; 
  margin-bottom: 40px;
  color: black;
}
.cta-buttons { 
  display: flex; 
  justify-content: center; 
  gap: 20px; 
}

/* ボタン共通 */
.btn-cta-line, .btn-cta-apply {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 15px 30px;
  border-radius: 999px;
  text-align: left;
  transition: transform 0.3s;
  text-decoration: none;
  color: #fff;
  min-width: 280px;
}
.btn-cta-line:hover, .btn-cta-apply:hover { transform: translateY(-3px); }

.btn-cta-line { 
  background: #05a647; 
}
.btn-cta-apply { 
  background: var(--purple-dark); 
}

.cta-buttons small { 
  display: block; 
  font-size: 11px; 
  opacity: 0.8; 
  text-align: center;
}
.cta-buttons strong { 
  font-size: 17px; 
  text-align: center;
}

/* --- PR詳細ページ全体 --- */
.pr-detail-page {
  background-color: #f8f9fa;
}
.detail-header {
  padding: 80px 0 0;
  text-align: center;
}
.pr-firstview {
  text-align: left;
}

.summary-card {
    background: #fff;
    padding: 30px;
    border-radius: 12px;
    border: 1px solid var(--gray-100);
    margin-bottom: 20px;
}
.summary-row {
    margin-bottom: 20px;
}
.summary-label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: var(--gray-400);
    margin-bottom: 5px;
}
.summary-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--dark-2);
}
.reward-highlight {
    font-size: 24px;
    color: var(--purple-dark);
    font-weight: 900;
}
.pr-tag-item {
    font-size: 13px;
    color: var(--gray-400);
    margin-right: 10px;
}

.pr-cat {
  padding-top: 42px;
  max-width: 1160px;
  margin: 0 auto;
}
.pr-cat-button {
  margin-top: 42px;
  padding: 0;
}

/* --- 事務所一覧エリア --- */
.agency-loop {
  border-top: 1px solid var(--gray-50);
  padding-top: 55px;
}
.agency-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 25px;
}
.agency-card {
    background: #fff;
    border: 1px solid var(--gray-100);
    border-radius: 12px;
    transition: 0.3s;
    text-align: center;
}
.agency-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--sh-md);
}
.agency-logo {
  aspect-ratio: 16/9;
  background: var(--off-white);
  border-bottom: 1px solid var(--gray-50);
  width: 100%;
  overflow: hidden;
  border-radius: 12px 12px 0 0;
}
.agency-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transition: transform 0.5s ease;
}

.agency-body {
    padding: 30px 20px;
}
.agency-name {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 10px;
}
.agency-catch {
  font-size: 14px;
  color: #696969;
  margin-bottom: 15px;
  min-height: 3em;
}
.agency-tags {
  font-size: 12px;
  color: var(--purple-dark);
  font-weight: 700;
  margin-bottom: 20px;
}
.agency-tags span { 
  margin: 0 5px;
}

/* --- 事務所詳細ページ用スタイル --- */
.agency-catch-detail {
    font-size: 18px;
    font-weight: 700;
    color: var(--gray-400);
    margin: 30px 0 25px;
}
.back-agency {
  margin: 15px 0;
  display: flex;
  justify-content: flex-start;
}
.agency-main-section {
  padding-bottom: 0;
}
.agency-main-visual {
    background: #fff;
    margin-bottom: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--gray-100);
}
.agency-main-visual img {
    width: 100%;
    height: auto;
}
.info-content-box {
    line-height: 1.8;
}
.agency-summary {
    position: sticky;
    top: 20px;
}
.summary-title {
  margin-bottom: 15px;
}

.common-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin: 50px 0;
}
.common-card {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #eee;
    overflow: hidden;
    position: relative;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    transition: 0.3s;
}
.common-card:hover { transform: translateY(-5px); }

/* バッジ */
.type-badge {
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 2;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 900;
    color: #fff;
}
.badge-audition { background: #6200ea; } 
.badge-pr { background: #ff4757; }


/* フィルターのスライダー */
.reward-filter-wrap {
    max-width: 400px;
    margin: 40px auto;
    text-align: center;
}
#rewardRange { width: 100%; margin: 15px 0; }
.range-labels { display: flex; justify-content: space-between; font-size: 12px; color: #999; }

/* 特集ハブのバナー */
.special-banners {
  padding: 60px 0;
}
.special-banner-card {
    display: block;
    height: 250px;
    margin-bottom: 30px;
    border-radius: 16px;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
    transition: 0.4s;
}
.special-banner-card:hover { transform: scale(1.02); }
.banner-content {
    position: absolute;
    bottom: 0; left: 0; width: 100%;
    padding: 40px;
    background: linear-gradient(transparent, rgba(0,0,0,0.7));
}
.banner-tag {
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.1em;
    border: 1px solid #fff;
    padding: 3px 10px;
    border-radius: 4px;
}
.type-label {
    position: absolute;
    top: 10px; left: 10px;
    z-index: 10;
    font-size: 10px;
    font-weight: 900;
    color: #fff;
    padding: 2px 8px;
    border-radius: 2px;
}
.type-label.audition { background: #6200ea; }
.type-label.pr { background: #ff4757; }
.card-img-wrap { aspect-ratio: 16 / 9; overflow: hidden; }
.card-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.card-body { padding: 15px; }
.card-body h3 { font-size: 16px; font-weight: 800; margin-bottom: 8px; }
.card-meta { font-size: 13px; color: #666; font-weight: 700; }

/* ブログヘッダー */
.blog-headers {
    background-color: #f4f7ff;
    padding: 60px 0;
}
.blog-category-nav {
    border-bottom: 1px solid #eee;
    background: #fff;
    top: 0;
    z-index: 100;
}
.category-list {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding: 15px 0;
    list-style: none;
}
.category-list a {
    text-decoration: none;
    color: #666;
    font-size: 14px;
    font-weight: 700;
    padding: 5px 15px;
    border-radius: 20px;
}
.category-list a:hover, .category-list a.active {
    background: var(--purple-main);
    color: #fff;
}
.blog-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    transition: 0.3s;
}
.blog-card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,0.05); }
.blog-img-wrap {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}
.blog-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.blog-cat-badge {
    position: absolute;
    bottom: 10px;
    left: 10px;
    background: rgba(255,255,255,0.9);
    color: #333;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 4px;
}
.blog-body { padding: 20px; }
.blog-date { 
  font-size: 12px; 
  color: #999; 
  display: block; 
  margin-bottom: 8px; 
}
.blog-title { font-size: 18px; line-height: 1.5; margin-bottom: 10px; font-weight: 800; }
.blog-excerpt { font-size: 14px; color: #666; line-height: 1.6; margin-bottom: 15px; }
.blog-more { font-size: 13px; font-weight: 700; color: var(--purple-main); }
.blog-single-header {
  padding-bottom: 30px;
}
.blog-content-wrap {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
    line-height: 1.8;
}
.blog-header {
  display: flex;
  flex-direction: column;
  padding: 0;
  text-align: left;
}
.blog-meta-top {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.blog-category {
    background: rgba(255,255,255,0.9);
    color: #333;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 4px;
    width: fit-content;
}
.blog-main-visual {
    margin-bottom: 40px;
}
.blog-main-visual img {
    width: 100%;
    height: auto;
    border-radius: 12px;
}
.entry-content h2 {
    border-left: 5px solid var(--purple-main);
    padding-left: 15px;
    margin: 40px 0 20px;
    font-size: 24px;
}
.entry-content p {
    margin-bottom: 25px;
}
.blog-nav-links {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #eee;
    padding-top: 40px;
    margin-top: 60px;
}



.keisai-form-page { background: #fcfaff; padding-bottom: 100px; }
.form-wrapper { 
    max-width: 800px; 
    margin: -40px auto 0; 
    background: #fff; 
    padding: 50px; 
    border-radius: 16px; 
    box-shadow: 0 10px 40px rgba(98, 0, 234, 0.05);
    position: relative;
    z-index: 10;
}
.form-step { display: none; }
.form-step.active { display: block; animation: fadeIn 0.4s ease; }
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.form-step h3 { 
    font-size: 20px; 
    font-weight: 800; 
    color: #6200ea; 
    margin-bottom: 25px; 
    padding-bottom: 10px;
    border-bottom: 2px solid #f0eaff;
}
.form-step label { display: block; font-weight: 800; margin-bottom: 20px; color: #333; font-size: 15px; }
.required { color: #ff4757; font-size: 11px; margin-left: 5px; vertical-align: middle; }
label small { display: block; font-weight: normal; color: #666; font-size: 12px; margin-bottom: 5px; }
hr { border: none; border-top: 1px solid #eee; margin: 30px 0; }

.form-step input[type="text"],
.form-step input[type="email"],
.form-step input[type="tel"],
.form-step input[type="url"],
.form-step input[type="date"],
.form-step select,
.form-step textarea {
    width: 100%; 
    padding: 15px; 
    border: 1px solid #eee; 
    border-radius: 8px; 
    background: #f9f9f9; 
    font-size: 16px;
    transition: 0.3s;
    box-sizing: border-box;
    margin-top: 8px;
}
.form-step input:focus, .form-step textarea:focus {
    background: #fff;
    border-color: #6200ea;
    outline: none;
    box-shadow: 0 0 0 4px rgba(98, 0, 234, 0.1);
}

.label-title { display: block; font-weight: 800; margin-bottom: 10px; font-size: 15px; }
.wpcf7-list-item { display: inline-block; margin: 0 15px 10px 0; }
.wpcf7-list-item label { font-weight: normal !important; display: flex !important; align-items: center; cursor: pointer; }
.wpcf7-list-item input { margin-right: 8px; width: 18px; height: 18px; }

.step-nav { 
    display: flex;
    justify-content: center; 
    gap: 20px; 
    margin-top: 40px;
    padding-top: 20px;
    border-top: 1px solid #eee;
}
.step-nav, 
.step-nav > p, 
.step-nav > span {
    display: flex;
    justify-content: center;
    gap: 20px;
}
.next-btn, .prev-btn, .wpcf7-submit {
    padding: 15px 40px;
    border-radius: 50px;
    font-weight: 800;
    font-size: 16px;
    cursor: pointer;
    transition: 0.3s;
    border: none;
    text-align: center;
}
.next-btn, .wpcf7-submit {
    background: #6200ea;
    color: #fff;
    min-width: 200px;
}
.next-btn:hover, .wpcf7-submit:hover { background: #5100c2; transform: translateY(-2px); }
.prev-btn {
    background: #eee;
    color: #666;
}
.prev-btn:hover { background: #e0e0e0; }
.wpcf7 input[type="submit"].wpcf7-submit {
    box-sizing: border-box !important;
    width: 100% !important;     /* 基本は100%にする */
    max-width: 280px !important; 
    display: block !important;
    margin: 30px auto !important; 
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.conf-box {
    background: #fcfaff;
    padding: 30px;
    border-radius: 12px;
    border: 1px solid #e0d5f5;
    margin-bottom: 30px;
}
.conf-item { margin-bottom: 15px; padding-bottom: 10px; border-bottom: 1px dashed #dcd0f0; }
.conf-label { font-size: 12px; color: #6200ea; font-weight: bold; }
.conf-value { font-size: 15px; color: #333; margin-top: 5px; font-weight: bold; }


:root {
    --purple-main: #6200ea;
    --green-cta: #34c759;
    --text-black: #333;
}
.keisai-lp { 
    line-height: 1.6;
    font-family: "Noto Sans JP", sans-serif; 
    color: var(--text-black); 
}
.keisai-hero {
    background: linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.4)), url('img/keisai-hero-bg.jpg') center/cover;
    padding: 120px 0;
    text-align: center;
    color: #fff;
}
.hero-badge { background: #fff; color: var(--purple-main); padding: 5px 15px; border-radius: 5px; font-weight: bold; margin-bottom: 20px; display: inline-block; }
.hero-title { font-size: 3rem; font-weight: 900; margin-bottom: 20px; line-height: 1.2; }
.hero-title span { color: #ffd700; } /* 「完全無料」を強調 */
.hero-sub { font-size: 1.2rem; margin-bottom: 40px; }
.hero-cta-wrap { display: flex; gap: 20px; justify-content: center; }
/* 共通ボタン */
.btn-main { 
  background-color: #5b21b6; 
  color: #fff; 
  padding: 18px 40px; 
  border-radius: 10px; 
  font-weight: bold; 
  text-decoration: none; 
  font-size: 1.1rem; 
  transition: 0.3s;
}
.btn-main:hover {
  background-color: #8B5CF6;
}
.btn-inquiry-white { 
  background: #fff; 
  color: var(--purple-main); 
  padding: 18px 40px; 
  border-radius: 10px; 
  font-weight: bold; 
  text-decoration: none; 
  font-size: 1.1rem;
  transition: 0.4s;
}
.btn-inquiry-white:hover {
  background-color: #5b21b6;
  color: white;
}

/* 実績 (Stats) */
.keisai-stats { background: #f8f9ff; padding: 60px 0; border-bottom: 1px solid #eee; }
.stats-grid { display: flex; justify-content: space-around; text-align: center; }
.stat-number { font-size: 2.2rem; font-weight: 900; color: var(--purple-main); }
.stat-number span { font-size: 3.5rem; margin-right: 5px; }

/* Section Title */
.section-title { 
  text-align: center; 
  margin: 50px 0 80px; 
  font-size: 2rem; 
  font-weight: bold; 
}
.section-title small { display: block; font-size: 0.9rem; color: #888; margin-top: 5px; letter-spacing: 2px; }

/* メリット (Merits) */
.merit-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.merit-card { background: #fff; padding: 40px 30px; border-radius: 15px; border: 1px solid #eee; text-align: center; transition: 0.3s; }
.merit-card:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0,0,0,0.05); }
.merit-icon { font-size: 3rem; margin-bottom: 20px; }
.merit-card h3 { font-size: 1.25rem; font-weight: bold; margin-bottom: 15px; color: var(--purple-main); }
.merit-card p { font-size: 0.95rem; color: #666; text-align: left; }

/* UI Points */
.keisai-ui-points { background: #fff; padding-bottom: 80px; }
.ui-flex { display: flex; align-items: center; gap: 50px; }
.ui-text { flex: 1; }
.ui-text ul { list-style: none; padding: 0; }
.ui-text li { 
  margin-bottom: 25px; 
  padding-left: 30px; 
  position: relative; 
}
.ui-text li strong {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #5b21b6;
}
.ui-image { 
  flex: 1; 
}
.ui-image img { width: 100%; border-radius: 10px; box-shadow: 0 15px 40px rgba(0,0,0,0.1); }

/* Flow */
.keisai-flow { background: #fdfdfd; padding-bottom: 80px; }
.flow-list { display: flex; gap: 20px; }
.flow-item { flex: 1; background: #fff; padding: 40px; border-radius: 10px; position: relative; border: 1px dotted #ccc; }
.flow-item .num { font-size: 3rem; font-weight: 900; color: #eee; position: absolute; top: 10px; right: 20px; }
.flow-item h4 { font-size: 1.2rem; margin-bottom: 15px; color: var(--purple-main); }
.flow-icon {
  font-size: 25px;
  line-height: 1.2;
  margin-bottom: 15px;
  display: block;
}

/* Price Table */
.price-table { 
  display: flex; 
  gap: 30px; 
  max-width: 1200px; 
  margin: 40px auto; 
}
.price-card { 
  flex: 1; 
  padding: 50px 40px; 
  border: 1px solid #eee; 
  border-radius: 15px; 
  background: #fff; 
  position: relative; 
  text-align: center; 
  transition: 0.3s;
  display: flex;
  flex-direction: column;
}
.price-card:hover { 
  border: 2px solid var(--purple-main); 
  box-shadow: 0 10px 30px rgba(98,0,234,0.1); 
  transform: scale(1.02);
}
.price-val { font-size: 3rem; font-weight: bold; margin: 20px 0; color: var(--purple-main); }
.price-card ul { list-style: none; padding: 0; margin: 30px 0; text-align: left; }
.price-card li { margin-bottom: 10px; font-size: 0.9rem; }
.price-card li::before { content: '・'; }
.recommend { position: absolute; top: -15px; left: 50%; transform: translateX(-50%); background: var(--purple-main); color: #fff; padding: 5px 20px; border-radius: 20px; font-size: 0.8rem; font-weight: bold; }
.btn-price-inquiry { 
  display: block; 
  border: 2px solid var(--purple-main); 
  color: var(--purple-main); 
  padding: 12px; 
  border-radius: 5px; 
  text-decoration: none; 
  font-weight: bold; 
  margin-top: auto;
  transition: 0.4s;
}
.btn-price-inquiry:hover {
  background-color: #5b21b6;
  color: white;
}
.keisai-cta { 
  padding: 80px 0 100px; 
  text-align: center; }
.cta-title { 
  font-size: 2.2rem; 
  margin-bottom: 40px; 
  font-weight: bold;
}
.cta-btns { display: flex; gap: 20px; justify-content: center; }
.btn-entry { 
  background-color: #5b21b6; 
  color: #fff; 
  padding: 22px 50px; 
  border-radius: 10px; 
  font-weight: bold; 
  text-decoration: none; 
  font-size: 1.3rem; 
  box-shadow: 0 5px 20px rgba(0,0,0,0.2); 
  transition: 0.3s;
}
.btn-entry:hover {
  background-color: #8B5CF6;
}
.btn-inquiry-outline { 
  background: transparent; 
  border: 2px solid #5b21b6;
  color: #5b21b6;
  padding: 20px 40px; 
  border-radius: 10px; 
  font-weight: bold; 
  text-decoration: none; 
  font-size: 1.1rem;
  transition: 0.4s;
}
.btn-inquiry-outline:hover {
  background-color: #5b21b6;
  color: white;
}
.error-message-box {
    background: #fff5f5;
    color: #ff4757;
    border: 1px solid #ffccd0;
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
    font-weight: bold;
    font-size: 14px;
    text-align: center;
    animation: shake 0.3s ease; /* ぷるっと揺れる */
}
.input-error {
    border-color: #ff4757 !important;
    background-color: #fff0f0 !important;
}
.group-error {
    border: 1px solid #ff4757;
    padding: 10px;
    border-radius: 8px;
    background-color: #fff0f0;
}
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}
.contact-form-container {
    margin: 40px auto;
    padding: 40px;
    background: #ffffff;
    border: 1px solid #eef0f2;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}
.form-row {
    margin-bottom: 25px;
}
.form-label {
    display: block;
    font-size: 15px;
    font-weight: 700;
    color: #1a202c;
    margin-bottom: 10px;
}
.badge-required {
    background: #e53e3e;
    color: #fff;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 8px;
    vertical-align: middle;
}
p br {
  display: none;
}
.contact-form-container input[type="text"],
.contact-form-container input[type="email"],
.contact-form-container select,
.contact-form-container textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    background-color: #f9fafb;
    font-size: 16px;
    color: #374151;
    transition: all 0.3s ease;
    box-sizing: border-box;
}
.contact-form-container input:focus,
.contact-form-container select:focus,
.contact-form-container textarea:focus {
    outline: none;
    border-color: #5b21b6;
    background-color: #fff;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.1);
}
.form-submit-wrap {
    text-align: center;
    margin-top: 40px;
}
.contact-submit {
    background: #1a202c;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    padding: 16px 60px;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.3s ease;
    -webkit-appearance: none;
}
.contact-submit:hover {
    background: #5b21b6;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(59, 130, 246, 0.3);
}
.p-contact {
    background-color: #f8fafc;
    padding: 80px 20px;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
.p-contact__inner {
    max-width: 800px;
    margin: 0 auto;
}
.p-contact__header {
    text-align: center;
    margin-bottom: 60px;
}
.p-contact__title {
    font-size: 40px;
    font-weight: 800;
    letter-spacing: 0.1em;
    color: #1e293b;
}
.p-contact__subtitle {
    font-size: 14px;
    font-weight: 700;
    color: #5b21b6;
    margin-bottom: 24px;
}
.p-contact__lead {
    font-size: 16px;
    line-height: 1.8;
    color: #64748b;
}
.wpcf7-form-control-wrap {
    display: block;
    margin-top: 8px;
}
.contact-form-container .form-row {
    margin-bottom: 32px;
}
.contact-form-container .form-label {
    display: block;
    font-weight: 700;
    font-size: 15px;
    color: #334155;
}
.wpcf7-not-valid-tip {
    font-size: 13px;
    margin-top: 5px;
}
.wpcf7 .ajax-loader {
    display: block;
    margin: 15px auto 0;
}
/* ============================================================ RESPONSIVE */
@media(max-width:1024px){
  .hero {
    min-height: auto;
    padding: 140px 0 80px;
  }
  .hero-inner{
    flex-direction: column;
    text-align: center;
  }
  .hero-text {
    flex-direction: column;
    align-items: center;
  }
  .hero-headline {
    margin-right: 0;
    margin-bottom: 30px;
    font-size: clamp(32px, 8vw, 48px);
  }
  .hero-checks {
    align-items: center;
    margin-bottom: 40px;
  }
  .banner-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .tag-groups{grid-template-columns:1fr 1fr}
  .cat-nav-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .pr-grid{grid-template-columns:1fr 1fr}
  .pr-card.pr-featured{grid-column:span 2}
  .service-grid{
    grid-template-columns: repeat(2, 1fr);
  }
  .reasons-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-brand{grid-column:span 2}
  .detail-hero-inner{grid-template-columns:1fr}
  .detail-sidebar{display:none}
  .merit-grid{grid-template-columns:1fr 1fr}
  .merit-card.merit-featured{grid-column:span 2}
  .plan-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .detail-container {
    flex-direction: column;
  }
  .container {
    padding: 0 24px;
  }
  .firstview {
    margin-bottom: 30px;
  }
  .entry-title {
    font-size: 24px;
  }
  .audi-main-visual img {
    width: 100%;
  }
  .sticky-card {
    margin-top: 40px;
    position: static;
    width: 100%;
  }
  .table-wrapper {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .detail-table {
    min-width: 500px;
  }
  .detail-grid {
    grid-template-columns: 1fr;
  }
  .summary-card {
    position: static;
  }
  .common-grid {
      grid-template-columns: repeat(2, 1fr);
  }
}

@media(max-width:768px){
  section {
    padding: 60px 0;
  }
  .global-nav,.header-actions{
    display:none;
  }
  .hamburger{
    display:flex;
  }
  .mobile-nav{display:flex}
  .banner-grid{
    grid-template-columns:1fr;
  }
  .list-page-header { padding: 60px 0; }
  .list-page-title { font-size: 24px; }
  .sort-nav {
      overflow-x: auto;
      justify-content: flex-start;
      padding-bottom: 10px;
      -webkit-overflow-scrolling: touch;
  }
  .sort-btn {
      flex-shrink: 0;
      padding: 8px 16px;
  }
  .audi-grid { grid-template-columns: 1fr; }
  .ac-title { min-height: auto; }
  .btn-more { width: 100%; }
  .cat-nav-grid{grid-template-columns:repeat(2,1fr)}
  .howto-steps{flex-direction:column}
  .hs-arrow{display:none}
  .hs-step{width:100%}
  .cta-band-inner{
    flex-direction:column;
    text-align:center;
  }
  .cta-band-sub {
    font-size: 24px;
  }
  .cta-band-btns {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }
    .btn-line-lg,
    .btn-search-lg {
        width: 100% !important;
        max-width: 100% !important;
    }
    .c-button {
        display: block; 
        width: fit-content;
        margin: 0 auto 10px;
        font-size: 13px;
        padding: 10px 20px;
    }
    .audition-loop {
      padding-top: 50px;
    }
  .biz-flow-steps{flex-direction:column}
  .bf-arrow{display:none}
  .form-row{grid-template-columns:1fr}
  .biz-form-card{padding:28px 20px}
  .apply-card{padding:24px 16px}
  .cta-buttons { flex-direction: column; align-items: center; }
  .btn-cta-line, .btn-cta-apply { width: 100%; }
  .agency-grid { grid-template-columns: 1fr; }
  .p-contact {
      padding: 60px 15px;
  }
  .p-contact__form {
      padding: 30px 20px;
  }
  .u-sp-only {
      display: block;
  }
  .merit-grid, .ui-flex, .flow-list, .price-table, .hero-cta-wrap, .cta-btns, .stats-grid { flex-direction: column; }
  .hero-title { font-size: 2rem; }
  .ui-image { order: -1; }
  .p-contact {
      padding: 40px 15px;
  }
  .p-contact__header {
      margin-bottom: 30px;
  }
  .p-contact__title {
      font-size: 24px;
  }
  .p-contact__form {
      padding: 30px 20px;
  }
  .u-sp-only {
      display: block;
  }
  .common-grid {
      grid-template-columns: 1fr;
      gap: 20px;
  }
 .blog-single-header {
      padding: 40px 0;
  }

  .list-page-title {
      font-size: 22px;
      line-height: 1.4;
  }

  .blog-meta-top {
      flex-direction: column;
      gap: 5px;
  }

  .blog-nav-links {
      flex-direction: column;
      text-align: center;
  }

  .blog-nav-links .prev,
  .blog-nav-links .next {
      width: 100%;
  }

  .blog-nav-links .back-to-list {
      order: 3;
      margin-top: 10px;
  }
}

@media(max-width:560px){
  .hero-headline {
    font-size: 32px;
  }
  .sp-br {
    display: block; /* 改行を有効に */
  }
  .hero-cta-group{
    flex-direction:column;
  }
  .btn-hero-primary, .line-cta, .btn-hero-ghost {
    width: 100%;
    justify-content: center;
  }
  .tag-groups{
    grid-template-columns:1fr;
  }
  .clients {
    flex-direction: column;
    gap: 15px;
  }
  .link-more {
    font-size: 11px;
  }
  .section-title {
    margin: 20px 0;
  }
  .blog-grid { grid-template-columns: 1fr; }
  .category-list { justify-content: flex-start; }
  .audi-card {
    flex: 0 0 280px;
  }
  .scroll-cards {
    padding-left: 15px;
    padding-right: 15px;
  }
  .cat-nav-grid{
    grid-template-columns:1fr;
  }
  .service-grid{
    grid-template-columns:1fr;
  }
  .reasons-grid{grid-template-columns:1fr}
  .footer-grid{
    grid-template-columns:1fr;
  }
  .footer-logo {
    justify-content: center;
    margin-bottom: 20px;
  }
  .footer-brand{grid-column:auto}
  .pr-grid{grid-template-columns:1fr}
  .pr-card.pr-featured{grid-column:auto}
  .biz-hero-cta{flex-direction:column}
  .footer-cta-btns{flex-wrap:wrap}
  .footer-bottom .container{
    flex-direction:column;
    align-items:flex-start;
  }
  .merit-card.merit-featured{grid-column:auto}
  .merit-grid{grid-template-columns:1fr}
  .audi-main-visual img {
    border-radius: 10px;
    margin:  30px auto 0; 
  }
  .dc-h2 {
      font-size: 20px;
      padding-bottom: 10px;
    }
  .dc-block {
    padding: 20px;
  }
  .detail-table th {
    width: 100px;
    font-size: 13px;
    padding: 10px;
  }
  .detail-table td {
    font-size: 14px;
    padding: 10px;
  }
  .btn-apply-large {
    padding: 18px; 
    font-size: 16px;
  }
  .sort-nav {
    gap: 8px;
  }
  .sort-btn {
    flex: 1;
    padding: 8px 0;
    text-align: center;
    font-size: 12px;
  }
  .cta-card {
    padding-top: 0;
  }
}
