:root{
  --bg:#03101b;
  --bg2:#061b2b;
  --card:rgba(255,255,255,.055);
  --card2:rgba(255,255,255,.085);
  --line:rgba(255,255,255,.14);
  --text:#fff;
  --muted:#9fb4c5;
  --soft:#d9e9f4;
  --accent:#7bd7ff;
  --gold:#d7b46a;
  --shadow:0 26px 70px rgba(0,0,0,.34);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans KR",Arial,sans-serif;
  background:radial-gradient(circle at top,#0a2c45 0%,var(--bg) 48%,#020811 100%);
  color:var(--text);
  letter-spacing:-.02em;
}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  background:linear-gradient(to bottom,rgba(3,16,27,.82),rgba(3,16,27,.34));
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.header.scrolled{background:rgba(3,16,27,.92)}
.header-inner{
  max-width:1240px;margin:auto;padding:18px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:850;font-size:21px;white-space:nowrap}
.brand img{width:44px;height:44px;object-fit:contain;border-radius:50%}
.brand small{display:block;font-size:11px;letter-spacing:.14em;color:var(--muted);font-weight:600}
.nav{display:flex;align-items:center;gap:30px;font-size:15px;font-weight:650}
.nav a{color:rgba(255,255,255,.86)}
.nav a:hover{color:#fff}
.nav .book{border:1px solid rgba(255,255,255,.75);padding:10px 16px;border-radius:10px;color:white}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:white;border-radius:10px;padding:10px 12px;font-size:20px}

.hero{
  min-height:760px;display:flex;align-items:center;
  padding:150px 24px 90px;
  background:
    linear-gradient(90deg,rgba(0,5,12,.92),rgba(0,8,16,.42) 50%,rgba(0,8,16,.82)),
    url("images/main-hero.jpg") center/cover no-repeat;
  position:relative;
}
.hero:after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:160px;
  background:linear-gradient(to bottom,transparent,var(--bg));
}
.hero-inner{position:relative;z-index:1;max-width:1240px;margin:auto;width:100%}
.kicker{color:var(--accent);font-size:14px;font-weight:800;letter-spacing:.18em;margin-bottom:18px;text-transform:uppercase}
.hero h1{font-size:clamp(42px,6vw,76px);line-height:1.08;margin:0 0 24px;letter-spacing:-.06em}
.hero p{font-size:19px;color:#d8e7f2;line-height:1.8;margin:0 0 34px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 22px;border-radius:12px;border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.07);font-weight:800;transition:.2s;
}
.btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.13)}
.btn.primary{background:#fff;color:#03101b;border-color:white}
.btn.gold{background:rgba(215,180,106,.16);border-color:rgba(215,180,106,.65);color:#ffe3a4}
.section{border-top:1px solid var(--line);padding:72px 24px}
.container{max-width:1240px;margin:auto}
.section-title{margin-bottom:30px}
.section-title h2{font-size:36px;margin:0 0 6px}
.section-title span{font-size:14px;text-transform:uppercase;letter-spacing:.14em;color:#647d91}
.layout-2{display:grid;grid-template-columns:1fr 1.18fr;gap:44px}
.price-stack{display:grid;gap:16px}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  border:1px solid var(--line);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow)
}
.card.pad{padding:24px}
.card h3{margin:0 0 16px;font-size:21px}
.price-row{
  display:flex;justify-content:space-between;gap:18px;padding:13px 0;
  border-top:1px solid rgba(255,255,255,.1);color:#edf8ff
}
.price-row:first-of-type{border-top:0}
.price-row strong{white-space:nowrap;color:#fff}
.note{color:var(--muted);font-size:14px;line-height:1.75;margin:12px 0 0}
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rental-list{columns:2;margin:0;padding-left:20px;color:#dcebf5;line-height:1.9}
.visual-card{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.visual-card img{width:100%;height:350px;object-fit:cover}
.visual-overlay{position:absolute;inset:auto 0 0;padding:34px;background:linear-gradient(transparent,rgba(0,0,0,.82));text-align:center}
.visual-overlay strong{font-size:26px;display:block;margin-bottom:8px}
.gallery-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
.gallery-3 img{height:170px;width:100%;object-fit:cover;border-radius:15px;border:1px solid var(--line)}
.course-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.course-card img{height:330px;width:100%;object-fit:cover}
.course-card h3{padding:20px 22px;margin:0;background:rgba(255,255,255,.06)}
.course-card p{padding:22px;margin:0;color:#d8e6f1;line-height:1.8}
.facility-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.facility-card{cursor:pointer}
.facility-card img{height:158px;width:100%;object-fit:cover;transition:.25s}
.facility-card:hover img{transform:scale(1.035)}
.facility-card p{margin:0;padding:14px;text-align:center;font-weight:750;background:rgba(255,255,255,.055)}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.contact-card{min-height:190px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:10px}
.contact-icon{font-size:46px;line-height:1}
.contact-card p{margin:0;color:var(--muted)}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.location-text{color:#dceaf4;line-height:1.9}
.location-text strong{color:white}
.map-card{background:#e8eef3;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-card img{height:270px;width:100%;object-fit:cover}
.map-placeholder{
  height:270px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#e8eef3,#b6d5ea);color:#183247;font-weight:800
}
.instagram{display:grid;grid-template-columns:180px 1fr 240px;gap:20px;align-items:center}
.insta-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.insta-grid img{height:132px;width:100%;object-fit:cover;border-radius:14px;border:1px solid var(--line)}
.info-footer{background:#020912;border-top:1px solid var(--line);padding:42px 24px}
.footer-grid{max-width:1240px;margin:auto;display:grid;grid-template-columns:1.4fr repeat(5,1fr);gap:26px;color:#c5d6e2;font-size:14px}
.footer-grid strong{display:block;color:#fff;margin-bottom:8px}
.floating{
  position:fixed;right:22px;bottom:22px;z-index:90;display:flex;flex-direction:column;gap:10px
}
.floating a{
  width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:#fff;color:#03101b;font-weight:900;box-shadow:0 16px 34px rgba(0,0,0,.35)
}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:200;display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.show{display:flex}
.lightbox img{max-height:86vh;max-width:92vw;border-radius:16px}
.close{position:absolute;right:24px;top:18px;background:none;border:0;color:white;font-size:44px;cursor:pointer}
@media(max-width:900px){
  .header-inner{padding:14px 18px}
  .menu-btn{display:block}
  .nav{
    position:fixed;top:74px;left:14px;right:14px;display:none;flex-direction:column;align-items:stretch;
    background:rgba(3,16,27,.96);border:1px solid var(--line);border-radius:18px;padding:18px
  }
  .nav.show{display:flex}
  .hero{min-height:680px;padding-top:130px}
  .layout-2,.location-grid,.instagram,.footer-grid{grid-template-columns:1fr}
  .price-grid,.course-grid,.contact-grid{grid-template-columns:1fr}
  .facility-grid{grid-template-columns:repeat(2,1fr)}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:560px){
  .section{padding:54px 18px}
  .hero h1{font-size:38px}
  .hero p{font-size:16px}
  .gallery-3,.facility-grid,.insta-grid{grid-template-columns:1fr}
  .gallery-3 img,.insta-grid img{height:190px}
  .rental-list{columns:1}
  .footer-grid{gap:18px}
}


/* Multi-page logo-only home */
.home-only {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 120px 24px 80px;
  background:
    radial-gradient(circle at center, rgba(14, 58, 88, .62), rgba(3, 16, 27, .92) 54%, #020811 100%),
    url("images/main-hero.jpg") center/cover no-repeat;
  position: relative;
}

.home-only::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.38);
}

.home-logo-wrap {
  position: relative;
  z-index: 1;
  text-align: center;
}

.home-logo-wrap img {
  width: min(420px, 78vw);
  max-height: 420px;
  object-fit: contain;
  filter: drop-shadow(0 28px 70px rgba(0,0,0,.55));
}

.home-logo-wrap p {
  margin: 28px 0 0;
  color: rgba(255,255,255,.78);
  font-size: 17px;
  letter-spacing: .12em;
}

.page-hero {
  padding: 150px 24px 70px;
  background:
    linear-gradient(90deg, rgba(0,5,12,.9), rgba(0,8,16,.55)),
    url("images/main-hero.jpg") center/cover no-repeat;
  border-bottom: 1px solid var(--line);
}

.page-hero .container {
  max-width: 1240px;
}

.page-hero h1 {
  margin: 0 0 8px;
  font-size: clamp(38px, 5vw, 58px);
  color: #ffffff !important;
  text-shadow: 0 3px 14px rgba(0,0,0,.55);
}

.page-hero p {
  margin: 0;
  color: rgba(255,255,255,.95) !important;
  text-transform: uppercase;
  letter-spacing: .14em;
  text-shadow: 0 2px 10px rgba(0,0,0,.55);
}

.subpage-main .section:first-child {
  border-top: 0;
}
.home-only {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 120px 24px 80px;

  background:
    linear-gradient(rgba(0,0,0,.25), rgba(0,0,0,.35)),
    url("images/main-hero.jpg") center center / cover no-repeat;

  position: relative;
}

.home-only::before {
  display: none;
}

.home-logo-wrap {
  position: relative;
  z-index: 1;
  text-align: center;
}

.home-logo-wrap img {
  display: none;
}

.home-logo-wrap p {
  display: none;
}
/* ===== WHITE RESORT STYLE ===== */

:root{
  --bg:#f8fafc;
  --text:#0f172a;
  --muted:#475569;
  --accent:#0284c7;
  --line:#dbeafe;
}

body{
  background:#f8fafc;
  color:#0f172a;
}

.header{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid #dbeafe;
}

.header.scrolled{
  background:rgba(255,255,255,.96);
}

.nav a{
  color:#0f172a;
}

.brand{
  color:#0f172a;
}

.brand small{
  color:#64748b;
}

.nav .book{
  background:#0284c7;
  color:white;
  border:none;
}

.home-only{
  min-height:100vh;

  background:
  linear-gradient(
    rgba(255,255,255,.15),
    rgba(255,255,255,.35)
  ),
  url("images/main-hero.jpg")
  center center / cover no-repeat;
}

.card{
  background:white;
  border:1px solid #dbeafe;
  box-shadow:
  0 10px 30px rgba(0,0,0,.06);
}

.info-footer{
  background:white;
  border-top:1px solid #dbeafe;
}

.footer-grid{
  color:#475569;
}

.footer-grid strong{
  color:#0f172a;
}
.home-feature {
  padding: 140px 24px 160px;
  background: linear-gradient(180deg, #03101b 0%, #061b2b 100%);
  color: white;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.08);
}

.feature-label {
  margin: 0 0 14px;
  font-size: 12px;
  letter-spacing: .18em;
  color: rgba(255,255,255,.35);
}

.home-feature h2 {
  margin: 0;
  font-size: 54px;
  font-weight: 700;
  letter-spacing: -1px;
}

.feature-line {
  width: 48px;
  height: 1px;
  margin: 28px auto 50px;
  background: rgba(255,255,255,.55);
}

.feature-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 34px;
}

.feature-item {
  color: white;
}

.feature-icon {
  height: 52px;
  margin-bottom: 20px;
  font-size: 64px;
  color: white;
  opacity: .9;
}

.feature-item h3 {
  margin: 0 0 12px;
  font-size: 24px;
  color: white;
}

.feature-item p {
  margin: 0;
  font-size: 17px;
  line-height: 1.8;
  color: rgba(255,255,255,.72);
}

@media (max-width: 760px) {
  .feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 420px) {
  .feature-grid {
    grid-template-columns: 1fr;
  }
}



/* =========================================================
   FINAL OVERRIDE - WHITE RESORT STYLE / TEXT FIX
   ========================================================= */

:root{
  --bg:#f8fafc;
  --bg2:#eef6fb;
  --card:#ffffff;
  --card2:#f8fafc;
  --line:#dbeafe;
  --text:#0f172a;
  --muted:#475569;
  --soft:#e0f2fe;
  --accent:#0284c7;
  --gold:#0284c7;
  --shadow:0 14px 38px rgba(15,23,42,.08);
}

body{
  background:#f8fafc !important;
  color:#0f172a !important;
}

.header{
  background:rgba(255,255,255,.9) !important;
  backdrop-filter:blur(18px);
  border-bottom:1px solid #dbeafe !important;
}

.header.scrolled{
  background:rgba(255,255,255,.97) !important;
}

.brand,
.nav a{
  color:#0f172a !important;
}

.brand small{
  color:#64748b !important;
}

.nav .book{
  background:#0284c7 !important;
  color:#ffffff !important;
  border:none !important;
}

.nav .book:hover{
  background:#0369a1 !important;
}

.home-only{
  min-height:100vh !important;
  padding:120px 24px 80px !important;
  background:
    linear-gradient(
      rgba(255,255,255,.10),
      rgba(255,255,255,.28)
    ),
    url("images/main-hero.jpg") center center / cover no-repeat !important;
  position:relative;
}

.home-only::before{
  display:none !important;
}

.home-logo-wrap,
.home-logo-wrap img,
.home-logo-wrap p{
  display:none !important;
}

.home-feature{
  padding:90px 24px 100px !important;
  background:
    linear-gradient(
      180deg,
      #f8fafc 0%,
      #eef6fb 100%
    ) !important;
  color:#0f172a !important;
  text-align:center;
  border-top:1px solid #dbeafe !important;
}

.feature-label{
  margin:0 0 14px;
  font-size:12px;
  letter-spacing:.18em;
  color:#64748b !important;
}

.home-feature h2{
  margin:0;
  font-size:32px;
  font-weight:600;
  letter-spacing:-1px;
  color:#0f172a !important;
}

.feature-line{
  width:48px;
  height:2px;
  margin:28px auto 50px;
  background:#0284c7 !important;
  border-radius:999px;
}

.feature-grid{
  max-width:900px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:34px;
}

.feature-item,
.feature-item h3{
  color:#0f172a !important;
}

.feature-icon{
  height:52px;
  margin-bottom:20px;
  font-size:34px;
  color:#0284c7 !important;
  opacity:1;
}

.feature-item h3{
  margin:0 0 12px;
  font-size:16px;
}

.feature-item p{
  margin:0;
  font-size:13px;
  line-height:1.7;
  color:#64748b !important;
}

.section{
  background:#f8fafc !important;
  border-top:1px solid #dbeafe !important;
}

.section-title h2{
  color:#0f172a !important;
}

.section-title span{
  color:#64748b !important;
}

.card{
  background:#ffffff !important;
  border:1px solid #dbeafe !important;
  box-shadow:0 14px 38px rgba(15,23,42,.08) !important;
}

.card,
.card h3,
.card h4,
.card p,
.card span,
.card strong,
.price-row,
.price-row span,
.price-row strong,
.rental-list,
.rental-list li,
.location-text,
.location-text strong{
  color:#0f172a !important;
}

.note,
.contact-card p{
  color:#475569 !important;
}

.price-row{
  border-top:1px solid #e2e8f0 !important;
}

.price-row:first-of-type{
  border-top:0 !important;
}

.course-card h3{
  background:#f8fafc !important;
  color:#0f172a !important;
}

.course-card p{
  color:#334155 !important;
}

.facility-card p{
  background:#ffffff !important;
  color:#0f172a !important;
}

.contact-card{
  background:#ffffff !important;
}

.contact-icon{
  color:#0284c7 !important;
}

.map-card{
  background:#ffffff !important;
  border:1px solid #dbeafe !important;
}

.map-placeholder{
  background:linear-gradient(135deg,#e0f2fe,#bae6fd) !important;
  color:#0f172a !important;
}

.btn{
  border:1px solid #bae6fd !important;
  background:#ffffff !important;
  color:#0f172a !important;
}

.btn.primary,
.btn.gold{
  background:#0284c7 !important;
  border-color:#0284c7 !important;
  color:#ffffff !important;
}

.info-footer{
  background:#eef6fb !important;
  border-top:1px solid #dbeafe !important;
}

.footer-grid{
  color:#475569 !important;
}

.footer-grid strong{
  color:#0f172a !important;
}

.floating a{
  background:#0284c7 !important;
  color:#ffffff !important;
}

@media (max-width:900px){
  .nav{
    background:rgba(255,255,255,.97) !important;
    border:1px solid #dbeafe !important;
  }
}

@media (max-width:760px){
  .feature-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:420px){
  .feature-grid{
    grid-template-columns:1fr;
  }
}
.instagram-section {
  padding: 100px 24px;
  background: #ffffff;
  text-align: center;
}

.instagram-section h2 {
  margin: 0;
  font-size: 42px;
  color: #0f172a;
}

.instagram-grid {
  max-width: 1100px;
  margin: 50px auto 36px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.instagram-grid a {
  display: block;
  overflow: hidden;
  border-radius: 18px;
  box-shadow: 0 14px 38px rgba(15,23,42,.10);
}

.instagram-grid img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  transition: .3s;
}

.instagram-grid a:hover img {
  transform: scale(1.06);
}

.instagram-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 24px;
  border-radius: 999px;
  background: #0284c7;
  color: white;
  font-weight: 800;
}

@media (max-width: 760px) {
  .instagram-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .instagram-section h2 {
    font-size: 32px;
  }
}


/* =========================================================
   PRICE PAGE - FINAL CLEAN STYLE
   가격안내 페이지 전용 최종 CSS
   ========================================================= */

.price-section{
  padding:90px 24px 100px;
  background:linear-gradient(180deg,#ffffff 0%,#f5f9fc 100%);
}

.price-title{
  max-width:1400px;
  margin:0 auto 55px;
}

.price-title p{
  margin:0 0 14px;
  color:#008bd2;
  font-size:13px;
  letter-spacing:5px;
  font-weight:800;
}

.price-title h2{
  margin:0 0 16px;
  color:#071a35;
  font-size:48px;
  font-weight:800;
  letter-spacing:-.04em;
}

.price-title span{
  color:#4b5b6b;
  font-size:17px;
}

/* 가격 카드 4개 */
.price-card-wrap{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:50px 60px;
  align-items:start;
}

.price-card{
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 18px 45px rgba(0,45,90,.08);
}

.price-card-head{
  min-height:88px;
  padding:18px 14px;
  background:linear-gradient(135deg,#061c4d,#003382);
  color:#ffffff;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  text-align:center;
}

.price-card-head span{
  font-size:30px;
  line-height:1;
  flex-shrink:0;
}

.price-card-head h3{
  margin:0;
  color:#ffffff;
  font-size:21px;
  font-weight:800;
  line-height:1.25;
  word-break:keep-all;
}

/* 금액 줄림 방지 */
.price-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:20px 22px;
  border-top:0 !important;
  border-bottom:1px solid #dce6ef;
  color:#061c4d !important;
}

.price-row:last-child{
  border-bottom:none;
}

.price-row strong{
  color:#061c4d !important;
  font-size:17px;
  font-weight:800;
  white-space:nowrap;
  letter-spacing:-.04em;
}

.price-row b{
  color:#061c4d !important;
  font-size:18px;
  font-weight:900;
  white-space:nowrap;
  flex-shrink:0;
  letter-spacing:-.04em;
}

.price-note{
  margin:0;
  padding:12px 22px 20px;
  color:#061c4d;
  font-size:14px;
  font-weight:800;
}

/* 교육과정 포함사항 */
.price-info-box{
  max-width:1400px;
  margin:34px auto 0;
  padding:30px 34px;
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:20px;
  box-shadow:0 14px 35px rgba(0,45,90,.06);
  display:flex;
  gap:24px;
  color:#061c4d;
}

.info-icon{
  color:#008bd2;
  font-size:34px;
  line-height:1;
  flex-shrink:0;
}

.price-info-box h3{
  margin:0 0 12px;
  color:#061c4d;
  font-size:22px;
  font-weight:900;
}

.price-info-box p{
  margin:6px 0;
  color:#334155;
  font-size:15px;
  line-height:1.7;
}

/* 개별 장비렌탈 */
.rental-info-box{
  max-width:1400px;
  margin:24px auto 0;
  padding:24px 34px;
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:20px;
  box-shadow:0 14px 35px rgba(0,45,90,.06);
  display:grid;
  grid-template-columns:180px 170px 1fr 1fr 1fr 1fr;
  align-items:center;
  gap:18px;
  color:#061c4d;
}

.rental-info-box strong{
  color:#061c4d;
  font-size:21px;
  font-weight:900;
  white-space:nowrap;
}

.rental-info-box span{
  color:#334155;
  font-size:15px;
  line-height:1.5;
  white-space:nowrap;
}

.rental-info-box span b{
  color:#0284c7;
  font-weight:900;
}

/* 태블릿 */
@media (max-width:1200px){
  .price-card-wrap{
    grid-template-columns:repeat(2,1fr);
  }

  .rental-info-box{
    grid-template-columns:repeat(2,1fr);
  }
}

/* 모바일 */
@media (max-width:768px){
  .price-section{
    padding:70px 18px 80px;
  }

  .price-title{
    margin-bottom:36px;
  }

  .price-title h2{
    font-size:38px;
  }

  .price-title span{
    font-size:15px;
  }

  .price-card-wrap{
    grid-template-columns:1fr;
    gap:20px;
  }

  .price-card-head h3{
    font-size:20px;
  }

  .price-row{
    padding:19px 20px;
  }

  .price-row strong{
    font-size:16px;
  }

  .price-row b{
    font-size:17px;
  }

  .price-info-box{
    flex-direction:column;
    padding:26px 24px;
  }

  .rental-info-box{
    grid-template-columns:1fr;
    padding:24px;
    gap:12px;
  }
}

/* 아주 작은 화면 */
@media (max-width:380px){
  .price-row{
    padding:18px 16px;
  }

  .price-row strong{
    font-size:15px;
  }

  .price-row b{
    font-size:16px;
  }
}
.price-card{
  min-height:300px;
  display:flex;
  flex-direction:column;
}
/* 모바일 햄버거 메뉴 검정색 */

.menu-btn{
  color:#111827 !important;
  border:1px solid #dbeafe !important;
  background:#ffffff !important;
}

.menu-btn:hover{
  background:#f8fafc !important;
}


/* =========================================================
   MENU / FUNDIVE / POINT PAGE ADDITIONS
   ========================================================= */

.nav{
  gap:22px !important;
  font-size:14px !important;
}

.header-inner{
  max-width:1320px !important;
}

.sub-title-block{
  margin:0 0 38px;
  text-align:center;
}

.sub-title-block p{
  margin:0 0 12px;
  color:#0284c7;
  font-size:13px;
  letter-spacing:4px;
  font-weight:900;
}

.sub-title-block h2{
  margin:0 0 14px;
  color:#071a35;
  font-size:38px;
  font-weight:900;
  letter-spacing:-.05em;
}

.sub-title-block span{
  color:#475569;
  font-size:16px;
  line-height:1.7;
}

.dive-page-section,
.point-page-section{
  padding:90px 24px 110px;
  background:linear-gradient(180deg,#ffffff 0%,#f5f9fc 100%);
}

.fun-info-card{
  max-width:1200px;
  margin:0 auto 34px;
  padding:24px 30px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:22px;
  box-shadow:0 14px 35px rgba(0,45,90,.06);
}

.fun-info-card strong{
  display:block;
  margin-bottom:8px;
  color:#061c4d;
  font-size:17px;
  font-weight:900;
}

.fun-info-card p{
  margin:0;
  color:#475569;
  font-size:14px;
  line-height:1.6;
}

.dive-gallery-grid{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.dive-gallery-card{
  overflow:hidden;
  border-radius:20px;
  background:#ffffff;
  border:1px solid #d7e6f5;
  box-shadow:0 14px 35px rgba(0,45,90,.07);
  cursor:pointer;
}

.dive-gallery-card img{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  transition:.3s;
}

.dive-gallery-card:hover img{
  transform:scale(1.06);
}

.point-main-card{
  max-width:1200px;
  margin:0 auto;
  overflow:hidden;
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:26px;
  box-shadow:0 18px 45px rgba(0,45,90,.08);
}

.point-main-card img{
  width:100%;
  height:auto;
  max-height:none;
  object-fit:contain;
  cursor:pointer;
}

.point-main-text{
  padding:26px 30px;
}

.point-main-text strong{
  display:block;
  margin-bottom:10px;
  color:#061c4d;
  font-size:22px;
  font-weight:900;
}

.point-main-text p{
  margin:0;
  color:#475569;
  font-size:15px;
  line-height:1.8;
}

.point-info-grid{
  max-width:1200px;
  margin:26px auto 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.point-info-card{
  padding:26px;
  background:#ffffff;
  border:1px solid #d7e6f5;
  border-radius:22px;
  box-shadow:0 14px 35px rgba(0,45,90,.06);
}

.point-info-card h3{
  margin:0 0 12px;
  color:#061c4d;
  font-size:20px;
}

.point-info-card p{
  margin:0;
  color:#475569;
  font-size:15px;
  line-height:1.8;
}

@media(max-width:1100px){
  .nav{
    gap:14px !important;
    font-size:13px !important;
  }

  .brand{
    font-size:18px !important;
  }
}

@media(max-width:900px){
  .nav{
    gap:18px !important;
    font-size:15px !important;
  }

  .fun-info-card,
  .point-info-grid{
    grid-template-columns:1fr;
  }

  .dive-gallery-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:560px){
  .sub-title-block h2{
    font-size:28px;
  }

  .dive-page-section,
  .point-page-section{
    padding:70px 18px 80px;
  }

  .dive-gallery-grid{
    grid-template-columns:1fr;
  }
}
.naver-map {
  width: 100%;
  height: 320px;
  border-radius: 18px 18px 0 0;
  overflow: hidden;
}
/* 오시는길 안내 카드 */

.location-guide {
  display: grid;
  gap: 22px;
}

.guide-item {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  padding: 22px 24px;
  background: #ffffff;
  border: 1px solid #dbeafe;
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .06);
}

.guide-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #e0f2fe;
  color: #0284c7;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}

.guide-item h3 {
  margin: 0 0 8px;
  color: #075985;
  font-size: 19px;
  font-weight: 900;
}

.guide-item p {
  margin: 0;
  color: #334155;
  font-size: 15px;
  line-height: 1.8;
}

/* 모바일 */
@media (max-width: 768px) {
  .guide-item {
    padding: 20px;
  }

  .guide-item h3 {
    font-size: 18px;
  }

  .guide-item p {
    font-size: 14px;
  }
}
.contact-img {
  width: 70px;
  height: 70px;
  object-fit: contain;
  display: block;
  margin: 0 auto 15px;
}


/* =========================================================
   FINAL MOBILE / CLEAN FIX - 2026-06-24
   메인 모바일 큰 여백 제거 + 모바일 메뉴 안정화
   ========================================================= */

@media (max-width: 768px) {
  .home-only {
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    aspect-ratio: 16 / 9 !important;
    background-size: contain !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
  }

  .home-feature {
    padding-top: 56px !important;
    padding-bottom: 70px !important;
  }

  .instagram-section {
    padding: 64px 18px !important;
  }

  .floating {
    right: 16px !important;
    bottom: 18px !important;
  }

  .floating a {
    width: 58px !important;
    height: 58px !important;
  }
}

@media (max-width: 420px) {
  .brand {
    font-size: 20px !important;
    gap: 10px !important;
  }

  .brand img {
    width: 54px !important;
    height: 54px !important;
  }

  .header-inner {
    padding: 14px 16px !important;
  }

  .menu-btn {
    font-size: 26px !important;
    padding: 12px 15px !important;
  }
}
/* 모바일 메인 이미지 상단 가림 수정 */
@media (max-width: 768px) {
  .header {
    position: sticky !important;
    top: 0 !important;
  }

  .home-only {
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    aspect-ratio: 16 / 9 !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
  }
}
.seo-text{
  max-width:900px;
  margin:40px auto;
  text-align:center;
}

.seo-text h2{
  color:#0f172a;
  font-size:32px;
  margin-bottom:16px;
}

.seo-text p{
  color:#475569;
  line-height:1.8;
}