/* pages.css */
@layer reset, tokens, base, pages;

@layer pages {
    :root { 
        --bg-gif: url("../image/gradient.gif"); 
		--shadow-lg: 0 10px 30px rgba(17, 29, 53, 0.2);
        --shadow-md: 0 6px 18px rgba(17, 29, 53, .15);
		--card-bg: #fff;
        --input-bg: #F5F4F9;
        --gutter-sm : 30px;
		--fs-title: clamp(27px, 3.2vw, 34px);
        --fs-lead: clamp(16px, 1.8vw, 18px);
		--input-h:50px;
		--container-w-login:360px;
		--container-w-sm:430px;
		--header-min-h: 240px; 

		--chip-bg: #f3f4f6;
		--chip-bd: #d1d5db;
		--chip-text: #111827;
		--chip-on-bg: #6551A9;
		--chip-on-text: #fff;
		--focus-chip: 0 0 0 3px rgba(99,102,241,.35);
    }
    
	.header-floating{height:var(--header-h-mobile); display:flex; align-items:center;}

    /* ==========================================================================
    intro
    =========================================================================== */
   .intro{height:100vh; background: var(--bg-gif) lightgray 50% / cover no-repeat; display:flex; align-items:center; justify-content:center;}
   .intro .inner-container{text-align:center;}
   .intro .inner-container h1{display:inline-block;}
   .intro .inner-container h3{color:#fff;}

   /* ==========================================================================
    login
    =========================================================================== */
	.login{min-height:100svh; background: var(--bg-gif) lightgray 50% / cover no-repeat;position:relative; display: flex; flex-direction: column;}
	.login .hero {
        position: relative;
		color: #fff;
		padding-top: max(24px, calc(env(safe-area-inset-top) + 12px)); /* iOS 상단 노치: 안전 영역만큼 여백 주기 */
		padding-bottom: clamp(20px, 10svh, 30px);
		min-height: 42svh; /* 모바일에서 주소창 고려 svh */
		display: grid;
		align-items: end; /* 아래 정렬로 자연스러운 시선 */
		min-height: clamp(180px, 38svh, 360px);
    }
	@supports (height: 100dvh) {
        .login .hero { min-height:30dvh; }
    }
	.login .hero .inner {
        padding-block: clamp(24px, 4svh, 40px);
        text-align: center;
    }
	.eyebrow{display: inline-block; font-size:13px; letter-spacing: .08em; font-weight: 700; text-transform: uppercase; font-family:var(--font-sans-eng);opacity: .9; padding: 6px 10px; border-radius: 999px; background: rgba(255,255,255,.12); backdrop-filter: blur(6px); margin-bottom:18px;}
	.login .title{font-weight:600; font-size: var(--fs-title);  margin: 0 0 10px; text-shadow: 0 2px 10px rgba(0,0,0,.25);}

	.login .card-wrap {
	    flex: 1;
		display: flex;
		z-index: 1;
    }
    .login .card {
	    display:grid;
		align-content: center;
	    flex: 1;
		min-height: 0;
		overflow: auto;
        background: var(--card-bg);
        box-shadow: var(--shadow-lg);
        padding: clamp(10px, 4vw, 20px);
        border: 1px solid rgba(0,0,0,.04);
		border-radius: 50px 50px 0 0;
		box-shadow: 0 -8px 12.2px 0 rgba(0, 0, 0, 0.25);
    }
	.login .form-box{width: min(100% - calc(var(--gutter-sm) * 1), var(--container-w-login)); margin:30px auto;}
    .form-row{padding:0}

	.btn-submit{height:var(--input-h); border-radius:var(--radius); border: 1px solid rgba(86, 40, 237, 0.5); background: linear-gradient(268deg, #299EFC 5.13%, #774EFC 94.87%); box-shadow: 0 0 7.5px 0 rgba(45, 21, 121, 0.73); text-shadow: 0 0 4px rgba(0, 0, 0, 0.45); width:100%; color:#fff; cursor: pointer; font-family:var(--font-sans-eng); font-weight:700; font-size:18px;}
	.btn-big{display:block; height:var(--input-h); border-radius:var(--radius); border: 1px solid rgba(86, 40, 237, 0.5); background: linear-gradient(268deg, #299EFC 5.13%, #774EFC 94.87%); box-shadow: 0 0 7.5px 0 rgba(45, 21, 121, 0.73); text-shadow: 0 0 4px rgba(0, 0, 0, 0.45); width:100%; color:#fff; cursor: pointer; font-family:var(--font-sans-eng); font-weight:600; font-size:17px; /*display:grid; align-items:center; place-content:center;*/ text-align:center; }

	.login .divider{display:grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 14px; margin:30px 0 20px; color:#707070}
	.login .divider::before, 
	.login .divider::after{content: "";height: 1px; background:currentColor; opacity: .25;}
	.login .socials{display:flex; gap:5px; justify-content:center;}

	.login .signup{text-align:center; margin-top:var(--space-4); color:#707070}
	.login .signup a{color:#FC4EF9; font-weight:700;}
	
	.login #submitBtn { display:inline-block; width:100%; height:100%; line-height:var(--input-h); }

	.login .find{display:flex; margin-top:var(--space-4); align-items:center; justify-content:center; gap:15px}
	.login .find a{font-size:15px; color:#707070; letter-spacing:-1.2px}
	.login .find a:first-child{position:relative; padding-right:15px;}
	/*
	.login .find a:first-child:after{position:absolute; content:""; width:1px; height:50%; background:#ddd; top:7px; right:0;}
	*/

	.input-group{position:relative; margin-bottom:var(--space-4)}
	.input-group span{position:absolute; width:50px; left:0; top:50%; text-align:center; transform:translateY(-40%)}
	.input-group input[type="text"],
	.input-group input[type="tel"],
	.input-group input[type="number"],
	.input-group input[type="email"],
	.input-group input[type="password"],
	.input-group .select{height:var(--input-h); border:1px solid var(--border-1); border-radius:var(--radius); background:var(--input-bg); padding:0 16px  0 50px; color:var(--text); width:100%; font-weight:500; font-size:15px;}
	.input-group .select{padding-right: 28px; padding-left:16px; color:var(--text);
    background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 10l5 5 5-5' stroke='%23A9B1C7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 8px center; background-size: 16px 16px; color:#434343}
	.input-group .label{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}
	.input-group h3{font-size:16px; color:#434343;padding-left:5px}

	.check-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:6px; margin-bottom:var(--space-8)}
	.chip{
       position: relative;
       display: inline-grid;
       grid-auto-flow: column;
       align-items: stretch;     /* ← center → stretch */
       justify-items: stretch;  
       gap:8px;
       height:42px;
       text-align:center;
       border-radius:10px;
       border:1px solid var(--chip-bd);
       background:var(--chip-bg);
       color:var(--chip-text);
       cursor:pointer;
       user-select:none;
       transition: background .2s ease, color .2s ease, border-color .2s ease;
    }
    .chip:hover{ border-color:#9ca3af; }
    .chip:has(input:focus-visible){ box-shadow: var(--focus-chip); outline:0;}
    .chip input{
      position:absolute; 
	  inset:0;
      width:100%; 
	  height:100%;
      opacity:0; 
	  margin:0; 
	  cursor:pointer;
	  border:3px solid red;
    }
    .chip input:checked + mark{
      background: var(--chip-on-bg);
      color: var(--chip-on-text);
      box-shadow: inset 0 0 0 1px var(--chip-on-bd);
    }
    .chip mark{
      display:block;
      padding: 8px 12px; 
      border-radius:8px;
      transition: inherit;
	  width:100%;
	  height:100%;
	  background:transparent;
	  font-size:15px;
	  color:var(--chip-text)
    }
    .chip[aria-disabled="true"]{
      opacity:.45; cursor:not-allowed;
    }
	.status{font-size:14px; margin:var(--space-1) 0 var(--space-4) 0; padding-left:5px; color:#707070}
	.status strong{color:var(--brand)}

	.grid-align{margin-bottom:var(--space-8)}
	.grid-align .box{display:flex; align-items:center;}
	.grid-align .box + .box{margin-left:auto}
	.grid-align .check_sm{transform:translateY(-8px); margin-left:10px}
 
    /* ==========================================================================
    비밀번호 찾기
    =========================================================================== */
    .login .find-box{display:grid; grid-template-rows:70px 1fr; align-items: stretch; height:100vh;}

	@supports (-webkit-touch-callout: none) {
		/* CSS specific to iOS devices */ 
		.login .find-box { padding-top:env(safe-area-inset-top, 0); }
	}

	.login .find-box .content-box{position:relative;  background: var(--card-bg); padding: clamp(10px, 4vw, 20px); border: 1px solid rgba(0,0,0,.04);border-radius: 50px 50px 0 0; box-shadow: 0 -8px 12.2px 0 rgba(0, 0, 0, 0.25);} 
	.login .sub-header-content { padding-bottom: 30px; color:#fff; text-align:center;}
    .login .inner_title h2{font-size:22px; margin-bottom:var(--space-4)}
	.login .inner_title p{color:#707070; font-size:15px; margin-bottom:var(--space-8)}
	.login .content-box input[type="text"],
	.login .content-box input[type="tel"],
	.login .content-box input[type="email"],
	.login .content-box input[type="number"],
	.login .content-box input[type="password"]{padding:0 16px !important}

	.login .content-box .find a{margin-left:auto; color:#548ECA; padding-right:0;}
	/*
	.login .content-box .find a:after{width:100%; height:1px; background:#548ECA; top:auto; bottom:0; left:0; right:auto}
	*/
	
	.login .content-box button{position:absolute; bottom:30px; left:50%; transform:translateX(-50%); width: min(100% - calc(var(--gutter-sm) * 1), var(--container-w-login)); font-weight:500; font-size:var(--font-size)}

	.join-btn-submit{position:static !important; margin:0 auto; bottom:auto !important; left:auto !important; transform:translateX(0) !important; width:100% !important;}

	 /* ==========================================================================
    메인
	=================================================== */
	.main{background:linear-gradient(180deg, #F3F0FF 0%, #EBE5FF 100%);}
	.main-header{border-radius: 0 0 50px 50px; background:var(--bg-gif); background-size:cover; box-shadow: 0 -8px 12.2px 0 rgba(0, 0, 0, 0.25); height:280px; display:grid; grid-template-rows:55px 1fr;}

	@supports (-webkit-touch-callout: none) {
		/* CSS specific to iOS devices */ 
		.main-header { padding-top:env(safe-area-inset-top, 0); }
	}

	.main-header .main-header-content{padding:0px 30px 30px 30px; display:flex; flex-direction: column; justify-content:center; text-align:center;}
	.main-header .main-header-content > h2,
	.main-header .main-header-content > p{color:#fff}
	.main-header .main-header-content > h2{margin-bottom:var(--space-4)}
	.main-header .main-header-content > p{font-size:17px; margin-bottom:var(--space-6)}

	.main-header .outbox{border-radius:70px; background: rgba(0, 0, 0, 0.37); gap:2px; display:grid; grid-template-columns : 1fr 1fr; padding:15px; position:relative;}
	.main-header .outbox a{display:block; border-radius: 25px; box-shadow: 0 0 5.5px 0 rgba(45, 21, 121, 0.73); color:#222;  padding:10px 5px; background: #FFF; text-align:center; font-weight:600; font-size:17px}
	.main-header .outbox .stamp a{background: #200C20; padding:10px 5px; color:#fff; padding-left:15px; box-shadow: 0 0 10.2px 0 #E853FF;}
    .main-header .outbox .stamp span{position:absolute; width:95px; left:-37px; top:-15px;}
    
	.stampbox{height:calc(100% - 280px);}
    .loadbox{position: relative; height:100%; display:flex; align-items:center; justify-content:center; justify-content:center;}
    .loadbox .icon{ height:100%; width:134px; display: block;}

	.stamps{display:flex; position:absolute ;align-items:flex-end; gap:20px; z-index:2;  justify-content:flex-end;}
	.stamps .stamp-circle{flex-shrink:0; width:120px; height:120px; border-radius:100px; aspect-ratio: 1/1; background:#fff; }
	.stamps .text{position: relative; width:100%;}
	.stamps .text h2{position: relative; font-size:19px; font-weight:500; color:#fff; border-radius:100px;  min-width:80px; padding:8px 20px 8px 50px; text-align:center; transform:translateY(-20px)}
	.stamps .text span{position:absolute; font-size:15px; color:#707070; width:100%;  text-align:center; top:30px}
    
	.stamps.cooking{top:50px; left:50%; transform:translateX(-32%)}
	.stamps.cooking .stamp-circle{border:1px solid rgba(86, 40, 237, 0.58); box-shadow:0 0 7px rgba(243, 105, 255, 0.53);}
	.stamps.cooking .text h2{background: #774EFC;}
	.stamps.cooking .text h2:after{position:absolute; content:""; background:url(../image/img1.png) no-repeat; width:90px; height:90px; background-size:90px; left:-45px; top:-25px}

	.stamps.culture{top:230px; left:50%; transform:translateX(-60%)}
	.stamps.culture .stamp-circle{border:1px solid rgba(28, 254, 242, 0.71); box-shadow:0 0 7px rgba(35,163,157,0.53);}
	.stamps.culture .text h2{background: #23A39D; padding:8px 50px 8px 20px}
	.stamps.culture .text h2:after{position:absolute; content:""; background:url(../image/img2.png) no-repeat; width:90px; height:90px; background-size:90px; right:-45px; top:-25px}

	.stamps.learning{top:420px; left:50%; transform:translateX(-50%)}
	.stamps.learning .stamp-circle{border:1px solid rgba(243, 105, 255, 0.53); box-shadow:0 0 7px rgba(243, 105, 255, 0.53);}
	.stamps.learning .text h2{background: #D050CE;}
	.stamps.learning .text h2:after{position:absolute; content:""; background:url(../image/img3.png) no-repeat; width:90px; height:90px; background-size:90px; left:-45px; top:-35px}

	.stamps .stamp-circle-active{background:#200C20 !important}

	/* 스탬프 획득 애니메이션 효과 */
	.stamp-animation-overlay {
		position: fixed;
		top: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
		background: rgba(0, 0, 0, 0.8);
		z-index: 1000;
		display: flex;
		align-items: center;
		justify-content: center;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.3s ease;
		will-change: opacity;
		transform: translateZ(0);
	}

	.stamp-animation-overlay.active {
		opacity: 1;
		visibility: visible;
	}

	.stamp-large-image {
		width: 80vw;
		height: 80vw;
		max-width: 400px;
		max-height: 400px;
		border-radius: 50%;
		background: #fff;
		display: flex;
		align-items: center;
		justify-content: center;
		position: relative;
		opacity: 0.3;
		transform: scale(2);
		box-shadow: 0 0 50px rgba(255, 255, 255, 0.3);
		will-change: transform, opacity, filter;
		backface-visibility: hidden;
		-webkit-font-smoothing: antialiased;
	}

	/* 내부 이미지를 두 겹으로 사용: 흐림(고정) + 선명(크로스페이드) */
	.stamp-large-image img { 
		position:absolute; 
		inset:0; 
		margin:auto; 
		width:95%; 
		height:95%; 
		object-fit:cover; 
		border-radius: 50%;
	}
	.stamp-large-image .img-blur { filter: blur(18px); opacity: 1; }
	.stamp-large-image .img-sharp { opacity: 0; }

	/* 활성화 시 애니메이션을 클래스 기반으로 트리거 */
	.stamp-animation-overlay.active .stamp-large-image.animating { animation: scaleDownLinear 1.4s linear forwards; }
	.stamp-animation-overlay.active .stamp-large-image.animating .img-blur { animation: blurFadeOut 0.9s linear forwards; }
	.stamp-animation-overlay.active .stamp-large-image.animating .img-sharp { animation: sharpFadeIn 0.9s linear 0.15s forwards; }

	/* 컨테이너의 선형 축소만 수행, 블러는 애니메이션하지 않음 */
	@keyframes scaleDownLinear {
		0%   { transform: scale(2.2); opacity: 0.3; }
		100% { transform: scale(1.0); opacity: 1; }
	}

	/* 흐린 이미지가 서서히 사라짐 */
	@keyframes blurFadeOut {
		0%   { opacity: 1; }
		100% { opacity: 0; }
	}

	/* 선명한 이미지가 서서히 나타남 */
	@keyframes sharpFadeIn {
		0%   { opacity: 0; }
		100% { opacity: 1; }
	}

	/* 파티클 효과 */
	.particles {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		pointer-events: none;
		z-index: 1001;
	}

	.particle {
		position: absolute;
		width: 6px;
		height: 6px;
		background: #FFD700;
		border-radius: 50%;
		animation: particleFloat 2.5s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
		opacity: 0;
	}

	@keyframes particleFloat {
		0% {
			opacity: 0;
			transform: translate(0, 0) scale(0) rotate(0deg);
		}
		10% {
			opacity: 0.8;
			transform: translate(calc(var(--random-x) * 0.2), calc(var(--random-y) * 0.2)) scale(0.5) rotate(45deg);
		}
		25% {
			opacity: 1;
			transform: translate(calc(var(--random-x) * 0.5), calc(var(--random-y) * 0.5)) scale(1) rotate(90deg);
		}
		50% {
			opacity: 1;
			transform: translate(var(--random-x), var(--random-y)) scale(1.2) rotate(180deg);
		}
		70% {
			opacity: 0.8;
			transform: translate(calc(var(--random-x) * 1.5), calc(var(--random-y) * 1.5)) scale(0.8) rotate(270deg);
		}
		85% {
			opacity: 0.4;
			transform: translate(calc(var(--random-x) * 1.8), calc(var(--random-y) * 1.8)) scale(0.4) rotate(320deg);
		}
		100% {
			opacity: 0;
			transform: translate(calc(var(--random-x) * 2), calc(var(--random-y) * 2)) scale(0) rotate(360deg);
		}
	}

	/* 스탬프 원 클릭 애니메이션 */
	.stamp-circle {
		transition: all 0.3s ease;
		position: relative;
		overflow: hidden;
	}

	.stamp-circle.bouncing {
		animation: stampBounce 0.8s cubic-bezier(0.68, -0.55, 0.265, 1.55);
	}

	@keyframes stampBounce {
		0% { 
			transform: scale(1) rotate(0deg); 
		}
		15% { 
			transform: scale(1.15) rotate(2deg); 
		}
		30% { 
			transform: scale(1.25) rotate(0deg); 
		}
		45% { 
			transform: scale(0.92) rotate(-1deg); 
		}
		60% { 
			transform: scale(1.08) rotate(0.5deg); 
		}
		75% { 
			transform: scale(0.98) rotate(-0.3deg); 
		}
		85% { 
			transform: scale(1.03) rotate(0.2deg); 
		}
		95% { 
			transform: scale(0.99) rotate(0deg); 
		}
		100% { 
			transform: scale(1) rotate(0deg); 
		}
	}

	.stamp-circle-active {
		background: #200C20 !important;
		box-shadow: 0 0 20px rgba(232, 83, 255, 0.8) !important;
		animation: pulseGlow 2s infinite;
	}

	@keyframes pulseGlow {
		0% { box-shadow: 0 0 20px rgba(232, 83, 255, 0.8); }
		50% { box-shadow: 0 0 30px rgba(232, 83, 255, 1); }
		100% { box-shadow: 0 0 20px rgba(232, 83, 255, 0.8); }
	}

	/* 스탬프 타입별 색상 커스터마이징 */
	.stamp-animation-overlay.cooking .stamp-large-image {
		box-shadow: 0 0 50px rgba(119, 78, 252, 0.5);
	}

	.stamp-animation-overlay.culture .stamp-large-image {
		box-shadow: 0 0 50px rgba(35, 163, 157, 0.5);
	}

	.stamp-animation-overlay.learning .stamp-large-image {
		box-shadow: 0 0 50px rgba(208, 80, 206, 0.5);
	}

	/* 스탬프별 파티클 색상 */
	.particle.cooking {
		background: linear-gradient(45deg, #774EFC, #299EFC);
		box-shadow: 0 0 10px rgba(119, 78, 252, 0.7);
	}

	.particle.culture {
		background: linear-gradient(45deg, #23A39D, #1CFEF2);
		box-shadow: 0 0 10px rgba(35, 163, 157, 0.7);
	}

	.particle.learning {
		background: linear-gradient(45deg, #D050CE, #F369FF);
		box-shadow: 0 0 10px rgba(208, 80, 206, 0.7);
	}

	/* 성공 메시지 개선 */
	.stamp-success-message {
		position: absolute;
		top: 70%;
		left: 50%;
		transform: translate(-50%, -50%);
		background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(248, 249, 250, 0.9));
		padding: 20px 35px;
		border-radius: 20px;
		font-size: 20px;
		font-weight: 700;
		color: #333;
		box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2), 0 5px 15px rgba(0, 0, 0, 0.1);
		opacity: 0;
		animation: messageSlideIn 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 1.8s forwards;
		text-align: center;
		border: 2px solid rgba(255, 255, 255, 0.3);
		backdrop-filter: blur(10px);
	}

	/* 추가 글로우 효과 */
	.stamp-circle-active::before {
		content: '';
		position: absolute;
		top: -5px;
		left: -5px;
		right: -5px;
		bottom: -5px;
		border-radius: 50%;
		background: linear-gradient(45deg, transparent, rgba(232, 83, 255, 0.3), transparent);
		animation: rotateGlow 3s linear infinite;
		z-index: -1;
	}

	@keyframes rotateGlow {
		0% { transform: rotate(0deg); }
		100% { transform: rotate(360deg); }
	}

	/* 강제 애니메이션 키프레임 - 리니어 버전 */
	@keyframes stampBounceTest {
		0% { 
			transform: scale(2.5); 
			opacity: 0.2; 
			filter: blur(15px); 
		}
		100% { 
			transform: scale(1); 
			opacity: 1; 
			filter: blur(0px); 
		}
	}

	@keyframes messageSlideIn {
		0% {
			opacity: 0;
			transform: translate(-50%, -50%) translateY(20px);
		}
		100% {
			opacity: 1;
			transform: translate(-50%, -50%) translateY(0);
		}
	}

	/* 오버레이 종료 애니메이션 */
	@keyframes stampFadeOut {
		0% {
			transform: scale(1);
			opacity: 1;
		}
		50% {
			transform: scale(1.1) rotate(5deg);
			opacity: 0.8;
		}
		100% {
			transform: scale(0.3) rotate(15deg);
			opacity: 0;
		}
	}

	@keyframes messageSlideOut {
		0% {
			opacity: 1;
			transform: translate(-50%, -50%) translateY(0) scale(1);
		}
		100% {
			opacity: 0;
			transform: translate(-50%, -50%) translateY(-30px) scale(0.8);
		}
	}

	@keyframes fadeOut {
		0% {
			opacity: 1;
		}
		100% {
			opacity: 0;
		}
	}

	/* ==========================================================================
    서브
	=========================================================================== */
    .sub-header{background: linear-gradient(115deg, #6C46E6 39.38%, #29C4FC 114.25%); box-shadow: 0 -8px 12.2px 0 rgba(0, 0, 0, 0.25); height:160px; display:grid; grid-template-rows:55px 1fr;}

	.sub-header-content h2{color:#fff; text-align:center;}
	
	.sub-wrap{transform:translateY(-40px); padding-bottom:30px}

	@supports (-webkit-touch-callout: none) {
		/* CSS specific to iOS devices */ 
		.sub-header { padding-top:env(safe-area-inset-top, 0); height:calc(160px + env(safe-area-inset-top, 0)); }
	}

	.subbg-box{border-radius:25px; background: radial-gradient(84.75% 84.75% at 50.13% 18.64%, #2B0C51 39.58%, #131022 100%); box-shadow: 0 0 9.9px 0 rgba(0, 0, 0, 0.15); padding:20px 20px 30px 20px; margin-bottom:var(--space-4)}
	.subbg-box.inner-title{text-align:center; min-height:150px; display:flex; flex-direction: column; align-items:center; justify-content:center;}
	.subbg-box.inner-title > h3,
	.subbg-box.inner-title > p{color:#fff}
	.subbg-box.inner-title > h3{font-weight:500; margin-bottom:var(--space-2); margin-top:var(--space-2);}
	.subbg-box.inner-title > p{font-size:15px}

	.outline-box{border-radius:25px; background:#fff; box-shadow: 0 0 9.9px 0 rgba(0, 0, 0, 0.15); padding:35px 20px}
	.outline-box-demo{border-radius:25px; background:#fff; box-shadow: 0 0 9.9px 0 rgba(0, 0, 0, 0.15); padding:25px}

	/* =========================================================
	   Experience (체험관 소개) 커스텀 스타일
	   ======================================================= */
	.tourist-content{--accent:#774EFC; --accent2:#23A39D; --gradient:linear-gradient(115deg,#6C46E6 0%, #29C4FC 100%); font-size:15px; line-height:1.55; color:#333;}
	.tourist-content .experience-quote{margin:0 0 28px; text-align:center;}
	.tourist-content .experience-quote blockquote{margin:0; font-size:clamp(20px,4.5vw,28px); font-weight:600; letter-spacing:-.5px; background:var(--gradient); -webkit-background-clip:text; background-clip:text; color:transparent;}
	.tourist-content .experience-quote figcaption{margin-top:10px; font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.12em; color:#707070}
	.tourist-content .exp-section{margin-bottom:38px; position:relative;}
	.tourist-content .exp-section:last-of-type{margin-bottom:0}
	.tourist-content .exp-section h3{display:flex; align-items:center; gap:10px; font-size:17px; font-weight:700; margin:0 0 14px; color:#111}
	.tourist-content .exp-section h3 .num{display:inline-grid; place-content:center; width:30px; height:30px; border-radius:10px; background:#200C20; color:#E853FF; font-size:14px; font-weight:700; box-shadow:0 0 0 3px rgba(232,83,255,.35);}
	.tourist-content .exp-lead{margin:0 0 14px; font-weight:500; color:#222}
	.tourist-content .exp-list{list-style:none; padding:0; margin:0 0 14px; display:grid; gap:8px}
	.tourist-content .exp-list li{position:relative; padding-left:18px; line-height:1.5;}
	.tourist-content .exp-list li:before{content:""; position:absolute; left:4px; top:.6em; width:6px; height:6px; border-radius:50%; background:linear-gradient(135deg,#774EFC,#29C4FC)}
	.tourist-content .exp-list.check li:before{content:""; width:16px; height:16px; top:.35em; left:0; background:none; border-radius:4px; box-shadow:0 0 0 2px #774EFC inset;}
	.tourist-content .exp-list.check li{padding-left:24px;}
	.tourist-content .exp-list.check li:after{content:"✓"; position:absolute; left:4px; top:.15em; font-size:13px; color:#774EFC; font-weight:700}
	.tourist-content .exp-badges{display:flex; flex-wrap:wrap; gap:6px; margin:6px 0 4px}
	.tourist-content .badge{display:inline-block; padding:6px 10px; background:#f3f4f6; color:#374151; border:1px solid #e5e7eb; font-size:12px; font-weight:600; border-radius:8px; letter-spacing:.3px;}
	.tourist-content .badge:hover{background:#e0e7ff; border-color:#c7d2fe}
	.tourist-content .exp-cards{display:grid; gap:16px;}
	@media (min-width:600px){ .tourist-content .exp-cards{grid-template-columns:repeat(2,minmax(0,1fr));} }
	.tourist-content .exp-cards .card{background:linear-gradient(180deg,#fff,#fafafa); border:1px solid #e5e5e8; border-radius:18px; padding:18px 18px 20px; box-shadow:0 4px 12px rgba(0,0,0,.06); position:relative;}
	.tourist-content .exp-cards .card:before{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; background:linear-gradient(135deg, rgba(119,78,252,.12), rgba(35,196,252,.08)); opacity:.55; mix-blend-mode:overlay;}
	.tourist-content .exp-cards .card h4{margin:0 0 10px; font-size:15px; font-weight:700; color:#222}
	.tourist-content .exp-cards .card p{margin:0; font-size:14px; line-height:1.55; color:#444}
	.tourist-content .exp-note{margin:10px 0 0; font-size:14px; padding:14px 16px; background:#f9f9fb; border:1px solid #e6e7eb; border-radius:14px; box-shadow:inset 0 0 0 1px rgba(119,78,252,.25);}
	.tourist-content b{color:#200C20; font-weight:600;}
	.tourist-content strong{background:linear-gradient(90deg,#299EFC,#774EFC); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:700;}
	.tourist-content .exp-section:hover h3 .num{box-shadow:0 0 0 3px rgba(35,196,252,.35);}
	.tourist-content .exp-section:hover .card{box-shadow:0 6px 18px rgba(0,0,0,.12);}

	/* =======================================================
	   키오스크 위치 안내 스타일
	   ======================================================= */
	.kiosk-guide{padding:10px 0;}
	
	/* 인트로 영역 */
	.guide-intro{text-align:center; margin-bottom:35px;}
	.guide-title{font-size:clamp(22px,5vw,28px); font-weight:700; margin:0 0 12px; background:linear-gradient(115deg,#6C46E6 0%, #29C4FC 100%); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-.5px;}
	.guide-desc{font-size:15px; line-height:1.6; color:#555; margin:0;}
	
	/* 단계 안내 */
	.guide-steps{display:grid; grid-template-columns:repeat(auto-fit,minmax(100px,1fr)); gap:12px; margin-bottom:35px;}
	.step-item{background:linear-gradient(135deg,#f8f9fa,#fff); border:1px solid #e5e7eb; border-radius:16px; padding:16px 12px; text-align:center; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:all .3s ease;}
	.step-item:hover{transform:translateY(-3px); box-shadow:0 4px 16px rgba(119,78,252,.15);}
	.step-icon{font-size:28px; margin-bottom:8px;}
	.step-text strong{display:block; font-size:14px; font-weight:700; color:#222; margin-bottom:4px;}
	.step-text p{font-size:12px; line-height:1.4; color:#666; margin:0;}
	
	/* 층별 카드 */
	.floor-cards{display:grid; gap:24px; margin-bottom:30px;}
	.floor-card{background:#fff; border:2px solid #e5e7eb; border-radius:20px; padding:20px; position:relative; overflow:hidden; box-shadow:0 4px 12px rgba(0,0,0,.08); transition:all .3s ease;}
	.floor-card:before{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; opacity:0; transition:opacity .3s ease;}
	.floor-card:hover{transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.12);}
	.floor-card:hover:before{opacity:1;}
	
	/* 층별 테마별 색상 */
	.floor-card.food{border-color:#FFB01F;}
	.floor-card.food:before{background:linear-gradient(135deg, rgba(255,176,31,.08), rgba(255,176,31,.03));}
	.floor-card.food .floor-theme{background:linear-gradient(135deg,#FFB01F,#FF8C42); color:#fff;}
	
	.floor-card.culture{border-color:#774EFC;}
	.floor-card.culture:before{background:linear-gradient(135deg, rgba(119,78,252,.08), rgba(119,78,252,.03));}
	.floor-card.culture .floor-theme{background:linear-gradient(135deg,#774EFC,#9D6FFF); color:#fff;}
	
	.floor-card.experience{border-color:#29C4FC;}
	.floor-card.experience:before{background:linear-gradient(135deg, rgba(41,196,252,.08), rgba(41,196,252,.03));}
	.floor-card.experience .floor-theme{background:linear-gradient(135deg,#29C4FC,#00E5FF); color:#fff;}
	
	/* 층 뱃지 */
	.floor-badge{display:flex; align-items:center; gap:8px; margin-bottom:16px;}
	.floor-num{display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; background:linear-gradient(135deg,#200C20,#3a1a3a); color:#E853FF; font-size:15px; font-weight:700; border-radius:12px; box-shadow:0 0 0 3px rgba(232,83,255,.25);}
	.floor-theme{display:inline-flex; align-items:center; padding:8px 16px; font-size:13px; font-weight:700; border-radius:20px; letter-spacing:.5px;}
	
	/* 층 콘텐츠 */
	.floor-content{margin-bottom:16px;}
	.floor-icon{font-size:36px; margin-bottom:10px;}
	.floor-title{font-size:18px; font-weight:700; color:#111; margin:0 0 6px;}
	.floor-location{font-size:14px; font-weight:600; color:#774EFC; margin:0 0 10px; display:flex; align-items:center; gap:4px;}
	.floor-location:before{content:"📍"; font-size:13px;}
	.floor-desc{font-size:14px; line-height:1.5; color:#555; margin:0;}
	
	/* 층 이미지 */
	.floor-img{border-radius:14px; overflow:hidden; margin-top:16px; box-shadow:0 2px 12px rgba(0,0,0,.1);}
	.floor-img img{width:100%; height:auto; display:block; transition:transform .3s ease;}
	.floor-card:hover .floor-img img{transform:scale(1.03);}
	
	/* 팁 영역 */
	.guide-tip{background:linear-gradient(135deg,#fff4e6,#fff); border:2px solid #FFB01F; border-radius:16px; padding:16px 20px; display:flex; align-items:flex-start; gap:12px; box-shadow:0 2px 8px rgba(255,176,31,.15);}
	.tip-icon{font-size:24px; flex-shrink:0; margin-top:2px;}
	.tip-content strong{display:block; font-size:15px; font-weight:700; color:#222; margin-bottom:4px;}
	.tip-content p{font-size:14px; line-height:1.5; color:#555; margin:0;}
	
	/* 반응형 */
	@media (min-width:768px){
		.guide-steps{grid-template-columns:repeat(3,1fr);}
		.floor-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
	}

	.list{ display: flex; flex-wrap: wrap; gap: 15px; }
	.list > div{ flex: 1 1 calc(50% - 15px); }
	.list > div > p{aspect-ratio: 1 / 1;width:100%; padding-top:100%; position: relative; border-radius:15px; overflow:hidden; border:1px solid #ddd}
	.list > div > p > img{
	    position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		right: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		aspect-ratio: 1 / 1;
	}
	.list > div > h4{height: 40px;font-weight:400; font-size:16px;  margin-top:var(--space-3); text-align:center}

     /*쿠폰*/
	.coupon-infor{text-align:center;}
	.coupon-infor > h4,
	.coupon-infor > p{color:#fff}
	.coupon-infor > h4{font-weight:500; margin-bottom:var(--space-2); margin-top:var(--space-2);}
	.coupon-infor > p{font-size:15px}
	.coupon-infor > p b{color:var(--gold); font-weight:500}
	.coupon-infor > p button{background:#200C20; padding:10px 20px; color:#E853FF; border:1px solid #E853FF; border-radius:50px; font-size:14px}

	.coupon-content .inner_coupon{width: min(100% - calc(var(--gutter-sm) * 1), var(--container-w-sm));margin:0 auto;}
	.coupon-content .tab{display:flex; gap:10px; margin-bottom:var(--space-8);}
	.coupon-content .tab a{position: relative; display:block; color:#707070; font-weight:500; font-size:15px; padding:0 3px;}
	.coupon-content .tab a.active{color:#212121; font-weight:600}
	.coupon-content .tab a.active:after{position:absolute; content:""; width:100%; height:3px; background:#FFB01F; left:0; bottom:-5px;}
    .coupon-content .tab_list{display:grid; align-items:center; justify-content:center}
	.coupon-content .tab_list > div{border-bottom:1px solid #ddd; padding-bottom:40px; margin-bottom:40px}
	.coupon-content .tab_list > div:last-child{border:0; padding-bottom:0px; margin-bottom:0px}
	.coupon-content .tab_list > div > p{color:#222; font-family:var(--font-sans-eng); font-weight:500;margin-top:var(--space-4); font-size:14px;}
	.coupon-content .tab_list > div > p span{background:#333; color:#fff; padding:5px 10px; border-radius:100px; margin-right:10px}

	/* 쿠폰 아이템 스타일 */
	.coupon_item {
		position: relative;
		cursor: pointer;
		transition: transform 0.2s ease;
	}
	.coupon_item:hover {
		transform: scale(1.02);
	}

	/* 사용된 쿠폰 흑백 처리 */
	.coupon_item img.used {
		filter: grayscale(100%);
		opacity: 0.6;
	}

	/* 쿠폰 사용 오버레이 이미지 */
	.coupon_item .coupon_img {
		position: relative;
		width: 100%;
	}	
	.coupon_item .coupon_used_img {
		position: absolute;
		top: 33%;
		left: 60%;
		transform: translate(-50%, -50%);
		width: 30%;
		max-width: 200px;
		z-index: 2;
		pointer-events: none;
		filter: none !important;
		opacity: 1 !important;
	}

	/* 쿠폰 없을 때 메시지 */
	.no-coupon {
		text-align: center;
		color: #999;
		padding: 40px 20px;
		font-size: 16px;
	}

	/* =========================================================
	   이용 안내 섹션 (main.html) - 위치 중심
	   ======================================================= */
	.location-guide{background:#54559B; border-radius:20px; padding:30px 20px; box-shadow:0 4px 12px rgba(119,78,252,.15); border:1px solid rgba(119,78,252,.1);}
	
	.guide-header{text-align:center; margin-bottom:24px;}
	.guide-section-title{font-size:var(--fs-xl); font-weight:500; /*color:#2D1B69;*/ color:#fff; margin-bottom:10px;}
	.guide-subtitle{font-size:16px; /*color:#5B4B8A;*/ color:#fff; margin:0;}
	
	/* 위치 카드 */
	.location-cards{display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:16px; margin-bottom:24px;}
	@media (min-width: 640px){
		.location-cards{grid-template-columns:repeat(3, 1fr);}
	}
	
	.location-card{background:#fff; border-radius:16px; overflow:hidden; box-shadow:0 2px 8px rgba(119,78,252,.12); transition:all .3s ease; position:relative; border:1px solid rgba(119,78,252,.08);}
	.location-card:hover{transform:translateY(-4px); box-shadow:0 8px 20px rgba(119,78,252,.25); border-color:rgba(119,78,252,.2);}
	
	.location-image{position:relative; width:100%; height:160px; overflow:hidden;}
	.location-image img{width:100%; height:100%; object-fit:cover; transition:transform .3s ease;}
	.location-card:hover .location-image img{transform:scale(1.05);}
	
	.location-badge{position:absolute; top:12px; left:12px; display:flex; align-items:center; gap:6px; z-index:1;}
	.floor-number{display:inline-block; padding:7px 14px; background:rgba(119,78,252,.95); color:#fff; border-radius:20px; font-size:15px; font-weight:700; backdrop-filter:blur(4px);}
	.theme-tag{display:inline-block; padding:7px 14px; background:rgba(255,255,255,.95); color:#333; border-radius:20px; font-size:14px; font-weight:600; backdrop-filter:blur(4px);}
	
	.location-content{padding:18px; text-align:center;}
	.location-icon{font-size:40px; margin-bottom:10px;}
	.location-title{font-size:18px; font-weight:700; color:#222; margin-bottom:10px;}
	.location-place{font-size:16px; color:#774EFC; font-weight:600; margin-bottom:8px;}
	.location-desc{font-size:15px; color:#666; margin:0; line-height:1.6;}
	
	/* 간단한 이용 팁 */
	.usage-tips{background:rgba(255,255,255,.9); border-radius:12px; padding:18px; margin-bottom:18px; border:1px solid rgba(119,78,252,.1); backdrop-filter:blur(10px); text-align:center;}
	.tip-box{display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap; margin-bottom:12px;}
	.tip-step{font-size:15px; font-weight:600; color:#5B4B8A; padding:8px 14px; background:rgba(119,78,252,.08); border-radius:20px; border:1px solid rgba(119,78,252,.15);}
	.tip-box i{color:#774EFC; font-size:14px;}
	@media (max-width: 500px){
		.tip-box i{display:none;}
		.tip-box{gap:6px;}
	}
	.tip-note{font-size:15px; color:#666; text-align:center; margin:0;}
	
	.btn-detail-link{display:inline-flex; align-items:center; justify-content:center; gap:8px; width:70%; padding:14px 24px; background:#774EFC; color:#fff; font-size:16px; font-weight:600; border-radius:10px; text-decoration:none;  transition:all .3s ease; margin-top:var(--space-4);}
	.btn-detail-link:hover{background:#774EFC; color:#fff;}
	.btn-detail-link i{font-size:14px;}

	/* =========================================================
	   Recommend (개인화 추천) 스타일
	   ======================================================= */
	.recommend{margin-top:var(--space-16); padding-bottom:100px;}
	.recommend .subbg-box.inner-title{margin-bottom:16px}
	.rcmd-grid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:14px}
	@media (min-width:680px){ .rcmd-grid{grid-template-columns: repeat(3, minmax(0,1fr));} }
	.rcmd-card{background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; overflow:hidden; box-shadow:0 6px 14px rgba(17,29,53,.08); display:flex; flex-direction:column;}
	.rcmd-card .thumb{position:relative; display:block; aspect-ratio: 16/10; overflow:hidden}
	.rcmd-card .thumb img{width:100%; height:100%; object-fit:cover; transition: transform .35s ease; display:block}
	.rcmd-card:hover .thumb img{transform:scale(1.05)}
	.rcmd-card .meta{display:flex; align-items:center; justify-content:space-between; gap:8px; padding:10px 12px 0}
	.cat-badge{display:inline-block; font-size:12px; font-weight:700; letter-spacing:.2px; padding:6px 10px; border-radius:999px; border:1px solid transparent;}
	.cat-badge.cooking{background:rgba(119,78,252,.08); color:#5b45f2; border-color:rgba(119,78,252,.25)}
	.cat-badge.culture{background:rgba(35,163,157,.08); color:#1f8e87; border-color:rgba(35,163,157,.25)}
	.cat-badge.learning{background:rgba(208,80,206,.08); color:#b046af; border-color:rgba(208,80,206,.25)}
	.score-pill{font-size:12px; font-weight:700; color:#374151; background:#f3f4f6; border:1px solid #e5e7eb; padding:6px 10px; border-radius:999px}
	.rcmd-card h4{margin:10px 12px 6px; font-size:15px; font-weight:700; color:#111; line-height:1.35}
	.rcmd-card .desc{margin:0 12px 10px; color:#555; font-size:13px}
	.rcmd-card .actions{margin:0 12px 14px 12px}
	.rcmd-card .btn-primary{display:inline-block; width:100%; text-align:center; padding:10px 12px; border-radius:10px; color:#fff; font-weight:700; font-size:14px; background: linear-gradient(268deg, #299EFC 5.13%, #774EFC 94.87%); border:1px solid rgba(86, 40, 237, 0.5); box-shadow: 0 0 7.5px 0 rgba(45, 21, 121, 0.33);}
	.no-recommend{padding:18px; text-align:center; color:#70707a; border:1px dashed #d1d5db; border-radius:14px; background:#fafafa}
     
	.guide{padding:0 0 20px 0}
    .guide > div{text-align:left; border-bottom:1px solid #ddd; padding-bottom:20px; margin-bottom:20px}
    .guide > div > h4{margin-bottom:var(--space-2);}
	.guide > div > p{font-size:15px;color:#707070}

	.tour_link { margin-top:50px; }
	.tour_link_nav {display:flex; gap:10px; margin-bottom:var(--space-8);}
	.tour_link_nav a {flex:1; text-align:center; padding:10px 0; border-radius:50px; font-size:14px; font-weight:600; background:#f3f4f6; color:#374151; border:1px solid #e5e7eb;}
	.tour_link_nav a.active {background: #774EFC; color:#fff; border-color:rgba(119,78,252,.5); box-shadow:0 0 7.5px 0 rgba(45,21,121,.33);}
	.tour_link_nav a:hover {background: #6C46E6; color:#fff; border-color:rgba(119,78,252,.5); box-shadow:0 0 7.5px 0 rgba(45,21,121,.33);}
	.tour_link_tab {margin-bottom:var(--space-8);}
	.tour_link_content {display:none; }
	.tour_link_content.active {display:block; }

	/*탈퇴*/
	.secession{padding-bottom:10px}
	.secession .secession-header{margin-bottom:var(--space-8);}
	.secession .secession-header h3{margin-bottom:var(--space-3);}
	.secession .secession-header .mb_password { border:1px solid #ddd; border-radius:8px; padding:12px; width:80%; margin-top:var(--space-3); font-size:14px; }

	.btnbox{display:flex; align-items:center; justify-content:center; gap:5px}
	.btn-point{background:var(--bg-5) !important; color:#fff !important}
	.btn-memo{display:block; border-radius:50px; font-size:14px; padding:13px 10px; background:var(--bg-4); color:#222; border:1px solid var(--border-1); flex-grow:1}

	/*맞춤관광*/
	.modal_wrap .stamp{position: relative; margin-bottom:var(--space-8);}
	.modal_wrap .stamp a{display:block; border-radius: 25px; box-shadow: 0 0 5.5px 0 rgba(45, 21, 121, 0.73); color:#222;  padding:10px 5px; background: #FFF; text-align:center; font-weight:600; font-size:17px}
	.modal_wrap .stamp a{background: #200C20; padding:15px 5px; color:#fff; padding-left:15px; box-shadow: 0 0 10.2px 0 #E853FF;}
    .modal_wrap .stamp span{position:absolute; width:85px; left:0px; bottom:-15px;}
	
	/* 투어 모달 디자인 */
	.tour-modal-header{position:relative; margin-bottom:20px;}
	.tour-modal-image{width:100%; height:220px; border-radius:12px; overflow:hidden; margin-bottom:15px; background:#f0f0f0;}
	.tour-modal-image img{width:100%; height:100%; object-fit:cover;}
	.tour-modal-title-wrap{text-align:center;}
	.tour-modal-title-wrap h4{font-size:22px; font-weight:700; color:#222; margin:0; line-height:1.3;}
	
	.tour-modal-body{max-height:50vh; overflow-y:auto; padding-right:5px; text-align:left;}
	.tour-modal-body::-webkit-scrollbar{width:6px;}
	.tour-modal-body::-webkit-scrollbar-track{background:#f1f1f1; border-radius:10px;}
	.tour-modal-body::-webkit-scrollbar-thumb{background:#888; border-radius:10px;}
	.tour-modal-body::-webkit-scrollbar-thumb:hover{background:#555;}
	
	.tour-description{background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%); padding:18px; border-radius:10px; margin-bottom:20px; /*border-left:4px solid #774EFC;*/ line-height:1.7; font-size:15px; color:#333;}
	
	.tour-info-grid{display:grid; grid-template-columns:1fr; gap:12px; margin-bottom:var(--space-6);}
	.tour-info-item:not(:has(a)),
	.tour-info-item > a {display:flex; align-items:flex-start; gap:12px; padding:14px; background:#fff; border:1px solid #e5e7eb; border-radius:10px; transition:all .3s ease;}
	.tour-info-item:hover{box-shadow:0 4px 12px rgba(119,78,252,.15); border-color:#774EFC;}
	.tour-info-item.full-width{grid-column:1/-1;}
	
	.info-icon{width:42px; height:42px; border-radius:10px; background:linear-gradient(135deg,#774EFC,#9D6FFF); display:flex; align-items:center; justify-content:center; flex-shrink:0; box-shadow:0 2px 8px rgba(119,78,252,.3);}
	.info-icon i{color:#fff; font-size:18px;}
	
	.info-content{flex:1; min-width:0;}
	.info-label{display:block; font-size:12px; font-weight:600; color:#774EFC; margin-bottom:4px; text-transform:uppercase; letter-spacing:0.5px;}
	.info-value{display:block; font-size:14px; line-height:1.6; color:#333; word-wrap:break-word;}
	.info-value a{color:#333; text-decoration:none; font-weight:500;}
	.info-value a:hover{text-decoration:underline;}
	
	.tour_modal_link{color:#774EFC; font-weight:600; text-decoration:underline;}
	
	@media (min-width: 500px){
		.tour-info-grid{grid-template-columns:repeat(2, 1fr);}
		.tour-modal-image{height:280px;}
	}

	/* ==========================================================================
    nav
	=========================================================================== */
	.ham_mu{margin-left:auto}
	.mobile_wrap{position:fixed; top:0; left:0; width:100%; height:100%; z-index:999; display:none;}
	.nav_box{position:relative; min-width:320px; max-width:768px; margin: 0 auto; height:100%; display:block; z-index:9999; overflow:hidden; }

	.mobile_nav{position:absolute; top:0; right:-500px; width:85%; height:100%; background:#170E32; z-index:99;}
	.mobile_nav > p{position:absolute; top:20px; right:20px; z-index:9;}

	@supports (-webkit-touch-callout: none) {
		/* CSS specific to iOS devices */ 
		.mobile_nav > p { padding-top:env(safe-area-inset-top, 0); }
	}

	.nav{position:absolute; top:0; left:0; width:100%; height:100%; overflow-y:auto;}    
	.gnbBg{position:fixed; top:0; left:0; width:100%; height:100%; display:none; background:rgba(0,0,0,0.7); z-index:99;}
	.inner_nav{width:80%; margin:0 auto; overflow-y:auto !important;}
	.inner_nav a{display:block; color:#F0DAFF; display:flex; align-items:center; gap:5px; font-size:18px; padding:10px 0; font-weight:500;}
	.inner_nav a span:first-child{flex-shrink:0; width:30px; transform:translateY(3px)}

	.nav .top_header{width:80%; margin:70px auto 30px; display:flex; align-items:center; border-bottom:1px solid rgba(255,255,255,0.3); padding-bottom:40px;}
	.nav .text h2,
	.nav .text p,
	.nav .text .eyebrow{color:#fff;}
	.nav .text h2{font-weight:600; margin-bottom:5px}
	.nav .text p{font-size:16px}

	.nav .text .eyebrow{margin-bottom:0px;}

	/*투댑스*/
	.mu_list{display:none;}
	.mu_list a{
		display:block;
		text-decoration:none;
		color:#fff;
		background:#33ccff;
		padding:8px 0 8px 10px;
		font-size:14px;
	}

	.tab-mu{display:flex; gap:2px; margin-top:var(--space-8); width:100%; align-items:center; justify-items: center;}
	.tab-mu a{color:#F4AAFF; border-radius:100px; border: 2px solid rgba(221, 0, 255, 0.58); flex:1 1 30%; line-height:40px}
	.tab-mu a.active{background:rgba(221, 0, 255, 0.58); color:#fff;}

	/* ==========================================================================
    pagination
	=========================================================================== */
	.pagination{display:flex; align-items:center; justify-content:center; gap:8px; margin:30px 0 20px; padding:0 20px;}
	.pagination .page-btn{display:inline-flex; align-items:center; justify-content:center; min-width:40px; height:40px; padding:0 12px; border-radius:8px; background:#fff; color:#333; font-size:15px; font-weight:500; text-decoration:none; border:1px solid #e5e7eb; transition:all .3s ease;}
	.pagination .page-btn:hover{background:#f3f4f6; border-color:#d1d5db;}
	.pagination .page-btn.active{background:linear-gradient(135deg,#774EFC,#9D6FFF); color:#fff; border-color:#774EFC; font-weight:700; box-shadow:0 2px 8px rgba(119,78,252,.3);}
	.pagination .page-btn.prev,
	.pagination .page-btn.next{min-width:40px; width:40px; padding:0; background:linear-gradient(135deg,#f8f9fa,#fff); border-color:#e5e7eb;}
	.pagination .page-btn.prev:hover,
	.pagination .page-btn.next:hover{background:linear-gradient(135deg,#774EFC,#9D6FFF); border-color:#774EFC; color:#fff;}
	.pagination .page-btn.prev i,
	.pagination .page-btn.next i{font-size:14px;}

	/* ==========================================================================
    tabBar
	=========================================================================== */
	.tabBar{position:fixed; left:0; bottom:0;width:100%; z-index:9}
	.inner_tabBar{height:55px; background:#171E2A; display:grid; grid-template-columns: repeat(4, 1fr); align-items:center;  justify-items: center;}
	.inner_tabBar a { display:inline-block; height:100%; padding:0 30px; }
    .inner_tabBar span{display:block; line-height:55px; }

	/* ==========================================================================
    Survey (설문조사) 스타일
	=========================================================================== */
	/*.survey-box{padding-bottom:100px;}*/
	.survey-infor{text-align:center; padding:clamp(30px, 6vw, 50px) 20px; background:linear-gradient(135deg, #774EFC 0%, #9D6FFF 100%); border-radius:20px; margin-bottom:var(--space-8); box-shadow:0 10px 30px rgba(119,78,252,.3);}
	.survey-icon-wrap{display:inline-block; margin-bottom:20px;}
	.survey-infor h4{color:#fff; font-size:clamp(20px, 4vw, 26px); font-weight:700; line-height:1.4; margin:0 0 12px;}
	.survey-infor p{color:rgba(255,255,255,.9); font-size:clamp(14px, 2.5vw, 16px); line-height:1.6; margin:0;}
	
	.survey-content{padding:clamp(20px, 4vw, 30px); background:#fff; border-radius:20px; box-shadow:0 6px 20px rgba(0,0,0,.08);}
	.inner_survey{display:flex; flex-direction:column; gap:clamp(24px, 5vw, 32px);}
	
	/* 질문 박스 */
	.survey-question{background:#F9FAFB; padding:clamp(18px, 4vw, 24px); border-radius:16px; border:1px solid #E5E7EB;}
	.question-header{display:flex; align-items:flex-start; gap:12px; margin-bottom:20px; flex-wrap:wrap;}
	.question-num{display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; background:linear-gradient(135deg, #774EFC, #9D6FFF); color:#fff; font-weight:700; font-size:16px; border-radius:8px; flex-shrink:0; box-shadow:0 4px 10px rgba(119,78,252,.3);}
	.question-header h5{flex:1; margin:0; font-size:clamp(15px, 3vw, 17px); font-weight:700; color:#1F2937; line-height:1.5; min-width:0; padding-top:4px;}
	.question-badge{display:inline-flex; align-items:center; font-size:12px; font-weight:600; padding:4px 10px; background:rgba(119,78,252,.1); color:#774EFC; border-radius:20px; white-space:nowrap;}
	.question-badge.optional{background:rgba(107,114,128,.1); color:#6B7280;}
	
	/* 평점 선택 (이모지) */
	.rating-box{display:grid; grid-template-columns:repeat(5, 1fr); gap:clamp(6px, 2vw, 12px);}
	.rating-item{position:relative; cursor:pointer; padding:clamp(8px, 2vw, 12px); border-radius:12px; background:#fff; border:2px solid transparent; transition:all .25s ease;}
	.rating-item input[type="radio"]{position:absolute; opacity:0; pointer-events:none;}
	.rating-item .rating-emoji{display:block; font-size:clamp(24px, 5vw, 42px); text-align:center; margin-bottom:8px; transition:transform .2s ease;}
	.rating-item .rating-text{display:block; text-align:center; font-size:clamp(10px, 2vw, 14px); font-weight:600; color:#6B7280; transition:color .2s ease; word-break:keep-all;}
	.rating-item:hover{background:#F9FAFB; border-color:#E5E7EB;}
	.rating-item input:checked ~ .rating-emoji{transform:scale(1.15);}
	.rating-item input:checked ~ .rating-text{color:#fff; font-weight:700;}
	.rating-item input:checked{background:transparent;}
	.rating-item:has(input:checked){background:linear-gradient(135deg, #774EFC 0%, #9D6FFF 100%); border-color:#774EFC; box-shadow:0 4px 12px rgba(119,78,252,.3);}
	.rating-item:hover .rating-emoji{transform:scale(1.08);}
	
	/* 체크박스 그리드 */
	.checkbox-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:12px;}
	@media (max-width: 480px){
		.checkbox-grid{grid-template-columns:repeat(2, 1fr);}
	}
	.checkbox-item{position:relative; cursor:pointer;}
	.checkbox-item input[type="checkbox"]{position:absolute; opacity:0; pointer-events:none;}
	.checkbox-card{display:flex; flex-direction:column; align-items:center; justify-content:center; padding:clamp(16px, 3vw, 20px) 10px; background:#fff; border:2px solid #E5E7EB; border-radius:12px; transition:all .25s ease; min-height:100px;}
	.checkbox-item:hover .checkbox-card{border-color:#774EFC; box-shadow:0 4px 12px rgba(119,78,252,.15); transform:translateY(-2px);}
	.checkbox-item input:checked ~ .checkbox-card{background:linear-gradient(135deg, #774EFC 0%, #9D6FFF 100%); border-color:#774EFC; box-shadow:0 6px 16px rgba(119,78,252,.3);}
	/*.checkbox-item input:checked ~ .checkbox-card .feature-icon,*/
	.checkbox-item input:checked ~ .checkbox-card .feature-name{filter:brightness(0) invert(1);}
	.feature-icon{font-size:clamp(28px, 5vw, 36px); margin-bottom:10px; display:block;}
	.feature-name{font-size:clamp(13px, 2.5vw, 14px); font-weight:600; color:#374151; text-align:center;}
	
	/* 라디오 리스트 */
	.radio-list{display:flex; flex-direction:column; gap:10px;}
	.radio-item{position:relative; cursor:pointer; display:block;}
	.radio-item input[type="radio"]{position:absolute; opacity:0; pointer-events:none;}
	.radio-item input[type="checkbox"]{position:absolute; opacity:0; pointer-events:none;}
	.radio-label{display:block; padding:14px 18px; background:#fff; border:2px solid #E5E7EB; border-radius:10px; font-size:15px; font-weight:500; color:#374151; transition:all .25s ease;}
	.radio-item:hover .radio-label{border-color:#774EFC; box-shadow:0 2px 8px rgba(119,78,252,.12);}
	.radio-item input:checked ~ .radio-label{background:linear-gradient(135deg, #774EFC 0%, #9D6FFF 100%); border-color:#774EFC; color:#fff; font-weight:700; box-shadow:0 4px 12px rgba(119,78,252,.3);}
	.radio-item input[type="checkbox"]:checked ~ .radio-label{background:linear-gradient(135deg, #774EFC 0%, #9D6FFF 100%); border-color:#774EFC; color:#fff; font-weight:700; box-shadow:0 4px 12px rgba(119,78,252,.3);}
	
	/* 텍스트 영역 */
	.survey-textarea{width:100%; padding:14px 16px; border:2px solid #E5E7EB; border-radius:10px; font-size:15px; font-family:inherit; resize:vertical; transition:all .25s ease; background:#fff;}
	.survey-textarea:focus{outline:none; border-color:#774EFC; box-shadow:0 0 0 4px rgba(119,78,252,.1);}
	.survey-textarea::placeholder{color:#9CA3AF;}
	
	/* NPS 스케일 */
	.nps-scale{display:flex; flex-direction:column; gap:12px;}
	.nps-labels{display:flex; justify-content:space-between; font-size:13px; font-weight:600; color:#6B7280;}
	.nps-buttons{display:grid; grid-template-columns:repeat(11, 1fr); gap:clamp(4px, 1vw, 8px);}
	.nps-item{position:relative; cursor:pointer; aspect-ratio:1;}
	.nps-item input[type="radio"]{position:absolute; opacity:0; pointer-events:none;}
	.nps-item span{display:flex; align-items:center; justify-content:center; width:100%; height:100%; background:#fff; border:2px solid #E5E7EB; border-radius:8px; font-size:clamp(12px, 2.5vw, 14px); font-weight:700; color:#6B7280; transition:all .2s ease;}
	.nps-item:hover span{border-color:#774EFC; background:#F3F4F6;}
	.nps-item input:checked ~ span{background:linear-gradient(135deg, #774EFC, #9D6FFF); border-color:#774EFC; color:#fff; transform:scale(1.1); box-shadow:0 4px 10px rgba(119,78,252,.4);}
	@media (max-width: 480px){
		.nps-buttons{gap:3px;}
		.nps-item span{border-radius:6px; font-size:11px;}
	}

	/* 5점 NPS 전폭 */
	.nps-buttons.nps-5{grid-template-columns:repeat(5, 1fr);}

	/* 5점 항목별 평가 그룹 */
	.score-group-list{display:flex; flex-direction:column; gap:20px;}
	.score-group-item{padding:16px; background:#F9F8FF; border-radius:12px;}
	.score-group-label{font-size:14px; font-weight:600; color:#374151; margin-bottom:12px;}
	.score-group-item .nps-buttons{grid-template-columns:repeat(5, 1fr);}
	.score-group-item .nps-item span{font-size:15px;}
	
	/* 제출 버튼 */
	.survey-submit-wrap{margin-top:clamp(10px, 3vw, 20px); text-align:center;}
	.btn-survey-submit{display:inline-flex; align-items:center; justify-content:center; gap:10px; width:100%; max-width:400px; padding:16px 32px; background:linear-gradient(268deg, #299EFC 5%, #774EFC 95%); color:#fff; font-size:17px; font-weight:700; border:1px solid rgba(86,40,237,.5); border-radius:12px; cursor:pointer; transition:all .3s ease; box-shadow:0 6px 16px rgba(45,21,121,.4); font-family:inherit;}
	.btn-survey-submit:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(45,21,121,.5);}
	.btn-survey-submit:active{transform:translateY(0); box-shadow:0 4px 12px rgba(45,21,121,.4);}
	.btn-survey-submit svg{transition:transform .3s ease;}
	.btn-survey-submit:hover svg{transform:translateX(4px);}

}