/* ══════════════════════════════════════════
   포레나더샵 인천시청역 - 메인 CSS
═══════════════════════════════════════════ */

/* ══ Pretendard 폰트 - 필요한 굵기만 선택 로드 (400/500/600/700/800) ══
   pretendard.css CDN 전체 로드(7개 파일) 대신 5개만 직접 선언
   font-display:swap → 폰트 로딩 전에도 텍스트 즉시 표시 (렌더링 차단 해결)
 ══════════════════════════════════════════════════════════════════════ */
@font-face {
  font-family: 'Pretendard';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/woff2/Pretendard-Regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Pretendard';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/woff2/Pretendard-Medium.woff2') format('woff2');
}
@font-face {
  font-family: 'Pretendard';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/woff2/Pretendard-SemiBold.woff2') format('woff2');
}
@font-face {
  font-family: 'Pretendard';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/woff2/Pretendard-Bold.woff2') format('woff2');
}
@font-face {
  font-family: 'Pretendard';
  font-weight: 800;
  font-style: normal;
  font-display: swap;
  src: url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/woff2/Pretendard-ExtraBold.woff2') format('woff2');
}

:root {
  --navy:       #1a2b4a;
  --navy-dark:  #0d1f3c;
  --navy-deep:  #0a1628;
  --blue:       #2563eb;
  --blue-light: #60a5fa;
  --white:      #ffffff;
  --off-white:  #f0f4ff;
  --text-dark:  #0f172a;
  --text-mid:   #334155;
  --gray:       #94a3b8;
  --gray-light: #e2e8f0;
  --gold:       #f59e0b;
  --red:        #e53e3e;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Pretendard',sans-serif; background:#fff; color:var(--text-dark); line-height:1.6; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
.container { max-width:1200px; margin:0 auto; padding:0 40px; }

/* HEADER */
#header { position:fixed; top:0; left:0; right:0; z-index:1000; background:rgba(10,22,40,0.15); backdrop-filter:blur(4px); transition:all 0.4s; padding:0 40px; display:flex; align-items:center; justify-content:space-between; height:72px; }
#header.scrolled { background:rgba(10,22,40,0.82); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); box-shadow:0 2px 20px rgba(0,0,0,0.2); }
.logo { text-decoration:none; }
.logo-main { display:block; font-size:16px; font-weight:800; color:#fff; letter-spacing:1px; transition:color 0.4s; }
.logo-sub  { display:block; font-size:10px; color:rgba(255,255,255,0.7); letter-spacing:3px; transition:color 0.4s; }


.header-nav { display:flex; align-items:center; gap:0; }
.nav-item { position:relative; }
.nav-item > a { display:flex; align-items:center; height:72px; padding:0 18px; font-size:13px; font-weight:500; color:rgba(255,255,255,0.9); letter-spacing:0.5px; transition:color 0.2s; }
#header.scrolled .nav-item > a { color:rgba(255,255,255,0.9); }
.nav-item > a:hover { color:#fff; }
#header.scrolled .nav-item > a:hover { color:#fff; }
.nav-dropdown { display:none; position:absolute; top:72px; left:0; background:#fff; min-width:140px; box-shadow:0 8px 24px rgba(0,0,0,0.12); z-index:100; }
.nav-dropdown a { display:block; padding:12px 20px; font-size:13px; color:var(--text-mid); border-bottom:1px solid var(--gray-light); transition:all 0.2s; }
.nav-dropdown a:last-child { border-bottom:none; }
.nav-dropdown a:hover { background:var(--off-white); color:var(--navy); padding-left:26px; }
.nav-item:hover .nav-dropdown { display:block; }
.nav-reserve { background:var(--red) !important; color:#fff !important; padding:10px 20px !important; height:auto !important; font-weight:700 !important; margin-left:16px; }
.nav-reserve:hover { background:#c53030 !important; opacity:1; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.hamburger span { display:block; width:24px; height:2px; background:#fff; transition:all 0.3s; }
#header.scrolled .hamburger span { background:#fff; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.mobile-menu { display:none; position:fixed; top:72px; left:0; right:0; bottom:0; background:#fff; z-index:999; overflow-y:auto; padding:20px 0; }
.mobile-menu.open { display:block; }
.mobile-menu-item { border-bottom:1px solid var(--gray-light); }
.mobile-menu-item > a { display:flex; align-items:center; justify-content:space-between; padding:16px 24px; font-size:15px; font-weight:600; color:var(--navy); }
.mobile-menu-sub { display:none; background:var(--off-white); }
.mobile-menu-sub.open { display:block; }
.mobile-menu-sub a { display:block; padding:12px 40px; font-size:14px; color:var(--text-mid); border-top:1px solid var(--gray-light); }
.mobile-reserve-btn { display:block; margin:20px 24px; background:var(--red); color:#fff; text-align:center; padding:16px; font-size:15px; font-weight:700; }

/* HERO */
#hero { height:100vh; min-height:700px; display:flex; align-items:center; justify-content:center; text-align:center; position:relative; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:center/cover no-repeat; z-index:-1; }
.hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(160deg,rgba(10,22,40,0.85) 0%,rgba(26,43,74,0.55) 50%,rgba(10,22,40,0.9) 100%); }
.hero-content { color:#fff; padding:0 20px; position:relative; z-index:1; }
.hero-label { font-size:11px; letter-spacing:6px; color:var(--blue-light); display:block; margin-bottom:20px; }
.hero-title { font-size:68px; font-weight:800; line-height:1.15; margin-bottom:16px; letter-spacing:-2px; word-break:keep-all; }
.hero-title strong { font-weight:800; color:var(--blue-light); display:block; }
.hero-subtitle { font-size:16px; color:rgba(255,255,255,0.7); margin-bottom:30px; }
.hero-divider { width:50px; height:1px; background:var(--blue-light); margin:0 auto 36px; }
.hero-info { display:flex; gap:60px; justify-content:center; margin-bottom:40px; flex-wrap:wrap; }
.hero-info-item { text-align:center; }
.hero-info-item .label { display:block; font-size:10px; letter-spacing:2px; color:var(--blue-light); margin-bottom:6px; }
.hero-info-item .value { font-size:14px; color:#fff; font-weight:600; }
.hero-cta { display:inline-block; padding:18px 52px; background:var(--red); color:#fff; font-size:15px; font-weight:700; letter-spacing:1px; transition:background 0.3s; }
.hero-cta:hover { background:#c53030; }

/* QUICK */
.quick-section { background:var(--navy); }
.quick-grid { display:grid; grid-template-columns:repeat(8,1fr); max-width:1400px; margin:0 auto; }
.quick-item { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:18px 8px; color:rgba(255,255,255,0.7); text-decoration:none; font-size:11px; font-weight:500; border-right:1px solid rgba(255,255,255,0.08); gap:6px; transition:all 0.2s; }
.quick-item:hover { background:rgba(255,255,255,0.06); color:#fff; }
.quick-item-icon { font-size:18px; }

/* SECTIONS */
.main-section { padding:100px 0; }
.ms-header { text-align:center; margin-bottom:60px; }
.ms-tag { font-size:11px; letter-spacing:5px; color:var(--blue); display:block; margin-bottom:16px; font-weight:600; }
.ms-title { font-size:34px; font-weight:800; line-height:1.4; margin-bottom:16px; letter-spacing:-1px; word-break:keep-all; }
.ms-title strong { color:var(--navy); }
.ms-divider { width:40px; height:3px; background:var(--blue); margin:0 auto 20px; }
.ms-subtitle { font-size:15px; color:var(--text-mid); word-break:keep-all; }
.bg-white { background:#fff; }
.bg-off   { background:var(--off-white); }
.bg-navy  { background:var(--navy); }
.bg-navy .ms-tag { color:var(--blue-light) !important; }
.bg-navy .ms-title,.bg-navy .ms-title strong { color:#fff !important; }
.bg-navy .ms-subtitle { color:rgba(255,255,255,0.7) !important; }
.bg-navy .ms-divider { background:var(--blue-light) !important; }
.ms-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.ms-img-wrap img { width:100%; height:420px; object-fit:cover; }
.ms-desc { font-size:15px; color:var(--text-mid); line-height:1.9; margin-bottom:10px; }
.bg-navy .ms-desc { color:rgba(255,255,255,0.85) !important; }
.bg-navy .ms-desc strong { color:#fff !important; }
.ms-spec-grid { display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--gray-light); margin:28px 0 32px; }
.ms-spec { padding:12px 0; border-bottom:1px solid var(--gray-light); }
.ms-spec-label { font-size:11px; color:var(--gray); display:block; margin-bottom:4px; letter-spacing:1px; }
.ms-spec-value { font-size:14px; font-weight:700; color:var(--text-dark); }
.bg-navy .ms-spec { border-color:rgba(255,255,255,0.12) !important; }
.bg-navy .ms-spec-label { color:rgba(255,255,255,0.5) !important; }
.bg-navy .ms-spec-value { color:#fff !important; }
.ms-btn { display:inline-flex; align-items:center; padding:14px 32px; background:var(--navy); color:#fff; font-size:14px; font-weight:700; transition:background 0.3s; }
.ms-btn:hover { background:var(--blue); }
.ms-btn-navy { background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.4); color:#fff; }
.ms-btn-navy:hover { background:rgba(255,255,255,0.25); }
.ms-btn-outline { display:inline-flex; align-items:center; padding:13px 32px; background:transparent; border:2px solid rgba(255,255,255,0.4); color:#fff; font-size:14px; font-weight:600; transition:all 0.3s; }
.ms-btn-outline:hover { background:rgba(255,255,255,0.1); }

/* LOCATION */
.loc-tag-row { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:50px; }
.loc-tag { padding:8px 20px; background:#fff; border:1px solid var(--gray-light); font-size:13px; font-weight:500; border-radius:30px; }
.loc-card-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:50px; }
.loc-card { background:#fff; padding:32px 24px; border-top:3px solid var(--blue); box-shadow:0 2px 16px rgba(0,0,0,0.06); }
.loc-card-icon { font-size:28px; margin-bottom:14px; display:block; }
.loc-card-title { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:8px; }
.loc-card-desc { font-size:13px; color:var(--text-mid); line-height:1.7; }

/* PREMIUM */
.premium-layout { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:stretch; margin-top:60px; }
.premium-img-wrap { display:flex; flex-direction:column; }
.premium-img-wrap img { width:100%; flex:1; object-fit:cover; min-height:400px; }
.premium-list { display:flex; flex-direction:column; }
.premium-list-item { display:flex; gap:20px; padding:16px 0; border-bottom:1px solid rgba(255,255,255,0.12); align-items:flex-start; }
.premium-list-item:first-child { border-top:1px solid rgba(255,255,255,0.12); }
.premium-list-num { font-size:22px; font-weight:800; color:var(--blue-light); flex-shrink:0; width:36px; line-height:1; }
.premium-list-title { font-size:15px; font-weight:700; color:#fff; margin-bottom:4px; }
.premium-list-desc { font-size:13px; color:rgba(255,255,255,0.7); line-height:1.6; }

/* UNIT TAB */
.unit-tab-btns { display:flex; justify-content:center; margin-bottom:50px; }
.unit-tab-btn { padding:14px 50px; background:#fff; border:2px solid var(--gray-light); font-size:14px; font-weight:500; color:var(--gray); cursor:pointer; font-family:'Pretendard',sans-serif; transition:all 0.2s; }
.unit-tab-btn.active { background:var(--navy); color:#fff; border-color:var(--navy); font-weight:700; }
.unit-tab-content { display:none; }
.unit-tab-content.active { display:block; }
.unit-type-title { font-size:22px; font-weight:800; color:var(--navy); margin-bottom:16px; }

/* SPECIAL */
.special-card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.special-card { background:rgba(255,255,255,0.08); padding:32px 24px; border-bottom:3px solid transparent; transition:all 0.3s; }
.special-card:hover { background:rgba(255,255,255,0.14); border-bottom-color:var(--blue-light); }
.special-card-icon { font-size:30px; margin-bottom:14px; display:block; }
.special-card-title { font-size:15px; font-weight:700; color:#fff; margin-bottom:8px; }
.special-card-desc { font-size:13px; color:rgba(255,255,255,0.7); line-height:1.7; }

/* FAQ */
.faq-section { margin-top:60px; }
.faq-item { border-bottom:1px solid var(--gray-light); cursor:pointer; }
.faq-q { display:flex; justify-content:space-between; align-items:center; padding:20px 0; font-size:15px; font-weight:600; color:var(--navy); }
.faq-q-label { color:var(--blue); margin-right:10px; font-size:18px; font-weight:800; }
.faq-arrow { transition:transform 0.3s; color:var(--gray); font-size:20px; }
.faq-item.open .faq-arrow { transform:rotate(90deg); }
.faq-a { display:none; padding:0 0 20px 30px; font-size:14px; color:var(--text-mid); line-height:1.8; }
.faq-a-label { color:var(--blue); font-weight:700; margin-right:8px; }

/* CTA */
.cta-row { display:flex; justify-content:center; align-items:center; gap:16px; margin-top:50px; padding-top:50px; border-top:1px solid var(--gray-light); flex-wrap:wrap; }
.btn-primary { display:inline-flex; align-items:center; justify-content:center; min-width:200px; padding:16px 24px; font-size:14px; font-weight:700; background:var(--navy); color:#fff; border:2px solid var(--navy); transition:all 0.3s; }
.btn-primary:hover { background:var(--blue); border-color:var(--blue); }
.btn-outline { display:inline-flex; align-items:center; justify-content:center; min-width:200px; padding:14px 24px; font-size:14px; font-weight:700; background:transparent; color:var(--navy); border:2px solid var(--navy); transition:all 0.3s; }
.btn-outline:hover { background:var(--navy); color:#fff; }

/* RESERVE */
.contact-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:50px; }
.contact-item { background:var(--off-white); padding:24px; text-align:center; }
.c-icon { font-size:28px; display:block; margin-bottom:10px; }
.c-label { font-size:11px; color:var(--gray); letter-spacing:2px; display:block; margin-bottom:6px; }
.c-value { font-size:16px; font-weight:700; color:var(--navy); }
.form-card { background:#fff; border:1px solid var(--gray-light); padding:40px; margin-bottom:30px; }
.form-card-title { font-size:16px; font-weight:700; color:var(--navy); margin-bottom:24px; padding-bottom:16px; border-bottom:2px solid var(--blue); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full { grid-column:1/-1; }
.form-group label { font-size:11px; letter-spacing:2px; color:var(--blue); font-weight:600; }
.form-group input,.form-group select,.form-group textarea { background:var(--off-white); border:1px solid var(--gray-light); color:var(--text-dark); padding:14px 18px; font-size:15px; font-family:'Pretendard',sans-serif; outline:none; transition:border-color 0.3s; -webkit-appearance:none; border-radius:0; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--blue); }
.form-group textarea { min-height:120px; resize:vertical; }
.form-submit { display:block; width:100%; padding:18px; background:var(--red); color:#fff; font-size:15px; font-weight:700; border:none; cursor:pointer; font-family:'Pretendard',sans-serif; letter-spacing:1px; transition:background 0.3s; }
.form-submit:hover { background:#c53030; }
.notice-box { background:var(--off-white); padding:20px 24px; border-left:3px solid var(--blue); font-size:13px; color:var(--text-mid); line-height:1.9; }

/* PAGE HERO */
.page-hero { height:280px; background:linear-gradient(135deg,rgba(13,31,60,0.92) 0%,rgba(37,99,235,0.65) 100%),var(--navy) center/cover; display:flex; align-items:center; justify-content:center; text-align:center; padding-top:72px; }
.page-hero-tag { font-size:11px; letter-spacing:5px; color:var(--blue-light); display:block; margin-bottom:14px; }
.page-hero-title { font-size:34px; font-weight:800; color:#fff; letter-spacing:-1px; word-break:keep-all; }
.page-hero-divider { width:40px; height:2px; background:var(--blue-light); margin:16px auto 0; }

/* BREADCRUMB */
.breadcrumb { background:#f8faff; border-bottom:1px solid var(--gray-light); padding:12px 0; }
.breadcrumb-inner { max-width:1200px; margin:0 auto; padding:0 40px; display:flex; align-items:center; gap:8px; font-size:13px; color:var(--gray); flex-wrap:wrap; }
.breadcrumb-inner a { color:var(--gray); transition:color 0.2s; }
.breadcrumb-inner a:hover { color:var(--navy); }
.breadcrumb-inner .current { color:var(--navy); font-weight:600; }

/* SUB NAV */
.sub-nav { background:#fff; border-bottom:2px solid var(--gray-light); }
.sub-nav-inner { max-width:1200px; margin:0 auto; padding:0 40px; display:flex; }
.sub-nav-inner a { padding:16px 24px; font-size:14px; font-weight:500; color:var(--gray); border-bottom:2px solid transparent; margin-bottom:-2px; transition:all 0.2s; }
.sub-nav-inner a:hover { color:var(--navy); }
.sub-nav-inner a.active { color:var(--navy); border-bottom-color:var(--blue); font-weight:700; }

/* PAGE CONTENT */
.page-content { padding:80px 0; }
.content-section { margin-bottom:60px; }
.content-tag { font-size:11px; letter-spacing:5px; color:var(--blue); display:block; margin-bottom:14px; font-weight:600; }
.content-title { font-size:28px; font-weight:800; color:var(--navy); margin-bottom:16px; letter-spacing:-0.5px; word-break:keep-all; }
.content-title strong { color:var(--blue); }
.content-divider { width:36px; height:3px; background:var(--blue); margin-bottom:20px; }
.content-text { font-size:15px; color:var(--text-mid); line-height:1.9; word-break:keep-all; }
.img-block { margin:40px 0; }
.img-block img { width:100%; cursor:zoom-in; transition:opacity 0.2s; }
.img-block img:hover { opacity:0.92; }
.img-caption { font-size:12px; color:var(--gray); text-align:center; margin-top:10px; }

/* TABLE */
.info-table { width:100%; border-collapse:collapse; margin:30px 0; font-size:14px; }
.info-table th { background:var(--navy); color:#fff; padding:14px 20px; text-align:left; font-weight:600; }
.info-table td { padding:14px 20px; border-bottom:1px solid var(--gray-light); color:var(--text-mid); }
.info-table tr:last-child td { border-bottom:none; }
.info-table td strong { color:var(--navy); font-weight:700; }

/* FOOTER */
#footer { background:var(--navy-deep); }
.footer-sitemap { background:#0d1f3c; border-bottom:1px solid rgba(255,255,255,0.06); padding:28px 0; text-align:center; }
.footer-sitemap-inner { display:flex; justify-content:center; max-width:1200px; margin:0 auto; flex-wrap:wrap; }
.footer-sitemap-inner a { color:rgba(255,255,255,0.6); font-size:13px; padding:6px 20px; border-right:1px solid rgba(255,255,255,0.1); transition:color 0.2s; }
.footer-sitemap-inner a:last-child { border-right:none; color:var(--red); }
.footer-sitemap-inner a:hover { color:#fff; }
.footer-top { display:grid; grid-template-columns:1fr 2fr; gap:80px; padding:50px 40px; border-bottom:1px solid rgba(255,255,255,0.06); max-width:1200px; margin:0 auto; }
.footer-logo-main { font-size:16px; font-weight:800; color:#fff; letter-spacing:1px; }
.footer-logo-sub  { font-size:10px; color:var(--blue-light); letter-spacing:3px; margin-top:6px; display:block; }
.footer-tel { font-size:32px; font-weight:800; color:var(--blue-light); display:block; margin-top:18px; }
.footer-hours { font-size:13px; color:rgba(255,255,255,0.5); margin-top:6px; }
.footer-info p { font-size:14px; color:rgba(255,255,255,0.7); margin-bottom:8px; line-height:1.7; }
.footer-info p strong { color:#fff; }
.footer-bottom { max-width:1200px; margin:0 auto; padding:22px 40px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; }
.footer-copy { font-size:12px; color:rgba(255,255,255,0.25); }
.footer-disclaimer { font-size:11px; color:rgba(255,255,255,0.2); max-width:600px; text-align:right; line-height:1.6; }

/* FLOATING */
.floating-wrap { position:fixed; bottom:30px; right:24px; z-index:999; display:flex; flex-direction:column; gap:10px; align-items:center; }
.floating-btn { display:flex; align-items:center; justify-content:center; width:56px; height:56px; border-radius:50%; font-size:22px; text-decoration:none; box-shadow:0 4px 16px rgba(0,0,0,0.25); transition:transform 0.2s,box-shadow 0.2s; }
.floating-btn:hover { transform:scale(1.1); box-shadow:0 6px 20px rgba(0,0,0,0.3); }
.float-tel { background:var(--gold); color:#fff; }
.float-rsv { background:var(--red); color:#fff; }

/* LIGHTBOX */
.lightbox-trigger { cursor:zoom-in !important; }
#lightbox-overlay { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.92); z-index:99999; justify-content:center; align-items:center; cursor:zoom-out; padding:20px; }
#lightbox-overlay.active { display:flex; }
#lightbox-overlay img { max-width:90vw; max-height:90vh; object-fit:contain; }
#lightbox-close { position:fixed; top:20px; right:24px; color:#fff; font-size:36px; cursor:pointer; z-index:100000; }

/* FADE */
.fade-up { opacity:0; transform:translateY(30px); transition:opacity 0.7s,transform 0.7s; }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* MOBILE */
@media (max-width:768px) {
  .container { padding:0 20px; }
  #header { padding:0 20px; }
  .header-nav { display:none; }
  .hamburger { display:flex; }
  .hero-title { font-size:36px; letter-spacing:-1px; }
  .hero-subtitle { display:none; }
  .hero-info { gap:20px; }
  .quick-grid { grid-template-columns:repeat(4,1fr); }
  .quick-item { padding:14px 6px; font-size:10px; }
  .main-section { padding:60px 0; }
  .ms-title { font-size:24px; }
  .ms-grid-2 { grid-template-columns:1fr; gap:30px; }
  .ms-img-wrap img { height:240px; }
  .loc-card-grid { grid-template-columns:1fr; gap:12px; }
  .premium-layout { grid-template-columns:1fr; }
  .premium-img-wrap { display:none; }
  .special-card-grid { grid-template-columns:1fr; gap:12px; }
  .unit-tab-btn { padding:12px 20px; font-size:13px; }
  .contact-grid { grid-template-columns:1fr; gap:12px; }
  .form-grid { grid-template-columns:1fr; }
  .cta-row { flex-direction:column; align-items:stretch; padding-top:30px; margin-top:30px; }
  .btn-primary,.btn-outline { min-width:unset; width:100%; }
  .page-hero { height:200px; }
  .page-hero-title { font-size:22px; }
  .sub-nav-inner { overflow-x:auto; }
  .sub-nav-inner a { padding:12px 14px; font-size:13px; white-space:nowrap; }
  .footer-top { grid-template-columns:1fr; gap:24px; padding:28px 20px; }
  .footer-tel { font-size:26px; }
  .footer-sitemap-inner { display:grid; grid-template-columns:repeat(3,1fr); }
  .footer-sitemap-inner a { border-right:none; padding:10px 4px; font-size:12px; text-align:center; }
  .footer-bottom { flex-direction:column; align-items:flex-start; padding:16px 20px; }
  .footer-disclaimer { text-align:left; }
  .breadcrumb-inner { padding:0 20px; }
  .floating-wrap { bottom:20px; right:14px; }
  .floating-btn { width:50px; height:50px; font-size:20px; }
  .form-card { padding:24px 20px; }
}

/* ══ CF7 폼 스타일링 (포레나 테마) ══ */
.wpcf7-form {
  max-width: 600px;
  margin: 0 auto;
}
.wpcf7-form p {
  margin-bottom: 16px !important;
}
.wpcf7-form label {
  display: block;
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--blue);
  font-weight: 600;
  margin-bottom: 8px;
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea,
.wpcf7-form select {
  width: 100% !important;
  background: var(--off-white) !important;
  border: 1px solid var(--gray-light) !important;
  border-radius: 0 !important;
  padding: 14px 18px !important;
  font-size: 15px !important;
  font-family: 'Pretendard', sans-serif !important;
  outline: none !important;
  -webkit-appearance: none !important;
  color: var(--text-dark) !important;
  transition: border-color 0.3s !important;
  box-shadow: none !important;
}
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
  border-color: var(--blue) !important;
}
.wpcf7-form input[type="submit"] {
  display: block !important;
  width: 100% !important;
  background: var(--red) !important;
  color: #fff !important;
  padding: 18px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  font-family: 'Pretendard', sans-serif !important;
  letter-spacing: 1px !important;
  transition: background 0.3s !important;
  border-radius: 0 !important;
  margin-top: 8px;
}
.wpcf7-form input[type="submit"]:hover {
  background: #c53030 !important;
}
.wpcf7-spinner { display: none !important; }
.wpcf7-response-output {
  margin-top: 16px !important;
  padding: 14px 18px !important;
  font-size: 14px !important;
  border-radius: 0 !important;
  border: none !important;
  text-align: center;
}
.wpcf7-mail-sent-ok {
  background: #e8f5e9 !important;
  color: #2e7d32 !important;
}
.wpcf7-validation-errors,
.wpcf7-acceptance-missing {
  background: #ffebee !important;
  color: #c62828 !important;
}

@media (max-width: 768px) {
  .wpcf7-form input[type="text"],
  .wpcf7-form input[type="tel"],
  .wpcf7-form textarea,
  .wpcf7-form select {
    font-size: 16px !important; /* iOS 자동확대 방지 */
  }
}

/* ══ 로고 이미지 - 스크롤 시 흰색 유지 ══ */
.logo-img-white {
  filter: brightness(0) invert(1);  /* 항상 흰색 */
  opacity: 1;
}
#header.scrolled .logo-img-white {
  filter: brightness(0) invert(1);
}

/* ══ CF7 폼 레이아웃 개선 ══ */
.wpcf7-form .form-row-half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.wpcf7-form p {
  margin-bottom: 16px !important;
}
.wpcf7-form br { display: none; }

/* ══ 평면도 이미지 - 잘리지 않게 ══ */
.unit-img-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f8f8f8;
  min-height: 300px;
}
.unit-img-wrap img {
  height: auto !important;
  max-height: 500px !important;
  object-fit: contain !important;
}

/* ══ 모바일 전용 수정 ══ */
@media (max-width: 768px) {
  /* 헤더 로고 축소 */
  .logo-img-white { height: 16px !important; }

  /* 방문예약 CTA 버튼 */
  .hero-cta { padding: 14px 32px !important; font-size: 14px !important; }

  /* 예약 섹션 contact-grid 카드 패딩 축소 */
  .contact-grid { gap: 8px !important; }
  .contact-item { padding: 14px 12px !important; }
  .c-icon { font-size: 20px !important; margin-bottom: 6px !important; }
  .c-label { font-size: 10px !important; }
  .c-value { font-size: 14px !important; }

  /* 입지환경 loc-card 패딩 축소 */
  .loc-card { padding: 16px 14px !important; }
  .loc-card-icon { font-size: 22px !important; margin-bottom: 8px !important; }
  .loc-card-title { font-size: 14px !important; margin-bottom: 6px !important; }
  .loc-card-desc { font-size: 12px !important; line-height: 1.5 !important; }
}

/* ══ SEO 아코디언 ══ */
.seo-accordion { border-top: 1px solid var(--gray-light); }
.seo-acc-item { border-bottom: 1px solid var(--gray-light); }
.seo-acc-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 4px;
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  cursor: pointer;
  transition: color 0.2s;
  user-select: none;
}
.seo-acc-q:hover { color: var(--blue); }
.seo-acc-q.open { color: var(--blue); }
.seo-acc-arrow {
  font-size: 22px;
  font-weight: 300;
  color: var(--gray);
  transition: transform 0.3s;
  flex-shrink: 0;
  margin-left: 12px;
  line-height: 1;
}
.seo-acc-q.open .seo-acc-arrow {
  transform: rotate(45deg);
  color: var(--blue);
}
.seo-acc-body {
  padding: 0 4px 28px;
  font-size: 15px;
  color: var(--text-mid);
  line-height: 2;
}
.seo-acc-body p { margin-bottom: 14px; }
.seo-acc-body p:last-child { margin-bottom: 0; }

@media (max-width: 768px) {
  .seo-acc-q { font-size: 14px; padding: 16px 4px; }
  .seo-acc-body { font-size: 14px; }
}

/* ══ 관련사이트 섹션 ══ */
.footer-related {
  background: #f0f4ff;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  padding: 28px 0;
}
.footer-related-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
}
.footer-related-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.5px;
}
.footer-related-select {
  width: 280px;
  padding: 10px 16px;
  font-size: 13px;
  font-family: 'Pretendard', sans-serif;
  background: #fff;
  border: 1px solid var(--gray-light);
  color: var(--text-dark);
  cursor: pointer;
  outline: none;
  border-radius: 0;
  -webkit-appearance: none;
}
.footer-related-select:focus { border-color: var(--blue); }

/* 소셜 아이콘 */
.footer-social {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.footer-social-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--gray);
  color: #fff;
  transition: background 0.2s, transform 0.2s;
  text-decoration: none;
}
.footer-social-btn svg { width: 18px; height: 18px; }
.footer-social-btn:hover { background: var(--navy); transform: scale(1.1); }
.footer-social-naver { background: #03c75a; }
.footer-social-naver:hover { background: #02a84a; }
.footer-social-blog { background: #03c75a; }
.footer-social-blog:hover { background: #02a84a; }

@media (max-width: 768px) {
  .footer-related-inner { padding: 0 20px; }
  .footer-related-select { width: 100%; }
}
