@import url('https://fonts.googleapis.com/css2?family=Pretendard:wght@400;500;600;700;800;900&display=swap');

/* =========================
   TABLE HOPPING PAGE BASE
========================= */

body.tablehopping-page,
.sub.tablehopping-page{
  background: transparent !important;
}

.tablehopping-page{
  position: relative;
  background: transparent;
  color:#f7f5ef;
  overflow-x:hidden;
}

.tablehopping-page::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(rgba(8,10,14,0.38), rgba(8,10,14,0.48)),
    url("../image/program/tablehopping/tablehopping-bg.webp");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}

.tablehopping-page::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 10%, rgba(230,184,104,0.10), transparent 22%),
    radial-gradient(circle at 80% 80%, rgba(230,184,104,0.08), transparent 20%);
}

.tablehopping-page section{
  position:relative;
  padding:120px 0;
}

.tablehopping-page section + section{
  margin-top:0;
}

.tablehopping-page section::before{
  display:none;
}

.tablehopping-page .tablehopping-hero::before{
  display:none;
}

.tablehopping-page .section-inner{
  width:90%;
  max-width:1200px;
  margin:0 auto;
  position:relative;
  z-index:2;
}

.tablehopping-page .section-inner.narrow{
  max-width:900px;
}

.tablehopping-page .section-heading{
  margin-bottom:54px;
}

.tablehopping-page .section-heading.center{
  text-align:center;
}

.tablehopping-page .section-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:9px 18px;
  border-radius:999px;
  border:1px solid rgba(201,157,83,0.28);
  background:rgba(201,157,83,0.08);
  color:#e5bc74;
  font-size:0.78rem;
  font-weight:800;
  letter-spacing:0.16em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.tablehopping-page h2{
  margin:0;
  font-size:clamp(2.4rem, 5vw, 4.3rem);
  line-height:1.14;
  font-weight:900;
  letter-spacing:-0.03em;
  color:#fff;
}

.tablehopping-page h2 span{
  color:#e8b968;
}

.tablehopping-page p{
  word-break:keep-all;
}

/* =========================
   HERO
========================= */

.tablehopping-page .tablehopping-hero{
  min-height:100vh;
  padding:0;
  overflow:hidden;
  background:#050608;
}

.tablehopping-page .tablehopping-hero .hero-bg,
.tablehopping-page .tablehopping-hero .hero-overlay{
  position:absolute;
  inset:0;
}

.tablehopping-page .tablehopping-hero .hero-bg{
  background:
    linear-gradient(90deg, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.52) 42%, rgba(0,0,0,0.78) 100%),
    url("../image/program/tablehopping/tablehopping-hero.webp");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  z-index:1;
}

.tablehopping-page .tablehopping-hero .hero-overlay{
  background:
    radial-gradient(circle at 24% 34%, rgba(201,157,83,0.18), transparent 22%),
    radial-gradient(circle at 76% 26%, rgba(58,86,150,0.14), transparent 24%),
    linear-gradient(to bottom, rgba(0,0,0,0.14), rgba(0,0,0,0.58));
  z-index:2;
}

.tablehopping-page .hero-inner{
  min-height:100vh;
  display:flex;
  align-items:center;
}

.tablehopping-page .hero-copy{
  position:relative;
  z-index:3;
  width:100%;
  max-width:660px;
  padding-top:80px;
}

.tablehopping-page .hero-kicker{
  display:inline-block;
  margin-bottom:18px;
  color:#e4ba72;
  font-size:0.9rem;
  font-weight:800;
  letter-spacing:0.22em;
}

.tablehopping-page .hero-copy h1{
  margin:0 0 22px;
  font-size:clamp(3rem, 7vw, 6rem);
  line-height:1.04;
  font-weight:900;
  letter-spacing:-0.04em;
  color:#fff;
  word-break:keep-all;
}

.tablehopping-page .hero-copy h1 span{
  color:#e8b968;
}

.tablehopping-page .hero-desc{
  max-width:620px;
  margin:0 0 34px;
  font-size:1.08rem;
  line-height:1.95;
  color:rgba(255,255,255,0.82);
}

.tablehopping-page .hero-buttons,
.tablehopping-page .cta-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

.tablehopping-page .btn-primary,
.tablehopping-page .btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:178px;
  min-height:56px;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  font-size:0.98rem;
  font-weight:800;
  transition:all 0.25s ease;
}

.tablehopping-page .btn-primary{
  color:#111;
  background:linear-gradient(135deg, #f0c57a 0%, #d9a24a 100%);
  box-shadow:0 14px 34px rgba(0,0,0,0.24);
}

.tablehopping-page .btn-primary:hover{
  transform:translateY(-2px);
}

.tablehopping-page .btn-secondary{
  color:#fff;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.tablehopping-page .btn-secondary:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,0.08);
}

.tablehopping-page .hero-scroll{
  position:absolute;
  left:50%;
  bottom:28px;
  transform:translateX(-50%);
  z-index:3;
}

.tablehopping-page .hero-scroll span{
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.24em;
  color:rgba(255,255,255,0.68);
}

/* =========================
   INTRO
========================= */

.tablehopping-page .tablehopping-intro{
  background:rgba(5,7,10,0.30);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .intro-copy{
  text-align:center;
}

.tablehopping-page .intro-copy p{
  margin:0 auto;
  max-width:860px;
  font-size:1.08rem;
  line-height:2.02;
  color:rgba(255,255,255,0.82);
}

.tablehopping-page .intro-copy p + p{
  margin-top:22px;
}

/* =========================
   POINT
========================= */

.tablehopping-page .tablehopping-point{
  background:rgba(5,7,10,0.36);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .point-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
}

.tablehopping-page .point-card{
  position:relative;
  padding:34px 30px;
  border-radius:28px;
  background:
    linear-gradient(135deg, rgba(201,157,83,0.10), rgba(255,255,255,0.03) 45%, rgba(45,62,108,0.10) 100%);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 45px rgba(0,0,0,0.24),
    inset 0 0 0 1px rgba(255,255,255,0.02);
  text-align:center;
}

.tablehopping-page .point-card::before,
.tablehopping-page .recommend-card::before,
.tablehopping-page .flow-card::before,
.tablehopping-page .check-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  background:
    radial-gradient(circle at 20% 0%, rgba(201,157,83,0.10), transparent 36%),
    radial-gradient(circle at 100% 100%, rgba(53,98,201,0.08), transparent 34%);
  opacity:0.9;
  z-index:-1;
  pointer-events:none;
}

.tablehopping-page .point-number{
  display:inline-block;
  margin-bottom:18px;
  color:#e5bc74;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0.12em;
}

.tablehopping-page .point-card h3{
  margin:0 0 14px;
  font-size:1.45rem;
  font-weight:800;
  color:#fff;
}

.tablehopping-page .point-card p{
  margin:0;
  font-size:1rem;
  line-height:1.88;
  color:rgba(255,255,255,0.8);
}

/* =========================
   RECOMMEND
========================= */

.tablehopping-page .tablehopping-recommend{
  background:rgba(5,7,10,0.42);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .recommend-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px;
}

.tablehopping-page .recommend-card{
  position:relative;
  padding:34px 30px;
  border-radius:28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.03), rgba(201,157,83,0.06) 52%, rgba(255,255,255,0.02) 100%);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 45px rgba(0,0,0,0.22),
    inset 0 0 0 1px rgba(255,255,255,0.02);
  text-align:center;
}

.tablehopping-page .recommend-card h3{
  margin:0 0 14px;
  font-size:1.55rem;
  font-weight:800;
  color:#fff;
}

.tablehopping-page .recommend-card p{
  margin:0;
  font-size:1rem;
  line-height:1.9;
  color:rgba(255,255,255,0.8);
}

/* =========================
   FLOW
========================= */

.tablehopping-page .tablehopping-flow{
  background:rgba(5,7,10,0.34);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .flow-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.tablehopping-page .flow-card{
  position:relative;
  padding:34px 30px;
  border-radius:28px;
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 44px rgba(0,0,0,0.20),
    inset 0 0 0 1px rgba(255,255,255,0.02);
  text-align:center;
}

.tablehopping-page .flow-step{
  display:inline-block;
  margin-bottom:16px;
  color:#e5bc74;
  font-size:0.86rem;
  font-weight:900;
  letter-spacing:0.16em;
}

.tablehopping-page .flow-card h3{
  margin:0 0 14px;
  font-size:1.38rem;
  font-weight:800;
  color:#fff;
}

.tablehopping-page .flow-card p{
  margin:0;
  font-size:1rem;
  line-height:1.88;
  color:rgba(255,255,255,0.78);
}

/* =========================
   CHECK
========================= */

.tablehopping-page .tablehopping-check{
  background:rgba(5,7,10,0.40);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .check-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:20px;
}

.tablehopping-page .check-card{
  position:relative;
  padding:30px 24px;
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 16px 40px rgba(0,0,0,0.22),
    inset 0 0 0 1px rgba(255,255,255,0.02);
  text-align:center;
}

.tablehopping-page .check-card h3{
  margin:0 0 12px;
  font-size:1.22rem;
  font-weight:800;
  color:#e8b968;
}

.tablehopping-page .check-card p{
  margin:0;
  font-size:0.98rem;
  line-height:1.82;
  color:rgba(255,255,255,0.78);
}

/* =========================
   CTA
========================= */

.tablehopping-page .tablehopping-cta{
  text-align:center;
  background:rgba(5,7,10,0.36);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}

.tablehopping-page .tablehopping-cta p{
  max-width:820px;
  margin:24px auto 34px;
  font-size:1.08rem;
  line-height:1.95;
  color:rgba(255,255,255,0.82);
  text-align:center;
}

.tablehopping-page .tablehopping-cta .cta-buttons{
  justify-content:center;
}

/* =========================
   FOOTER
========================= */

.tablehopping-page .footer{
  padding:32px 0 38px;
  border-top:1px solid rgba(255,255,255,0.06);
  background:#040506;
}

.tablehopping-page .footer-inner{
  width:90%;
  max-width:1200px;
  margin:0 auto;
  text-align:center;
}

.tablehopping-page .footer p{
  margin:0;
  font-size:0.92rem;
  color:rgba(255,255,255,0.48);
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 1100px){

  .tablehopping-page .point-grid,
  .tablehopping-page .flow-grid{
    grid-template-columns:1fr;
  }

  .tablehopping-page .check-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px){

  .tablehopping-page section{
    padding:92px 0;
  }

  .tablehopping-page .hero-copy{
    max-width:100%;
    text-align:center;
    margin:0 auto;
  }

  .tablehopping-page .hero-desc{
    margin-left:auto;
    margin-right:auto;
  }

  .tablehopping-page .hero-buttons{
    justify-content:center;
  }

  .tablehopping-page .recommend-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 768px){

  .tablehopping-page .section-inner{
    width:92%;
  }

  .tablehopping-page .tablehopping-hero{
    padding:0;
    min-height:100svh;
    overflow:hidden;
    background:#050608;
  }

  .tablehopping-page .hero-inner{
    min-height:100svh;
    padding:0;
  }

  .tablehopping-page .tablehopping-hero .hero-bg{
    position:absolute;
    inset:0;
    transform:none;
    background:
      linear-gradient(180deg, rgba(0,0,0,0.56) 0%, rgba(0,0,0,0.40) 38%, rgba(0,0,0,0.88) 100%),
      url("../image/program/tablehopping/tablehopping-hero.webp");
    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
    z-index:1;
  }

  .tablehopping-page .tablehopping-hero .hero-overlay{
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at 24% 24%, rgba(201,157,83,0.12), transparent 22%),
      linear-gradient(to bottom, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.18) 35%, rgba(0,0,0,0.60) 72%, rgba(5,6,8,0.96) 100%);
    z-index:2;
  }

  .tablehopping-page .hero-copy{
    padding-top:70px;
  }

  .tablehopping-page .hero-kicker{
    font-size:0.82rem;
    letter-spacing:0.18em;
  }

  .tablehopping-page .hero-copy h1{
    font-size:clamp(2.5rem, 10vw, 4.2rem);
    line-height:1.08;
    word-break:keep-all;
  }

  .tablehopping-page .hero-desc{
    font-size:1rem;
    line-height:1.85;
  }

  .tablehopping-page .btn-primary,
  .tablehopping-page .btn-secondary{
    width:100%;
    max-width:320px;
  }

  .tablehopping-page .check-grid{
    grid-template-columns:1fr;
  }

  .tablehopping-page .point-card,
  .tablehopping-page .recommend-card,
  .tablehopping-page .flow-card{
    padding:28px 24px;
    border-radius:24px;
  }

  .tablehopping-page .check-card{
    padding:24px 20px;
  }

  .tablehopping-page .point-card h3,
  .tablehopping-page .recommend-card h3,
  .tablehopping-page .flow-card h3{
    font-size:1.3rem;
  }

  .tablehopping-page .tablehopping-cta p,
  .tablehopping-page .intro-copy p{
    font-size:1rem;
    line-height:1.9;
  }
}

@media (max-width: 480px){

  .tablehopping-page section{
    padding:78px 0;
  }

  .tablehopping-page .section-inner{
    width:88%;
  }

  .tablehopping-page .hero-copy{
    padding-top:52px;
  }

  .tablehopping-page .hero-copy h1{
    font-size:clamp(2.2rem, 10.8vw, 3.5rem);
    line-height:1.08;
  }

  .tablehopping-page .hero-desc{
    font-size:0.94rem;
    line-height:1.78;
  }

  .tablehopping-page .section-label{
    min-height:38px;
    padding:8px 14px;
    font-size:0.7rem;
  }

  .tablehopping-page h2{
    font-size:clamp(2rem, 9vw, 3rem);
  }

  .tablehopping-page .point-card,
  .tablehopping-page .recommend-card,
  .tablehopping-page .flow-card,
  .tablehopping-page .check-card{
    padding:24px 18px;
    border-radius:22px;
  }

  .tablehopping-page .hero-scroll{
    bottom:22px;
  }

  .tablehopping-page .hero-scroll span{
    font-size:0.66rem;
  }
}

.tablehopping-page .tablehopping-intro,
.tablehopping-page .tablehopping-point,
.tablehopping-page .tablehopping-recommend,
.tablehopping-page .tablehopping-flow,
.tablehopping-page .tablehopping-check,
.tablehopping-page .tablehopping-cta{
  background: rgba(5, 7, 10, 0.34);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}