:root{--bg:#f3f0ea;--bg-2:#f7f4ef;--line:#d9cdbb;--gold:#c8af83;--gold-dark:#b89b6c;--text:#4a433b;--title:#494239;--footer:#c7ae83;--deep:#1c1d23;--white:#fff}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;overflow-x:hidden}body{font-family:"Noto Sans KR",sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{text-decoration:none;color:inherit}ul,li{list-style:none}img{display:block;max-width:100%}.container{width:min(1240px,calc(100% - 64px));margin:0 auto}.section{padding:72px 0 0}.sec-title{text-align:center;font-family:"Cormorant Garamond",serif;font-size:48px;font-weight:600;color:var(--title);line-height:1;letter-spacing:.02em;margin-bottom:18px}.sec-title::after{content:"";display:block;width:28px;height:2px;background:var(--gold);margin:14px auto 0}.site-header{position:absolute;left:0;top:0;width:100%;z-index:20;padding:18px 0}.site-header .inner{width:min(1360px,calc(100% - 48px));margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:20px}.nav-left,.nav-right{display:flex;align-items:center;gap:26px;padding-top:8px}.nav-right{justify-content:flex-end}.hero-nav a{color:#fff;font-size:18px;font-weight:500;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.2);white-space:nowrap}.hero-logo{display:flex;align-items:center;justify-content:center;min-width:220px}.hero-logo img{width:140px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.18))}.sub-header{position:relative;background:#574c40}.hero{position:relative;width:100%;height:580px;overflow:hidden;background:#000}.hero .slides{height:100%;position:relative}.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease;background-size:cover;background-position:center}.hero .slide.active{opacity:1}.hero .slide::after,.detail-hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.28)}.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:15;width:54px;height:54px;border:none;background:transparent;color:#fff;font-size:48px;line-height:1;cursor:pointer;opacity:.9}.hero-arrow.left{left:22px}.hero-arrow.right{right:22px}.hero-dots{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:15;display:flex;gap:14px;align-items:center}.hero-dots button,.story-dots button{width:11px;height:11px;border-radius:50%;border:2px solid rgba(255,255,255,.92);background:transparent;cursor:pointer;padding:0}.hero-dots button.active,.story-dots button.active{background:#fff}.offers{padding-top:64px}.offer-tabs{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);width:min(930px,100%);margin:34px auto 28px;background:#f6f2ec}.offer-tab{height:52px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6a6259;transition:.2s ease}.offer-tab.active{background:var(--gold);color:#fff;font-weight:600}.offer-wrap{position:relative;width:min(1100px,100%);margin:0 auto;padding:0 36px}.offer-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.offer-card{background:#f5f2ec;border:1px solid #e1d8cb;min-height:395px;display:flex;flex-direction:column}.offer-card .thumb{aspect-ratio:1/.82;background-size:cover;background-position:center}.offer-card .txt{padding:18px 16px 18px}.offer-card h3{font-size:28px;line-height:1.2;color:#584f45;font-weight:600;letter-spacing:-.03em;margin-bottom:10px}.offer-card p{font-size:15px;color:#6a6259;line-height:1.7;min-height:92px}.offer-card a{display:inline-block;margin-top:16px;font-size:15px;color:#6f675d;font-weight:500}.membership{padding-top:72px}.membership-box{width:min(1120px,100%);margin:34px auto 0;display:flex;min-height:395px;overflow:hidden;background:#ddd}.member-panel{position:relative;display:flex;align-items:flex-end;overflow:hidden;cursor:pointer;transition:flex .45s ease;flex:1;min-width:110px}.member-panel::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55),rgba(0,0,0,.1));z-index:1}.member-panel .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .5s ease}.member-panel:hover .bg{transform:scale(1.03)}.member-panel.active{flex:4.3}.member-panel:not(.active){flex:.82}.member-content{position:relative;z-index:2;width:100%;height:100%;display:flex;align-items:flex-end;color:#fff}.member-panel.active .member-info{padding:40px 36px 32px;max-width:440px}.member-title{font-size:54px;line-height:1.05;font-weight:800;margin-bottom:12px}.member-desc{font-size:17px;line-height:1.7;color:rgba(255,255,255,.9);margin-bottom:20px}.member-btn{display:inline-flex;align-items:center;justify-content:center;height:46px;padding:0 18px;border:1px solid rgba(255,255,255,.8);color:#fff;font-size:15px;font-weight:500}.member-vertical{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;color:#fff;font-size:42px;font-weight:800;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.05em}.member-circle{position:absolute;right:24px;bottom:24px;width:38px;height:38px;border:1px solid rgba(255,255,255,.8);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;z-index:3}.membership .sec-title,.membership .member-title,.membership .member-desc,.membership .member-btn,.membership .member-vertical,.consult-title,.consult-form,.consult-form input,.consult-form select,.consult-form button,.consult-bottom,.floating-consult-btn,.consult-modal,.consult-modal input,.consult-modal select,.consult-modal textarea,.consult-modal button{font-family:"Nanum Gothic",sans-serif}.story-wrap{width:min(1120px,100%);margin:28px auto 0;display:flex;flex-direction:column;gap:22px}.story-row{display:grid;grid-template-columns:43% 57%;min-height:265px;background:#f5f1ea;border:1px solid #e4dbcf}.story-row.reverse{grid-template-columns:57% 43%}.story-text{padding:24px 28px 22px;display:flex;flex-direction:column;justify-content:center}.story-kor{font-size:16px;color:#867967;font-weight:500;margin:10px 0 12px}
.story-slide-title{
  display:block;
  margin:0 0 8px;
  font-size:22px;
  line-height:1.35;
  font-weight:800;
  color:#4f473e;
  letter-spacing:-.04em;
  word-break:keep-all;
}
.story-slide-title.is-empty{
  display:none;
}
.story-title{font-family:"Cormorant Garamond",serif;font-size:40px;line-height:1.02;color:#4f473e;font-weight:600;letter-spacing:.01em;white-space:pre-line}.story-desc{font-size:14px;color:#6b6259;line-height:1.8;margin-top:10px;white-space:pre-line}.story-btn{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;margin-top:18px;height:42px;padding:0 16px;border:1px solid var(--gold);color:#a9895c;font-size:14px;font-weight:500;background:#f8f3ec}.story-slider{position:relative;overflow:hidden;min-height:265px}.story-track{position:relative;width:100%;height:100%}.story-slide{position:absolute;inset:0;opacity:0;transition:opacity .55s ease;background-size:cover;background-position:center}.story-slide.active{opacity:1}.story-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:36px;height:36px;border:none;background:rgba(255,255,255,.1);color:#fff;font-size:38px;line-height:1;cursor:pointer}.story-arrow.prev{left:14px}.story-arrow.next{right:14px}.story-dots{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);display:flex;gap:10px;z-index:4}.consult{margin-top:58px;background:linear-gradient(rgba(18,21,31,.45),rgba(18,21,31,.48)),url('https://images.unsplash.com/photo-1514565131-fce0801e5785?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;color:#fff;padding:24px 0 22px;position:relative}.consult-title{text-align:center;font-size:46px;font-weight:800;margin-bottom:14px}.consult-form{width:min(1120px,calc(100% - 48px));margin:0 auto;display:grid;grid-template-columns:1.1fr 1.1fr 1.2fr .8fr;gap:12px;align-items:center}.consult-form input,.consult-form select{width:100%;height:50px;background:rgba(16,17,22,.38);border:1px solid rgba(255,255,255,.42);color:#fff;padding:0 14px;font-size:15px;outline:none}.consult-form input::placeholder{color:rgba(255,255,255,.85)}.consult-form button{height:50px;border:none;background:var(--gold);color:#fff;font-size:16px;font-weight:600;cursor:pointer}.consult-bottom{width:min(1120px,calc(100% - 48px));margin:10px auto 0;display:flex;justify-content:center;align-items:center;gap:14px;color:rgba(255,255,255,.88);font-size:13px}.consult-bottom a{display:inline-flex;align-items:center;justify-content:center;min-width:82px;height:28px;border:1px solid rgba(255,255,255,.36);font-size:12px}footer{background:var(--footer);color:#fff;padding:26px 0}.footer-top{width:min(1240px,calc(100% - 64px));margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.35)}.footer-logo img{width:84px;filter:brightness(0) invert(1);opacity:.95}.footer-links{display:flex;flex-wrap:wrap;gap:18px;justify-content:flex-start;font-size:15px}.footer-links a.active{color:#fff1be;font-weight:600}.sns{display:flex;gap:18px;align-items:center}.sns a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.footer-bottom{width:min(1240px,calc(100% - 64px));margin:16px auto 0;display:grid;grid-template-columns:1.2fr auto;gap:20px;align-items:end}.footer-info{font-size:13px;line-height:1.9;color:rgba(255,255,255,.95)}.footer-copy{margin-top:6px;font-size:12px;opacity:.95}.footer-brands{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:20px;align-items:center;font-family:"Cormorant Garamond",serif;font-size:24px;opacity:.96}.floating-actions{position:fixed;right:22px;bottom:22px;z-index:1200;display:flex;flex-direction:column;gap:12px;align-items:flex-end}.floating-consult-btn,.floating-kakao-btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,.16);transition:transform .2s ease,box-shadow .2s ease}.floating-consult-btn:hover,.floating-kakao-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(0,0,0,.2)}.floating-consult-btn{min-width:146px;height:52px;padding:0 18px;border-radius:999px;background:var(--gold);color:#fff;font-size:15px;font-weight:700;letter-spacing:-.02em}.floating-kakao-btn{width:58px;height:58px;border-radius:50%;background:#FEE500}.floating-kakao-btn img{width:34px;height:34px;object-fit:contain}.consult-modal{position:fixed;inset:0;background:rgba(17,18,22,.54);display:none;align-items:center;justify-content:center;z-index:2000;padding:24px}.consult-modal.active{display:flex}.consult-modal-panel{position:relative;width:min(560px,100%);background:#fff;border-radius:24px;padding:30px 28px 24px;box-shadow:0 20px 50px rgba(0,0,0,.18)}.consult-modal-close{position:absolute;right:18px;top:16px;width:40px;height:40px;border:none;background:transparent;font-size:30px;color:#6f675d;cursor:pointer;line-height:1}.consult-modal-title{font-size:28px;font-weight:800;color:#2f2a24;margin-bottom:8px;letter-spacing:-.03em}.consult-modal-desc{font-size:14px;line-height:1.7;color:#6b6259;margin-bottom:20px}.consult-modal-form{display:grid;gap:12px}.consult-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.consult-modal input,.consult-modal select,.consult-modal textarea,.admin-form input,.admin-form select,.admin-form textarea{width:100%;border:1px solid #ddd1c0;border-radius:14px;background:#fbf8f4;color:#4a433b;font-size:15px;padding:14px 16px;outline:none}.consult-modal textarea,.admin-form textarea{min-height:120px;resize:vertical}.consult-modal-submit,.btn{height:52px;border:none;border-radius:14px;background:var(--gold);color:#fff;font-size:16px;font-weight:700;cursor:pointer;padding:0 18px;display:inline-flex;align-items:center;justify-content:center}body.modal-open{overflow:hidden}.detail-hero{height:430px;position:relative;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff}.detail-hero .detail-copy{position:relative;z-index:2;width:min(1120px,calc(100% - 48px));margin:0 auto;padding:0 0 58px}.detail-hero h1{font-size:52px;line-height:1.08;letter-spacing:-.04em}.detail-hero p{font-size:18px;margin-top:14px;color:rgba(255,255,255,.92)}.detail-body{width:min(1120px,calc(100% - 48px));margin:48px auto}.detail-intro{background:#f7f4ef;border:1px solid #e4dbcf;padding:34px;border-radius:24px;white-space:pre-line}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:28px}.detail-card{background:#f7f4ef;border:1px solid #e4dbcf;border-radius:24px;overflow:hidden}.detail-card .img{height:250px;background-size:cover;background-position:center}.detail-card .copy{padding:24px}.detail-card h3{font-size:24px;color:#4f473e;margin-bottom:8px}.consult-list{width:min(980px,calc(100% - 48px));margin:48px auto}.consult-item{background:#f7f4ef;border:1px solid #e4dbcf;border-radius:18px;padding:18px 22px;margin-bottom:12px;display:grid;grid-template-columns:1fr auto;gap:12px}.badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:#e8dcc9;color:#6b563b;font-size:13px;font-weight:800}.badge.done{background:#dfe9dd;color:#3d6843}.admin-wrap{width:min(1180px,calc(100% - 40px));margin:36px auto}.admin-top{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e4dbcf;border-radius:18px;padding:18px 22px;margin-bottom:18px}.admin-menu{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.admin-menu a{background:#574c40;color:#fff;padding:10px 14px;border-radius:999px}.admin-card{background:#fff;border:1px solid #e4dbcf;border-radius:18px;padding:22px;margin-bottom:16px}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}.admin-table th,.admin-table td{border-bottom:1px solid #eee;padding:12px;text-align:left;font-size:14px}.admin-table th{background:#f7f4ef}.admin-form{display:grid;gap:12px}.notice{background:#fff7e8;border:1px solid #e6cf9d;padding:14px;border-radius:14px;margin-bottom:16px}@media(max-width:1100px){.hero{height:500px}.site-header .inner{grid-template-columns:1fr;justify-items:center;gap:14px}.nav-left,.nav-right{justify-content:center;flex-wrap:wrap;padding-top:0}.offer-list,.detail-grid{grid-template-columns:1fr}.membership-box{flex-direction:column;min-height:auto}.member-panel,.member-panel.active,.member-panel:not(.active){flex:none;min-height:120px}.member-panel.active{min-height:340px}.member-panel:not(.active) .member-vertical{writing-mode:horizontal-tb;font-size:30px}.story-row,.story-row.reverse{grid-template-columns:1fr}.consult-form{grid-template-columns:1fr}.footer-top,.footer-bottom{grid-template-columns:1fr}.footer-links,.sns,.footer-brands{justify-content:center}.footer-info{text-align:center}}@media(max-width:768px){.container,.footer-top,.footer-bottom{width:min(100% - 30px,1240px)}.hero-nav a{font-size:15px}.hero-logo img{width:115px}.sec-title{font-size:38px}.offer-tabs{grid-template-columns:1fr 1fr}.story-title{font-size:34px}.floating-actions{right:16px;bottom:16px}.consult-modal-grid{grid-template-columns:1fr}.detail-hero h1{font-size:38px}.consult-item{grid-template-columns:1fr}.admin-table{display:block;overflow-x:auto}}

/* 2026-04-24 update: offer tab/card alignment + admin image upload preview */
.offer-tabs{align-items:stretch;overflow:hidden;border-radius:0}
.offer-tab{display:flex;align-items:center;justify-content:center;text-align:center;padding:0 10px;line-height:1.25;white-space:nowrap;min-width:0}
.offer-list{align-items:stretch}.offer-card{height:100%;overflow:hidden}.offer-card .thumb{display:block;width:100%;min-height:0}.offer-card .txt{display:flex;flex-direction:column;flex:1}.offer-card .txt a{margin-top:auto}.admin-label{display:block;font-weight:700;color:#5b5045;margin-top:8px}.admin-help{font-size:13px;color:#74695d;line-height:1.7;margin:6px 0 12px}.admin-image-card{border:1px solid #e3d6c4;background:#fbf8f3}.admin-thumb{width:220px;max-width:100%;height:120px;object-fit:cover;border-radius:12px;border:1px solid #dfd2c0;margin:6px 0 10px}
@media(max-width:900px){.offer-tabs{grid-template-columns:repeat(3,1fr);width:100%}.offer-list{grid-template-columns:1fr 1fr}.offer-card h3{font-size:22px}.offer-card p{min-height:auto}}
@media(max-width:560px){.offer-tabs{grid-template-columns:1fr 1fr}.offer-tab{height:46px;font-size:13px}.offer-list{grid-template-columns:1fr}.offer-wrap{padding:0}.offer-card{min-height:auto}.offer-card .thumb{aspect-ratio:1/.68}}

/* v3: 메인 탭/멤버십 동작 보정 */
.offer-tabs button.offer-tab{font-family:inherit}
.offer-card .thumb{display:block;width:100%;border:0;cursor:default}
.member-panel:not(.active) .member-content{display:none}
.member-panel.active .member-vertical{display:none}
.member-panel.active .member-content{display:flex}
.member-panel:not(.active) .member-circle{opacity:.92}

/* v3: 관리자 화면 기능별 정리 */
.admin-dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.admin-dashboard-card{background:#fff;border:1px solid #e4dbcf;border-radius:20px;padding:22px;box-shadow:0 10px 24px rgba(70,60,50,.06)}
.admin-dashboard-card h3{font-size:20px;color:#40382f;margin-bottom:8px}
.admin-dashboard-card p{font-size:14px;color:#6d6257;line-height:1.7;margin-bottom:16px}
.admin-dashboard-card .btn{height:42px;border-radius:999px;font-size:14px}
.admin-section-title{font-size:22px;color:#40382f;margin:24px 0 12px;padding-left:12px;border-left:4px solid var(--gold)}
.admin-subtitle{font-size:14px;color:#6d6257;margin:-4px 0 14px;line-height:1.7}
.admin-mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.admin-fixed-note{background:#f7f1e7;border:1px dashed #ceb58b;border-radius:14px;padding:12px 14px;color:#665742;font-size:14px;line-height:1.7}
@media(max-width:900px){.admin-dashboard,.admin-mini-grid{grid-template-columns:1fr}.admin-top{align-items:flex-start;gap:12px;flex-direction:column}.admin-menu{gap:8px}.admin-menu a{font-size:13px}}

/* =========================
   v4 STORY layout fix
   - 메인 STORY 사진 폭/높이 동일화
   - 상세페이지 4분류 대형 사진 레이아웃
   - 모바일 최적화
========================= */
.story-wrap{
  width:min(1120px, calc(100% - 64px));
}
.story-row,
.story-row.reverse{
  grid-template-columns:1fr 1fr !important;
  min-height:320px;
  align-items:stretch;
}
.story-slider{
  height:320px;
  min-height:320px;
  width:100%;
  background:#ddd1c0;
}
.story-track,
.story-slide{
  width:100%;
  height:100%;
}
.story-slide{
  background-size:cover;
  background-position:center;
}
.story-text{
  min-height:320px;
}
.story-detail-page{
  width:min(1180px, calc(100% - 64px));
}
.story-detail-sections{
  display:flex;
  flex-direction:column;
  gap:28px;
  margin-top:34px;
}
.story-detail-row{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  min-height:430px;
  background:#f7f4ef;
  border:1px solid #e4dbcf;
  border-radius:26px;
  overflow:hidden;
  box-shadow:0 18px 38px rgba(74,67,59,.08);
}
.story-detail-row.reverse{
  grid-template-columns:.92fr 1.08fr;
}
.story-detail-row.reverse .story-detail-photo{
  order:2;
}
.story-detail-row.reverse .story-detail-copy{
  order:1;
}
.story-detail-photo{
  min-height:430px;
  background-size:cover;
  background-position:center;
  background-color:#ddd1c0;
}
.story-detail-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:48px 42px;
}
.detail-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:999px;
  background:var(--gold);
  color:#fff;
  font-weight:800;
  margin-bottom:18px;
}
.story-detail-copy h2{
  font-size:34px;
  line-height:1.18;
  color:#4f473e;
  letter-spacing:-.04em;
  margin-bottom:16px;
}
.story-detail-copy p{
  font-size:16px;
  line-height:1.9;
  color:#665d54;
}
@media(max-width:1100px){
  .story-wrap{
    width:min(100% - 40px, 1120px);
  }
  .story-row,
  .story-row.reverse{
    grid-template-columns:1fr !important;
    min-height:auto;
  }
  .story-row.reverse .story-slider{
    order:2;
  }
  .story-row.reverse .story-text{
    order:1;
  }
  .story-slider{
    height:360px;
    min-height:360px;
  }
  .story-text{
    min-height:auto;
  }
  .story-detail-row,
  .story-detail-row.reverse{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .story-detail-row.reverse .story-detail-photo,
  .story-detail-row.reverse .story-detail-copy{
    order:initial;
  }
  .story-detail-photo{
    min-height:360px;
  }
}
@media(max-width:768px){
  .story-wrap,
  .story-detail-page{
    width:min(100% - 30px, 1180px);
  }
  .story-slider{
    height:260px;
    min-height:260px;
  }
  .story-text{
    padding:24px 20px;
  }
  .story-title{
    font-size:30px;
  }
  .story-desc{
    font-size:14px;
  }
  .story-detail-row{
    border-radius:20px;
  }
  .story-detail-photo{
    min-height:260px;
  }
  .story-detail-copy{
    padding:30px 22px;
  }
  .story-detail-copy h2{
    font-size:27px;
  }
  .story-detail-copy p{
    font-size:14px;
  }
  .detail-step{
    width:42px;
    height:42px;
    margin-bottom:14px;
  }
}

/* v5 STORY 상세페이지: 4분류 x 각 4장 슬라이드 */
.story-rich-page{width:min(1180px,calc(100% - 56px));margin:0 auto;padding:54px 0 70px}.story-rich-page .detail-intro{max-width:880px;margin:0 auto 42px;text-align:center;font-size:17px;line-height:1.9;color:#62594f}.story-rich-sections{display:flex;flex-direction:column;gap:34px}.story-rich-row{display:grid;grid-template-columns:58% 42%;min-height:430px;background:#f7f3ec;border:1px solid #e2d7c8;border-radius:28px;overflow:hidden;box-shadow:0 16px 36px rgba(70,60,50,.07)}.story-rich-row.reverse{grid-template-columns:42% 58%}.story-rich-row.reverse .story-rich-slider{order:2}.story-rich-row.reverse .story-rich-copy{order:1}.story-rich-slider{position:relative;min-height:430px;overflow:hidden;background:#ddd}.story-rich-slider .story-track{height:100%}.story-rich-slider .story-slide{background-size:cover;background-position:center}.story-rich-copy{display:flex;flex-direction:column;justify-content:center;padding:42px 40px}.story-rich-copy .detail-step{display:inline-flex;width:54px;height:54px;border-radius:50%;align-items:center;justify-content:center;background:var(--gold);color:#fff;font-weight:800;margin-bottom:22px}.story-rich-copy h2{font-size:34px;line-height:1.2;color:#443b32;letter-spacing:-.04em;margin-bottom:18px}.story-rich-copy p{font-size:16px;line-height:1.9;color:#6b6259;word-break:keep-all}.story-rich-note{margin-top:22px;padding:12px 14px;border-radius:14px;background:#fff9f0;border:1px solid #e1d1b8;color:#8a714e;font-size:13px}.story-rich-slider .story-arrow{background:rgba(0,0,0,.16);border-radius:999px}.story-rich-slider .story-dots{bottom:18px}

/* v5 관리자: 사이트 분위기와 맞춘 사이드바 */
body.admin-body{background:linear-gradient(135deg,#f3f0ea 0%,#f9f6f1 45%,#ece2d3 100%);min-height:100vh}.admin-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.admin-sidebar{position:sticky;top:0;background:#51473d;color:#fff;padding:26px 20px;display:flex;flex-direction:column;box-shadow:16px 0 40px rgba(57,47,38,.12);z-index:5}.admin-brand{display:flex;flex-direction:column;gap:2px;color:#fff;padding:12px 12px 24px;border-bottom:1px solid rgba(255,255,255,.18);margin-bottom:18px}.admin-brand span{font-family:"Cormorant Garamond",serif;font-size:34px;line-height:1;font-weight:700;letter-spacing:.04em}.admin-brand small{font-size:13px;color:rgba(255,255,255,.72)}.admin-side-menu{display:flex;flex-direction:column;gap:8px}.admin-side-menu a{display:flex;align-items:center;min-height:46px;border-radius:14px;padding:0 14px;color:#fff;background:rgba(255,255,255,.06);font-weight:700;letter-spacing:-.02em}.admin-side-menu a:hover{background:var(--gold)}.admin-side-user{margin-top:auto;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:16px;display:grid;gap:6px}.admin-side-user span{font-size:13px;color:rgba(255,255,255,.78)}.admin-side-user a{font-size:13px;color:#fff1be}.admin-main{padding:32px;width:min(1280px,100%)}.admin-page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;background:rgba(255,255,255,.75);border:1px solid rgba(226,215,200,.9);border-radius:24px;padding:24px 28px;box-shadow:0 14px 32px rgba(70,60,50,.07);backdrop-filter:blur(10px)}.admin-page-head span{font-size:12px;color:#9a8565;font-weight:800;letter-spacing:.12em}.admin-page-head h1{font-size:30px;color:#443b32;letter-spacing:-.04em}.admin-view-site{height:42px;padding:0 18px;border-radius:999px;background:var(--gold);color:#fff;display:inline-flex;align-items:center;font-weight:800}.admin-wrap{width:auto;margin:0}.admin-top,.admin-menu{display:none!important}.admin-card{box-shadow:0 12px 28px rgba(70,60,50,.06)}.admin-detail-section-card{border-color:#d6c2a2;background:#fffdf9}.admin-detail-section-card>h4{font-size:19px;color:#443b32;margin-bottom:12px}.admin-detail-images{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}.admin-detail-images .admin-image-card{margin-bottom:0}.admin-detail-images h5{font-size:15px;color:#6a5945;margin-bottom:8px}

@media (max-width:1100px){.story-rich-row,.story-rich-row.reverse{grid-template-columns:1fr}.story-rich-row.reverse .story-rich-slider,.story-rich-row.reverse .story-rich-copy{order:initial}.story-rich-slider{min-height:360px}.story-rich-copy{padding:34px 28px}.admin-shell{grid-template-columns:1fr}.admin-sidebar{position:relative;height:auto}.admin-side-menu{display:grid;grid-template-columns:repeat(2,1fr)}.admin-main{padding:20px}.admin-page-head{align-items:flex-start;gap:16px;flex-direction:column}.admin-detail-images{grid-template-columns:1fr}}
@media (max-width:768px){.story-rich-page{width:min(100% - 30px,1180px);padding:36px 0 54px}.story-rich-page .detail-intro{text-align:left;font-size:15px;margin-bottom:28px}.story-rich-row{border-radius:20px;min-height:auto}.story-rich-slider{min-height:290px}.story-rich-copy{padding:28px 20px}.story-rich-copy .detail-step{width:44px;height:44px;margin-bottom:16px}.story-rich-copy h2{font-size:27px}.story-rich-copy p{font-size:14px}.admin-side-menu{grid-template-columns:1fr}.admin-sidebar{padding:20px 16px}.admin-main{padding:16px}.admin-page-head{padding:20px}.admin-page-head h1{font-size:24px}.admin-card{border-radius:16px;padding:18px}.admin-form input,.admin-form select,.admin-form textarea{font-size:14px;padding:12px 13px}.admin-thumb{width:100%;height:150px}}

.story-rich-category{
  display:inline-flex;
  align-self:flex-start;
  margin:0 0 12px;
  padding:7px 12px;
  border:1px solid #dfcfb8;
  border-radius:999px;
  color:#987b50;
  background:#fffaf2;
  font-size:13px;
  font-weight:700;
  letter-spacing:-.02em;
}

/* v8 섹션 문구 + SPECIAL OFFERS 상세페이지 교차형 레이아웃 */
.sec-subtitle{
  text-align:center;
  margin:-8px auto 28px;
  color:#8a7a65;
  font-size:18px;
  font-weight:600;
  letter-spacing:-.03em;
}
.offer-card .thumb{
  display:block;
}
.offer-detail-page{
  width:min(1180px,calc(100% - 56px));
  margin:0 auto;
  padding:54px 0 74px;
}
/* v27 SPECIAL OFFERS / STORY intro band */
.detail-intro-band{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  margin-bottom:46px;
  padding:50px 24px 54px;
  background:linear-gradient(135deg,#c7ae83 0%,#d8c49b 46%,#b99764 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.detail-intro-band::before,
.detail-intro-band::after{
  content:"";
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.13);
  pointer-events:none;
}
.detail-intro-band::before{width:360px;height:360px;left:-130px;top:-170px;}
.detail-intro-band::after{width:300px;height:300px;right:-120px;bottom:-160px;}
.detail-intro-band-inner{
  position:relative;
  z-index:1;
  width:min(1120px,100%);
  margin:0 auto;
  text-align:center;
}
.detail-intro-eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.3);
  color:#fff8e8;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:16px;
}
.detail-intro-title{
  max-width:940px;
  margin:0 auto 16px;
  font-size:34px;
  line-height:1.42;
  letter-spacing:-.045em;
  color:#fff;
  word-break:keep-all;
  text-shadow:0 2px 14px rgba(88,68,36,.15);
}
.detail-intro-text{
  max-width:920px;
  margin:0 auto;
  font-size:17px;
  line-height:1.95;
  color:rgba(255,255,255,.92);
  word-break:keep-all;
}
.story-intro-shell{margin-top:0;}
.offer-detail-sections{
  display:flex;
  flex-direction:column;
  gap:34px;
}
.offer-detail-row{
  display:grid;
  grid-template-columns:58% 42%;
  min-height:440px;
  background:#f7f3ec;
  border:1px solid #e2d7c8;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 16px 36px rgba(70,60,50,.07);
}
.offer-detail-row.reverse{
  grid-template-columns:42% 58%;
}
.offer-detail-row.reverse .offer-detail-photo{
  order:2;
}
.offer-detail-row.reverse .offer-detail-copy{
  order:1;
}
.offer-detail-photo{
  min-height:440px;
  background-size:cover;
  background-position:center;
  background-color:#ddd1c0;
}
.offer-detail-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:48px 42px;
}
.offer-detail-copy h2{
  font-size:34px;
  line-height:1.2;
  color:#443b32;
  letter-spacing:-.04em;
  margin-bottom:18px;
}
.offer-detail-copy p{
  font-size:16px;
  line-height:1.9;
  color:#6b6259;
  word-break:keep-all;
}
@media(max-width:1100px){
  .offer-detail-row,
  .offer-detail-row.reverse{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .offer-detail-row.reverse .offer-detail-photo,
  .offer-detail-row.reverse .offer-detail-copy{
    order:initial;
  }
  .offer-detail-photo{
    min-height:360px;
  }
  .offer-detail-copy{
    padding:34px 28px;
  }
}
@media(max-width:768px){
  .sec-subtitle{
    font-size:15px;
    margin:-6px auto 22px;
  }
  .offer-detail-page{
    width:min(100% - 30px,1180px);
    padding:36px 0 54px;
  }
  .offer-intro-shell{
    margin:0 0 28px calc(50% - 50vw);
    padding:34px 0;
  }
  .offer-intro-inner{
    width:min(100% - 30px,1120px);
  }
  .offer-intro-eyebrow{
    font-size:11px;
    letter-spacing:.12em;
    min-height:30px;
    padding:0 13px;
    margin-bottom:12px;
  }
  .offer-intro-title{
    font-size:23px;
    line-height:1.5;
    margin-bottom:10px;
  }
  .offer-detail-page .detail-intro{
    text-align:left;
    font-size:15px;
    line-height:1.85;
  }
  .offer-detail-row{
    border-radius:20px;
  }
  .offer-detail-photo{
    min-height:290px;
  }
  .offer-detail-copy{
    padding:28px 20px;
  }
  .offer-detail-copy h2{
    font-size:27px;
  }
  .offer-detail-copy p{
    font-size:14px;
  }
}
.offer-tabs a.offer-tab{
  display:flex;
  align-items:center;
  justify-content:center;
}

/* v9 SPECIAL OFFERS 상세 탭 + 컨텐츠 타입 배지 제거 */
.offer-detail-tabs{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  width:min(930px,100%);
  margin:0 auto 36px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#f6f2ec;
}
.offer-detail-tabs .offer-tab{
  display:flex;
  align-items:center;
  justify-content:center;
  height:52px;
  font-size:14px;
  font-weight:700;
  color:#6a6259;
}
.offer-detail-tabs .offer-tab.active{
  background:var(--gold);
  color:#fff;
}
.story-rich-category{display:none!important;}
@media(max-width:768px){
  .offer-detail-tabs{grid-template-columns:1fr 1fr;margin-bottom:26px;}
  .offer-detail-tabs .offer-tab{height:46px;font-size:13px;}
}

/* =========================
   v11 HEADER / MOBILE MENU / CONSULT KAKAO
========================= */
html{
  scroll-behavior:smooth;
  scroll-padding-top:92px;
}
.site-header{
  position:fixed !important;
  left:0;
  top:0;
  width:100%;
  z-index:1800;
  padding:18px 0;
  transition:background .25s ease, box-shadow .25s ease, padding .25s ease, backdrop-filter .25s ease;
}
.site-header.is-scrolled,
.site-header.mobile-open{
  background:rgba(76,66,56,.94);
  box-shadow:0 12px 32px rgba(0,0,0,.16);
  backdrop-filter:blur(12px);
  padding:11px 0;
}
.site-header .inner{
  position:relative;
  align-items:center !important;
}
.site-header .nav-left,
.site-header .nav-right{
  padding-top:0 !important;
}
.site-header .hero-nav a{
  position:relative;
  font-size:17px;
  font-weight:700;
}
.site-header .hero-nav a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:2px;
  background:#fff;
  opacity:0;
  transform:scaleX(.5);
  transition:.2s ease;
}
.site-header .hero-nav a:hover::after{
  opacity:.9;
  transform:scaleX(1);
}
.site-menu-toggle,
.mobile-nav-panel{
  display:none;
}
.consult-kakao-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin:0 0 16px;
  padding:15px 16px;
  border:1px solid #ead9b9;
  border-radius:18px;
  background:linear-gradient(135deg,#fffaf0,#fff6dc);
}
.consult-kakao-box div{
  display:grid;
  gap:3px;
}
.consult-kakao-box strong{
  color:#3c3328;
  font-size:16px;
  font-weight:800;
  letter-spacing:-.03em;
}
.consult-kakao-box span{
  color:#766a5d;
  font-size:13px;
  line-height:1.45;
}
.consult-kakao-box a{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:#FEE500;
  color:#2b2419;
  font-size:14px;
  font-weight:800;
  box-shadow:0 8px 18px rgba(0,0,0,.08);
}
@media (min-width:901px){
  .site-header .inner{
    grid-template-columns:1fr auto 1fr !important;
  }
}
@media (max-width:900px){
  html{
    scroll-padding-top:78px;
  }
  .site-header{
    padding:12px 0 !important;
    background:rgba(76,66,56,.92);
    box-shadow:0 10px 28px rgba(0,0,0,.14);
    backdrop-filter:blur(12px);
  }
  .site-header .inner{
    width:min(100% - 28px, 1360px) !important;
    display:flex !important;
    justify-content:space-between;
    align-items:center;
    gap:12px;
  }
  .site-header .nav-left,
  .site-header .nav-right{
    display:none !important;
  }
  .site-header .hero-logo{
    min-width:0;
    justify-content:flex-start;
    order:1;
  }
  .site-header .hero-logo img{
    width:112px;
  }
  .site-menu-toggle{
    order:2;
    width:46px;
    height:46px;
    border:1px solid rgba(255,255,255,.36);
    border-radius:999px;
    background:rgba(255,255,255,.08);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:5px;
    cursor:pointer;
  }
  .site-menu-toggle span{
    display:block;
    width:20px;
    height:2px;
    border-radius:999px;
    background:#fff;
    transition:transform .22s ease, opacity .22s ease;
  }
  .site-header.mobile-open .site-menu-toggle span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }
  .site-header.mobile-open .site-menu-toggle span:nth-child(2){
    opacity:0;
  }
  .site-header.mobile-open .site-menu-toggle span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }
  .mobile-nav-panel{
    position:fixed;
    left:16px;
    right:16px;
    top:74px;
    display:none;
    grid-template-columns:1fr;
    gap:8px;
    padding:16px;
    border:1px solid rgba(255,255,255,.16);
    border-radius:22px;
    background:rgba(63,54,45,.98);
    box-shadow:0 22px 50px rgba(0,0,0,.22);
  }
  .site-header.mobile-open .mobile-nav-panel{
    display:grid;
  }
  .mobile-nav-panel a,
  .mobile-nav-panel button{
    display:flex;
    align-items:center;
    justify-content:space-between;
    min-height:48px;
    padding:0 14px;
    border:1px solid rgba(255,255,255,.10);
    border-radius:14px;
    background:rgba(255,255,255,.06);
    color:#fff;
    font-size:15px;
    font-weight:800;
    font-family:"Noto Sans KR",sans-serif;
    cursor:pointer;
  }
  .mobile-nav-panel a::after,
  .mobile-nav-panel button::after{
    content:"〉";
    color:#d8c094;
  }
  body.mobile-menu-open{
    overflow:hidden;
  }
  .consult-kakao-box{
    flex-direction:column;
    align-items:stretch;
  }
  .consult-kakao-box a{
    width:100%;
  }
}

/* v12: 모달 카카오톡 버튼을 메인 카카오톡 버튼 톤과 동일하게 정리 */
.consult-kakao-box .consult-modal-kakao-btn{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:46px;
  padding:0 18px;
  border:none;
  border-radius:999px;
  background:#FEE500;
  color:#2b2419;
  font-size:14px;
  font-weight:800;
  letter-spacing:-.02em;
  box-shadow:0 12px 28px rgba(0,0,0,.16);
  transition:transform .2s ease, box-shadow .2s ease;
}
.consult-kakao-box .consult-modal-kakao-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 30px rgba(0,0,0,.2);
}
.consult-kakao-box .consult-modal-kakao-btn img{
  width:26px;
  height:26px;
  object-fit:contain;
  display:block;
}
@media (max-width:900px){
  .consult-kakao-box .consult-modal-kakao-btn{
    width:100%;
  }
}

/* v14: 소노리움17 상세페이지 전용 디자인 보강 */
.member-detail-hero{position:relative;min-height:520px;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff;overflow:hidden;padding-top:120px}.member-detail-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(25,22,18,.74),rgba(25,22,18,.36) 46%,rgba(25,22,18,.12));z-index:1}.member-detail-hero__inner{position:relative;z-index:2;width:min(1120px,calc(100% - 48px));margin:0 auto;padding:0 0 72px}.member-eyebrow,.member-section-kicker{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.18em;color:#d7bd8b;text-transform:uppercase}.member-detail-hero h1{margin-top:14px;font-size:68px;line-height:1;font-family:"Nanum Gothic","Noto Sans KR",sans-serif;font-weight:800;letter-spacing:-.055em}.member-detail-hero p{margin-top:18px;max-width:680px;font-size:21px;line-height:1.65;color:rgba(255,255,255,.94);word-break:keep-all}.member-hero-actions,.member-final-cta>div{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.member-primary-btn,.member-kakao-btn,.member-outline-btn{min-height:52px;display:inline-flex;align-items:center;justify-content:center;padding:0 22px;border-radius:999px;font-size:15px;font-weight:800;font-family:"Nanum Gothic","Noto Sans KR",sans-serif;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.member-primary-btn{border:1px solid var(--gold);background:var(--gold);color:#fff;box-shadow:0 14px 28px rgba(0,0,0,.16)}.member-primary-btn:hover,.member-kakao-btn:hover,.member-outline-btn:hover{transform:translateY(-2px)}.member-kakao-btn{border:1px solid #FEE500;background:#FEE500;color:#2b2419;box-shadow:0 14px 28px rgba(0,0,0,.14)}.member-outline-btn{border:1px solid var(--gold);color:#8a6d43;background:#fffaf2}.member-detail-page{width:min(1120px,calc(100% - 48px));margin:58px auto 76px}.member-overview-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:center;padding:38px 42px;border:1px solid #e3d7c6;border-radius:28px;background:linear-gradient(135deg,#fbf8f3,#f2eadf);box-shadow:0 20px 50px rgba(92,76,54,.08)}.member-overview-card h2{margin-top:12px;font-size:34px;line-height:1.32;color:#423a31;letter-spacing:-.055em;word-break:keep-all}.member-overview-card p{color:#675d51;font-size:16px;line-height:1.9;word-break:keep-all}.member-highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0 34px}.member-highlight-card{min-height:128px;padding:24px 22px;border:1px solid #e3d7c6;border-radius:22px;background:#f8f4ee;box-shadow:0 12px 28px rgba(92,76,54,.06)}.member-highlight-card span{display:block;color:#9a8465;font-size:13px;font-weight:800;margin-bottom:12px}.member-highlight-card strong{display:block;color:#423a31;font-size:22px;line-height:1.35;letter-spacing:-.035em;word-break:keep-all}.member-info-section{margin-top:24px;padding:34px;border:1px solid #e3d7c6;border-radius:28px;background:#f8f4ee;box-shadow:0 14px 34px rgba(92,76,54,.055)}.member-info-section.compact{padding-bottom:30px}.member-section-head{display:grid;grid-template-columns:64px 1fr;gap:18px;align-items:start;margin-bottom:22px}.member-section-head>span{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#c8af83;color:#fff;font-family:"Cormorant Garamond",serif;font-size:23px;font-weight:700}.member-section-head h2{color:#423a31;font-size:30px;line-height:1.2;letter-spacing:-.045em}.member-section-head p{margin-top:8px;color:#756a5f;font-size:15px;line-height:1.75;word-break:keep-all}.member-table-wrap{overflow-x:auto;border-radius:18px;border:1px solid #ded2c0;background:#fffaf4}.member-table{width:100%;min-width:720px;border-collapse:collapse;color:#4a433b;background:#fffaf4}.member-table caption{caption-side:top;text-align:right;padding:12px 16px 6px;color:#9b8566;font-size:13px;font-weight:700}.member-table th,.member-table td{padding:16px 18px;border-top:1px solid #eadfce;text-align:center;vertical-align:middle;font-size:15px;line-height:1.6}.member-table th{background:#e9dcc9;color:#4a3f33;font-weight:800}.member-table td:first-child,.member-table th:first-child{text-align:left}.member-table strong{color:#a5814d;font-weight:900}.member-note{margin-top:12px;color:#857769;font-size:13px;line-height:1.65}.member-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.member-choice-card{padding:26px;border:1px solid #e2d5c1;border-radius:22px;background:#fffaf4}.member-choice-card.featured{background:linear-gradient(135deg,#fffaf4,#efe2cf);border-color:#d4bc91}.member-choice-card span{display:inline-flex;padding:7px 11px;border-radius:999px;background:#efe3d0;color:#856a42;font-size:13px;font-weight:800}.member-choice-card h3{margin-top:16px;color:#423a31;font-size:29px;line-height:1.25;letter-spacing:-.04em}.member-choice-card p{margin-top:10px;color:#4d443a;font-size:17px;font-weight:800;line-height:1.7}.member-choice-card small{display:block;margin-top:14px;color:#756a5f;font-size:14px;line-height:1.75;word-break:keep-all}.stay-night-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stay-night-grid div{min-height:136px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;border-radius:24px;border:1px solid #e0d2bd;background:#fffaf4}.stay-night-grid span{color:#8c7a64;font-size:14px;font-weight:800}.stay-night-grid strong{color:#423a31;font-size:38px;line-height:1;font-family:"Cormorant Garamond",serif}.benefit-table td:nth-child(3),.benefit-table th:nth-child(3){white-space:nowrap}.member-footnotes{margin-top:16px;padding:18px 20px;border-radius:18px;background:#efe5d6;color:#6c5f51;font-size:13px;line-height:1.8}.member-final-cta{margin-top:32px;padding:48px 42px;border-radius:32px;background:linear-gradient(135deg,rgba(62,55,47,.96),rgba(118,93,59,.92));color:#fff;text-align:center;box-shadow:0 22px 56px rgba(39,31,22,.18)}.member-final-cta>span{display:inline-block;color:#d7bd8b;font-size:12px;font-weight:900;letter-spacing:.18em}.member-final-cta h2{margin-top:12px;font-size:34px;line-height:1.25;letter-spacing:-.04em}.member-final-cta p{max-width:720px;margin:12px auto 0;color:rgba(255,255,255,.88);font-size:16px;line-height:1.85;word-break:keep-all}.member-final-cta>div{justify-content:center}.member-final-cta .member-outline-btn{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}@media(max-width:1100px){.member-detail-hero{min-height:460px}.member-detail-hero h1{font-size:54px}.member-overview-card{grid-template-columns:1fr}.member-highlight-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.member-detail-hero{min-height:420px;padding-top:100px}.member-detail-hero__inner,.member-detail-page{width:min(100% - 30px,1120px)}.member-detail-hero__inner{padding-bottom:44px}.member-detail-hero h1{font-size:42px}.member-detail-hero p{font-size:16px}.member-hero-actions,.member-final-cta>div{flex-direction:column}.member-primary-btn,.member-kakao-btn,.member-outline-btn{width:100%}.member-detail-page{margin:34px auto 52px}.member-overview-card,.member-info-section,.member-final-cta{padding:24px 18px;border-radius:22px}.member-overview-card h2,.member-final-cta h2{font-size:26px}.member-highlight-grid,.member-choice-grid,.stay-night-grid{grid-template-columns:1fr}.member-highlight-card{min-height:auto}.member-section-head{grid-template-columns:1fr;gap:12px}.member-section-head>span{width:48px;height:48px;font-size:20px}.member-section-head h2{font-size:25px}.member-table th,.member-table td{padding:13px 14px;font-size:14px}}


/* v16: 회원권 상세페이지 상단 멤버십 슬라이드 및 중복 CTA 정리 */
body.solid-header .site-header{
  background:rgba(76,66,56,.94);
  box-shadow:0 12px 32px rgba(0,0,0,.16);
  backdrop-filter:blur(12px);
  padding:11px 0;
}
.membership-detail-picker{
  padding-top:132px;
  padding-bottom:0;
}
.membership-detail-picker .sec-title{
  margin-bottom:10px;
}
.membership-detail-picker .sec-subtitle{
  text-align:center;
  color:#7b6d5b;
  font-size:17px;
  font-weight:700;
  margin:0 auto 8px;
  letter-spacing:-.02em;
}
.membership-detail-picker .membership-box{
  box-shadow:0 22px 52px rgba(69,55,37,.12);
}
.member-final-cta{
  padding:52px 44px;
}
.member-final-cta p{
  max-width:780px;
}
@media(max-width:1100px){
  .membership-detail-picker{
    padding-top:118px;
  }
}
@media(max-width:768px){
  .membership-detail-picker{
    padding-top:104px;
  }
  .membership-detail-picker .sec-subtitle{
    font-size:15px;
  }
}

/* v17: variable content counts, reviews, consultation notice */
.offer-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.consult-notice{width:min(1120px,calc(100% - 48px));margin:0 auto 14px;padding:12px 16px;border:1px solid rgba(255,255,255,.38);background:rgba(255,255,255,.14);border-radius:14px;text-align:center;font-size:14px;color:#fff;font-weight:700;font-family:"Nanum Gothic",sans-serif;}
.review-hero::after{background:rgba(0,0,0,.38)}
.reviews-page{width:min(1120px,calc(100% - 48px));margin:52px auto 76px;}
.review-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:28px;}
.review-card{padding:26px 24px;border:1px solid #e3d7c6;border-radius:24px;background:#fffaf4;box-shadow:0 16px 34px rgba(92,76,54,.07);display:flex;flex-direction:column;min-height:362px;height:100%;}
.review-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;}
.review-card-head span{display:inline-flex;padding:7px 11px;border-radius:999px;background:#efe3d0;color:#856a42;font-size:13px;font-weight:800;}
.review-card-head strong{color:#c8a04e;letter-spacing:.04em;white-space:nowrap;}
.review-card h2{font-size:22px;line-height:1.34;color:#423a31;letter-spacing:-.04em;margin-bottom:12px;word-break:keep-all;}
.review-card p{font-size:15px;line-height:1.82;color:#6b6259;word-break:keep-all;flex:1;}
.review-meta{display:flex;justify-content:space-between;gap:12px;margin-top:auto;padding-top:16px;border-top:1px solid #eadfce;color:#8b7b68;font-size:13px;font-weight:700;align-items:center;}
.empty-text{grid-column:1/-1;text-align:center;color:#8b7b68;padding:40px 0;}
.membership-detail-picker{padding-top:54px;}
.member-detail-hero + .membership-detail-picker{padding-top:58px;}
.member-detail-hero .member-hero-actions{display:none!important;}

@media(max-width:1100px){.review-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:768px){.offer-list{grid-template-columns:1fr}.reviews-page{width:min(100% - 30px,1120px);margin:34px auto 52px}.review-grid{grid-template-columns:1fr}.review-card{padding:22px 18px;border-radius:20px;min-height:auto}.consult-notice{width:min(100% - 30px,1120px);}}

/* v18: 콘텐츠별 메인/상세 노출 개수 별도 관리 UI */
.admin-two-col{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
}
.admin-two-col label{
  display:grid;
  gap:6px;
  font-weight:800;
  color:#574c40;
  font-size:14px;
}
.admin-two-col input{
  width:100%;
}
@media(max-width:768px){
  .admin-two-col{grid-template-columns:1fr;}
}

/* v19: reviews pagination */
.review-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:34px auto 0;
  flex-wrap:wrap;
}
.review-pagination a{
  min-width:42px;
  height:42px;
  padding:0 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #e0d2bf;
  border-radius:999px;
  background:#fffaf4;
  color:#6f604f;
  font-size:14px;
  font-weight:800;
  box-shadow:0 10px 22px rgba(92,76,54,.05);
}
.review-pagination a.active,
.review-pagination a:hover{
  background:#c8af83;
  border-color:#c8af83;
  color:#fff;
}
@media(max-width:768px){
  .review-pagination{gap:6px;margin-top:26px;}
  .review-pagination a{min-width:38px;height:38px;padding:0 12px;font-size:13px;}
}

/* v21: privacy agreement + customer center */
.privacy-check{display:flex;align-items:center;gap:9px;font-size:13px;line-height:1.5;color:#6b6259;word-break:keep-all}.privacy-check input{width:17px!important;height:17px!important;min-width:17px;padding:0!important;accent-color:var(--gold);box-shadow:none!important}.privacy-check a{color:#8c6b3f;font-weight:800;text-decoration:underline;text-underline-offset:3px}.consult-privacy-check{grid-column:1/-1;justify-content:center;color:rgba(255,255,255,.92);margin-top:2px}.consult-privacy-check a{color:#fff1be}.modal-privacy-check{justify-content:flex-start;background:#fbf8f4;border:1px solid #eadfcc;border-radius:14px;padding:12px 14px}.customer-page{margin-top:48px}.customer-intro-card{background:linear-gradient(135deg,#f7f2e9,#fffaf3);border:1px solid #e4d8c8;border-radius:28px;padding:42px;display:grid;grid-template-columns:.9fr 1.1fr;gap:32px;align-items:center;box-shadow:0 16px 38px rgba(91,72,51,.08)}.customer-intro-card span,.customer-section-head span{font-family:"Cormorant Garamond",serif;letter-spacing:.12em;color:#b3905e;font-weight:700}.customer-intro-card h2{font-size:38px;line-height:1.22;color:#3f382f;letter-spacing:-.04em}.customer-intro-card p{font-size:16px;line-height:1.9;color:#6b6259}.customer-section{margin-top:52px}.customer-section-head{text-align:center;margin-bottom:26px}.customer-section-head h2{font-size:36px;color:#40382f;letter-spacing:-.04em;margin-top:6px}.customer-section-head p{font-size:15px;color:#7b7063;margin-top:8px}.faq-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.faq-card,.term-card,.process-card{background:#fffaf5;border:1px solid #e5d8c6;border-radius:22px;padding:24px;box-shadow:0 12px 28px rgba(73,58,39,.06)}.faq-card h3{font-size:20px;color:#3f382f;letter-spacing:-.035em;margin-bottom:12px}.faq-card p,.term-card p,.process-card p{font-size:15px;line-height:1.8;color:#665c51}.process-arrow-grid{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:12px;align-items:stretch}.process-card{position:relative;min-height:210px;display:flex;flex-direction:column}.process-card strong{width:48px;height:48px;border-radius:50%;background:#c8af83;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:18px}.process-card h3{font-size:22px;color:#3f382f;margin-bottom:10px;letter-spacing:-.04em}.process-arrow{display:flex;align-items:center;justify-content:center;color:#c8af83;font-size:32px;font-weight:800}.term-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.term-card span{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#efe3cf;color:#8b6b3d;font-weight:900;margin-bottom:14px}.term-card h3{font-size:20px;color:#3f382f;margin-bottom:10px;letter-spacing:-.035em}.customer-final-cta{margin-top:56px}.simple-policy-page .detail-intro h2{font-size:30px;color:#40382f;margin-bottom:16px}.simple-policy-page .detail-intro p{font-size:16px;line-height:1.9;margin-top:12px;color:#63594e}
@media(max-width:1100px){.customer-intro-card{grid-template-columns:1fr}.faq-grid,.term-grid{grid-template-columns:1fr 1fr}.process-arrow-grid{grid-template-columns:1fr}.process-arrow{transform:rotate(90deg);height:34px}.process-card{min-height:auto}}
@media(max-width:768px){.customer-intro-card{padding:28px 20px;border-radius:22px}.customer-intro-card h2{font-size:28px}.customer-section-head h2{font-size:28px}.faq-grid,.term-grid{grid-template-columns:1fr}.consult-privacy-check{justify-content:flex-start;width:min(1120px,calc(100% - 48px));margin:0 auto;color:#fff}.process-card{padding:22px}.modal-privacy-check{font-size:12px}}


/* v27 STORY quick navigation */
.story-page-nav{
  width:min(1120px, calc(100% - 48px));
  margin:36px auto 0;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
}
.story-page-nav a{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border:1px solid #dfd2bf;
  border-radius:999px;
  background:#f8f3ec;
  color:#6b6259;
  font-size:15px;
  font-weight:800;
  text-align:center;
  letter-spacing:-.035em;
  word-break:keep-all;
  transition:background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.story-page-nav a:hover,
.story-page-nav a.active{
  background:var(--gold);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(120,94,58,.16);
}
.story-section-jump{
  max-width:1120px;
  margin:0 auto 30px;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
}
.story-section-jump a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 14px;
  border-radius:999px;
  background:#fffaf4;
  border:1px solid #e3d6c3;
  color:#7a6b5b;
  font-size:13px;
  font-weight:800;
  letter-spacing:-.025em;
}
.story-section-jump a:hover{background:#eadcc7;color:#4c4238;}
.story-rich-row{scroll-margin-top:112px;}
@media(max-width:900px){
  .story-page-nav{
    width:min(100% - 30px, 1120px);
    margin-top:26px;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:10px;
  }
  .story-page-nav a{min-height:52px;font-size:13px;border-radius:18px;}
  .story-section-jump{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;margin-bottom:22px;}
  .story-section-jump a{flex:0 0 auto;}
}


/* v28: detail tabs sit directly below the representative hero image */
.offer-detail-page{
  margin:0 auto !important;
  padding:0 0 74px !important;
}
.offer-detail-tabs{
  width:min(1120px,100%) !important;
  margin:0 auto 0 !important;
}
.offer-intro-band,
.story-intro-shell{
  margin-top:0 !important;
}

/* v28: STORY/VIEW MORE navigation restored as a tab bar below the hero */
.story-page-nav{
  width:min(1120px,calc(100% - 48px)) !important;
  margin:0 auto 0 !important;
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:0 !important;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#f6f2ec;
}
.story-page-nav a{
  min-height:56px !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  color:#6a6259 !important;
  padding:0 14px !important;
  transform:none !important;
}
.story-page-nav a:hover,
.story-page-nav a.active{
  background:var(--gold) !important;
  color:#fff !important;
  box-shadow:none !important;
  transform:none !important;
}
.story-rich-page{
  padding-top:0 !important;
}

@media(max-width:768px){
  .offer-detail-page{
    width:min(100% - 30px,1180px) !important;
    padding:0 0 54px !important;
  }
  .offer-detail-tabs{
    width:100% !important;
    grid-template-columns:1fr 1fr !important;
    margin:0 auto 0 !important;
  }
  .detail-intro-band{
    padding:34px 15px 38px !important;
    margin-bottom:28px !important;
  }
  .detail-intro-title{
    font-size:23px !important;
    line-height:1.5 !important;
  }
  .detail-intro-text{
    text-align:left !important;
    font-size:15px !important;
    line-height:1.85 !important;
  }
  .story-page-nav{
    width:min(100% - 30px,1120px) !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    margin:0 auto 0 !important;
  }
  .story-page-nav a{
    min-height:48px !important;
    font-size:13px !important;
    padding:0 10px !important;
  }
}


/* v29: STORY 상세 내부 작은 분류 버튼 제거 + 모바일 햄버거 원형 2줄 복구 */
.story-section-jump{
  display:none !important;
}
@media(max-width:768px){
  .mobile-nav-panel{
    position:fixed;
    left:16px;
    right:16px;
    top:74px;
    display:none;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    padding:18px;
    border:1px solid rgba(255,255,255,.18);
    border-radius:28px;
    background:rgba(63,54,45,.98);
    box-shadow:0 22px 50px rgba(0,0,0,.22);
  }
  .site-header.mobile-open .mobile-nav-panel{
    display:grid;
  }
  .mobile-nav-panel a{
    aspect-ratio:1/1;
    min-height:0;
    padding:0 8px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    line-height:1.25;
    background:rgba(255,255,255,.10);
    border:1px solid rgba(255,255,255,.18);
    color:#fff;
    font-size:13px;
    font-weight:900;
    letter-spacing:-.04em;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  }
  .mobile-nav-panel a:nth-child(1),
  .mobile-nav-panel a:nth-child(4){
    background:rgba(200,175,131,.22);
  }
  .mobile-nav-panel a::after{
    display:none !important;
    content:none !important;
  }
  .mobile-nav-panel button{
    display:none !important;
  }
}
@media(max-width:420px){
  .mobile-nav-panel{
    gap:9px;
    padding:14px;
  }
  .mobile-nav-panel a{
    font-size:12px;
  }
}


/* v30: 모바일 햄버거 원형 메뉴 높이 축소 */
@media(max-width:768px){
  .mobile-nav-panel{
    left:14px !important;
    right:14px !important;
    top:68px !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:8px !important;
    padding:12px !important;
    border-radius:22px !important;
  }
  .mobile-nav-panel a{
    aspect-ratio:auto !important;
    min-height:40px !important;
    height:40px !important;
    padding:0 10px !important;
    border-radius:999px !important;
    font-size:12px !important;
    line-height:1.15 !important;
    letter-spacing:-.05em !important;
    white-space:nowrap !important;
  }
}
@media(max-width:420px){
  .mobile-nav-panel{
    left:10px !important;
    right:10px !important;
    top:66px !important;
    gap:7px !important;
    padding:10px !important;
    border-radius:20px !important;
  }
  .mobile-nav-panel a{
    height:36px !important;
    min-height:36px !important;
    padding:0 7px !important;
    font-size:11px !important;
  }
}

/* v31 admin polish: centered login, unified admin font/buttons, sidebar stats */
.admin-body,
.admin-login-body,
.admin-body input,
.admin-body select,
.admin-body textarea,
.admin-body button,
.admin-login-body input,
.admin-login-body button{
  font-family:"Malgun Gothic","맑은 고딕",Arial,sans-serif !important;
}
.admin-login-body{
  min-height:100vh;
  margin:0;
  background:
    radial-gradient(circle at 15% 12%, rgba(255,255,255,.55), transparent 30%),
    linear-gradient(135deg,#f2ede5 0%,#fbf8f2 48%,#e3d5bf 100%);
  color:#4a433b;
}
.admin-login-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:36px 18px;
}
.admin-login-card{
  width:min(460px,100%);
  background:rgba(255,255,255,.86);
  border:1px solid rgba(224,211,190,.95);
  border-radius:30px;
  padding:38px 36px 32px;
  box-shadow:0 28px 70px rgba(72,57,38,.16);
  backdrop-filter:blur(12px);
  text-align:center;
}
.admin-login-brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin-bottom:20px;
  color:#4c4238;
}
.admin-login-brand span{
  font-family:"Cormorant Garamond",serif !important;
  font-size:46px;
  line-height:1;
  font-weight:700;
  letter-spacing:.06em;
}
.admin-login-brand small{
  margin-top:4px;
  color:#a98b5f;
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
}
.admin-login-card h1{
  margin:0;
  color:#3f382f;
  font-size:30px;
  line-height:1.25;
  letter-spacing:-.045em;
}
.admin-login-card>p{
  margin:10px 0 24px;
  color:#74695d;
  font-size:14px;
  line-height:1.65;
  word-break:keep-all;
}
.admin-login-form{
  text-align:left;
  gap:14px;
}
.admin-login-form label{
  display:grid;
  gap:7px;
  color:#5b5045;
  font-size:13px;
  font-weight:900;
}
.admin-login-form input{
  height:54px;
  border-radius:16px;
  background:#fbf8f4;
}
.admin-login-submit{
  width:100%;
  margin-top:4px;
}
.admin-login-help{
  margin-top:18px;
  padding:16px;
  border-radius:18px;
  background:#f7f1e8;
  border:1px solid #e7d8c4;
  text-align:left;
  display:grid;
  gap:4px;
  color:#6b6259;
  font-size:13px;
  line-height:1.55;
}
.admin-login-help strong{color:#4c4238;font-size:14px;}
.admin-login-help em{color:#9b6b3e;font-style:normal;font-weight:900;margin-top:4px;}
.admin-login-notice{text-align:left;margin-bottom:16px;}
.admin-body .btn,
.admin-body button.btn,
.admin-body a.btn,
.admin-login-body .btn,
.admin-view-site,
.admin-form button,
.admin-form a.btn,
.admin-table .btn{
  min-height:44px;
  height:auto;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,#c8af83,#b99661);
  color:#fff !important;
  font-size:14px;
  font-weight:900;
  letter-spacing:-.025em;
  box-shadow:0 12px 24px rgba(104,78,44,.14);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  text-decoration:none !important;
}
.admin-body .btn:hover,
.admin-body button.btn:hover,
.admin-body a.btn:hover,
.admin-login-body .btn:hover,
.admin-view-site:hover,
.admin-form button:hover,
.admin-form a.btn:hover,
.admin-table .btn:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 30px rgba(104,78,44,.20);
}
.admin-body .btn-sm,
.admin-table .btn,
.admin-card .btn[style*="height:36px"]{
  min-height:36px;
  padding:0 14px;
  font-size:13px;
}
.admin-form button:not(.btn){
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 18px;
  cursor:pointer;
}
.admin-side-menu a{
  transition:background .2s ease, transform .2s ease, color .2s ease;
}
.admin-side-menu a:hover{
  transform:translateX(3px);
}
.admin-sidebar-widget{
  margin-top:14px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
}
.admin-sidebar-widget-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
}
.admin-sidebar-widget-head span{
  color:rgba(255,255,255,.72);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
}
.admin-sidebar-widget-head a{
  color:#fff1be;
  font-size:12px;
  font-weight:900;
}
.admin-sidebar-widget>strong{
  display:block;
  color:#fff;
  font-size:31px;
  line-height:1.05;
  letter-spacing:-.04em;
}
.admin-sidebar-widget>small{
  display:block;
  margin-top:5px;
  color:rgba(255,255,255,.72);
  font-size:13px;
}
.admin-sidebar-consult-list{
  display:grid;
  gap:8px;
  margin-top:14px;
}
.admin-sidebar-consult-list p{
  margin:0;
  color:rgba(255,255,255,.66);
  font-size:13px;
}
.admin-sidebar-consult-list a{
  display:grid;
  grid-template-columns:1fr auto;
  gap:3px 8px;
  padding:10px 11px;
  border-radius:14px;
  background:rgba(255,255,255,.08);
  color:#fff;
}
.admin-sidebar-consult-list b{
  font-size:13px;
  letter-spacing:-.02em;
}
.admin-sidebar-consult-list span{
  grid-column:1/-1;
  color:rgba(255,255,255,.72);
  font-size:12px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.admin-sidebar-consult-list em{
  font-style:normal;
  color:#fff1be;
  font-size:12px;
  white-space:nowrap;
}
.admin-stat-card span{
  display:block;
  color:#9a8565;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  margin-bottom:10px;
}
.admin-stat-card strong{
  display:block;
  color:#40382f;
  font-size:36px;
  line-height:1;
  letter-spacing:-.04em;
}
.admin-stat-card p{margin-top:10px!important;margin-bottom:0!important;}
.admin-card-title-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:16px;
}
.admin-card-title-row .admin-section-title,
.admin-card-title-row .admin-subtitle{
  margin-top:0;
}
.admin-mini-list{
  display:grid;
  gap:10px;
}
.admin-mini-list a{
  display:grid;
  grid-template-columns:1fr auto;
  gap:4px 12px;
  align-items:center;
  padding:14px 16px;
  border:1px solid #eadfce;
  border-radius:16px;
  background:#fffaf4;
  color:#4a433b;
}
.admin-mini-list b{font-size:15px;}
.admin-mini-list span{
  color:#6b6259;
  font-size:13px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.admin-mini-list em{
  font-style:normal;
  color:#9a8565;
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}
.admin-empty-text{
  margin:0;
  padding:22px;
  border-radius:16px;
  background:#fffaf4;
  border:1px solid #eadfce;
  color:#8b7b68;
  text-align:center;
}
.admin-table th,
.admin-table td{
  vertical-align:middle;
}
.admin-table form{
  margin:0;
}
@media(max-width:1100px){
  .admin-sidebar-widget{margin-top:12px;}
  .admin-side-user{margin-top:14px;}
}
@media(max-width:768px){
  .admin-login-card{padding:30px 22px 24px;border-radius:24px;}
  .admin-login-brand span{font-size:40px;}
  .admin-login-card h1{font-size:25px;}
  .admin-card-title-row{flex-direction:column;}
  .admin-card-title-row .btn{width:100%;}
  .admin-mini-list a{grid-template-columns:1fr;}
  .admin-mini-list em{white-space:normal;}
}


/* v32: 상담 연락처 자동 하이픈 / 모달 카카오 영역 정리 */
.consult-kakao-box .consult-kakao-title,
.consult-kakao-box strong{
  font-weight:700 !important;
  font-size:15px !important;
  line-height:1.45 !important;
  letter-spacing:-.035em !important;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.consult-kakao-box span{
  font-weight:400 !important;
  line-height:1.55 !important;
}
.consult-kakao-box .consult-modal-kakao-btn{
  flex:0 0 58px !important;
  width:58px !important;
  min-width:58px !important;
  max-width:58px !important;
  height:58px !important;
  min-height:58px !important;
  padding:0 !important;
  border:0 !important;
  border-radius:50% !important;
  background:#FEE500 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:0 12px 28px rgba(0,0,0,.16) !important;
  transition:transform .2s ease, box-shadow .2s ease !important;
}
.consult-kakao-box .consult-modal-kakao-btn:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 16px 30px rgba(0,0,0,.2) !important;
}
.consult-kakao-box .consult-modal-kakao-btn img{
  width:34px !important;
  height:34px !important;
  object-fit:contain !important;
  display:block !important;
}
input[type="tel"],
input[name="phone"]{
  letter-spacing:.01em;
}
@media(max-width:900px){
  .consult-kakao-box .consult-modal-kakao-btn{
    width:58px !important;
    min-width:58px !important;
    max-width:58px !important;
    height:58px !important;
    min-height:58px !important;
    align-self:flex-start !important;
  }
}

/* v33: 관리자 사이드바 간격 정리 + 목록 페이지네이션 */
.admin-sidebar{
  gap:14px !important;
  overflow-y:auto !important;
  scrollbar-width:thin;
}
.admin-brand{
  margin-bottom:4px !important;
}
.admin-side-menu{
  margin-bottom:0 !important;
}
.admin-sidebar-widget{
  margin-top:0 !important;
  flex:0 0 auto;
}
.admin-sidebar-consults{
  margin-bottom:0 !important;
}
.admin-side-user{
  margin-top:0 !important;
  flex:0 0 auto;
}
.admin-sidebar-consult-list{
  max-height:none;
}
.admin-sidebar-consult-list a{
  min-height:78px;
  align-content:center;
}
.admin-count-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:#efe3d0;
  color:#856a42;
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}
.admin-row-actions{
  display:flex !important;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
}
.admin-row-actions .btn,
.admin-table .btn{
  min-height:36px !important;
  height:36px !important;
  padding:0 13px !important;
  border-radius:12px !important;
  font-size:13px !important;
  line-height:1 !important;
}
.admin-body .btn-dark,
.admin-body .btn.btn-dark{
  background:#574c40 !important;
  color:#fff !important;
}
.admin-body .btn-danger,
.admin-body .btn.btn-danger{
  background:#9b4d4d !important;
  color:#fff !important;
}
.admin-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:28px auto 0;
  flex-wrap:wrap;
}
.admin-pagination a,
.admin-pagination span{
  min-width:40px;
  height:40px;
  padding:0 13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #e0d2bf;
  border-radius:999px;
  background:#fffaf4;
  color:#6f604f;
  font-size:13px;
  font-weight:900;
  box-shadow:0 10px 22px rgba(92,76,54,.05);
}
.admin-pagination span{
  border-color:transparent;
  background:transparent;
  box-shadow:none;
  min-width:auto;
  padding:0 4px;
}
.admin-pagination a.active,
.admin-pagination a:hover{
  background:#c8af83;
  border-color:#c8af83;
  color:#fff;
}
@media(max-width:1100px){
  .admin-sidebar{gap:12px !important;}
}
@media(max-width:768px){
  .admin-count-badge{width:100%;}
  .admin-pagination{gap:6px;margin-top:22px;}
  .admin-pagination a,.admin-pagination span{min-width:36px;height:36px;padding:0 11px;font-size:12px;}
  .admin-row-actions .btn,.admin-table .btn{height:34px!important;min-height:34px!important;padding:0 11px!important;}
}

/* v34: 관리자 모바일 최적화 - 사이드바/상담관리/후기관리/방문자 로그 */
@media(max-width:900px){
  body.admin-body{
    background:linear-gradient(135deg,#f3f0ea 0%,#fbf8f2 52%,#eadfce 100%) !important;
  }
  .admin-shell{
    display:block !important;
    min-height:auto !important;
  }
  .admin-sidebar{
    position:relative !important;
    top:auto !important;
    height:auto !important;
    min-height:0 !important;
    overflow:visible !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
    padding:16px 14px !important;
    border-radius:0 0 24px 24px !important;
    box-shadow:0 14px 34px rgba(57,47,38,.16) !important;
  }
  .admin-brand{
    padding:0 2px 12px !important;
    margin:0 !important;
    border-bottom:1px solid rgba(255,255,255,.16) !important;
    align-items:flex-start !important;
  }
  .admin-brand span{
    font-size:30px !important;
  }
  .admin-brand small{
    font-size:12px !important;
  }
  .admin-side-menu{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:8px !important;
    margin:0 !important;
  }
  .admin-side-menu a{
    min-height:42px !important;
    justify-content:center !important;
    text-align:center !important;
    padding:0 10px !important;
    border-radius:14px !important;
    font-size:13px !important;
    transform:none !important;
  }
  .admin-sidebar-widget{
    margin:0 !important;
    padding:14px !important;
    border-radius:18px !important;
  }
  .admin-sidebar-visits,
  .admin-sidebar-consults{
    width:100% !important;
  }
  .admin-sidebar-widget>strong{
    font-size:28px !important;
  }
  .admin-sidebar-consult-list{
    gap:7px !important;
    margin-top:12px !important;
  }
  .admin-sidebar-consult-list a{
    min-height:auto !important;
    padding:9px 10px !important;
    border-radius:13px !important;
  }
  .admin-side-user{
    margin:0 !important;
    padding:14px !important;
    border-radius:18px !important;
  }
  .admin-main{
    width:100% !important;
    padding:16px 14px 34px !important;
  }
  .admin-page-head{
    margin-bottom:14px !important;
    padding:18px 16px !important;
    border-radius:20px !important;
    gap:12px !important;
  }
  .admin-page-head span{
    font-size:11px !important;
    letter-spacing:.1em !important;
  }
  .admin-page-head h1{
    font-size:23px !important;
  }
  .admin-view-site{
    width:100% !important;
    min-height:42px !important;
  }
  .admin-card,
  .admin-dashboard-card{
    border-radius:18px !important;
    padding:18px 16px !important;
  }
  .admin-section-title{
    font-size:20px !important;
    margin:0 0 10px !important;
  }
  .admin-subtitle{
    font-size:13px !important;
    line-height:1.65 !important;
  }
  .admin-form,
  .admin-mini-grid,
  .admin-two-col{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .admin-form input,
  .admin-form select,
  .admin-form textarea{
    min-height:46px !important;
    border-radius:13px !important;
    font-size:14px !important;
  }
  .admin-form textarea{
    min-height:130px !important;
  }
  .admin-dashboard{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
}

@media(max-width:760px){
  .admin-responsive-table{
    display:block !important;
    width:100% !important;
    border:0 !important;
    background:transparent !important;
    border-radius:0 !important;
    overflow:visible !important;
  }
  .admin-responsive-table thead{
    display:none !important;
  }
  .admin-responsive-table tbody,
  .admin-responsive-table tr,
  .admin-responsive-table td{
    display:block !important;
    width:100% !important;
  }
  .admin-responsive-table tr{
    margin:0 0 12px !important;
    padding:12px 14px !important;
    border:1px solid #e3d6c3 !important;
    border-radius:18px !important;
    background:#fffaf4 !important;
    box-shadow:0 12px 26px rgba(92,76,54,.07) !important;
  }
  .admin-responsive-table td{
    position:relative !important;
    min-height:40px !important;
    padding:9px 0 9px 92px !important;
    border:0 !important;
    border-bottom:1px solid #efe5d6 !important;
    text-align:left !important;
    color:#4a433b !important;
    font-size:14px !important;
    line-height:1.55 !important;
    white-space:normal !important;
    word-break:break-word !important;
    overflow:visible !important;
  }
  .admin-responsive-table td:last-child{
    border-bottom:0 !important;
    padding-bottom:0 !important;
  }
  .admin-responsive-table td::before{
    content:attr(data-label);
    position:absolute;
    left:0;
    top:10px;
    width:78px;
    color:#9a8565;
    font-size:12px;
    font-weight:900;
    letter-spacing:-.025em;
  }
  .admin-responsive-table td[colspan]{
    padding:18px 0 !important;
    text-align:center !important;
  }
  .admin-responsive-table td[colspan]::before{
    display:none !important;
  }
  .admin-responsive-table td small{
    display:block;
    margin-top:4px;
    color:#8a7a65;
    font-size:12px;
    line-height:1.45;
    word-break:break-all;
  }
  .admin-mobile-message{
    line-height:1.75 !important;
  }
  .admin-mobile-actions{
    padding-left:0 !important;
    padding-top:34px !important;
  }
  .admin-mobile-actions::before{
    top:9px !important;
  }
  .admin-row-actions{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:7px !important;
    width:100% !important;
  }
  .admin-row-actions form{
    display:inline-flex !important;
    margin:0 !important;
  }
  .admin-row-actions .btn,
  .admin-table .btn{
    flex:1 1 72px !important;
    min-width:72px !important;
    height:38px !important;
    min-height:38px !important;
    padding:0 12px !important;
    border-radius:999px !important;
    font-size:13px !important;
  }
  .admin-pagination{
    justify-content:flex-start !important;
    gap:6px !important;
    margin-top:18px !important;
    overflow-x:auto !important;
    flex-wrap:nowrap !important;
    padding:2px 0 8px !important;
  }
  .admin-pagination a,
  .admin-pagination span{
    flex:0 0 auto !important;
    min-width:36px !important;
    height:36px !important;
    padding:0 11px !important;
    font-size:12px !important;
  }
}

@media(max-width:420px){
  .admin-sidebar{
    padding:14px 10px !important;
    gap:10px !important;
  }
  .admin-side-menu{
    gap:7px !important;
  }
  .admin-side-menu a{
    min-height:39px !important;
    font-size:12px !important;
    padding:0 7px !important;
  }
  .admin-main{
    padding:14px 10px 30px !important;
  }
  .admin-card,
  .admin-dashboard-card{
    padding:16px 13px !important;
  }
  .admin-responsive-table tr{
    padding:11px 12px !important;
    border-radius:16px !important;
  }
  .admin-responsive-table td{
    padding-left:82px !important;
    font-size:13px !important;
  }
  .admin-responsive-table td::before{
    width:70px !important;
    font-size:11px !important;
  }
}

/* v32: company page + SEO/social channel polish */
.sns a.sns-blog{
  width:auto;
  min-width:58px;
  padding:0 12px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.03em;
}
.sns a.sns-insta{
  font-size:13px;
}
.company-hero{
  min-height:470px;
  background-position:center;
}
.company-hero::after{
  background:linear-gradient(90deg,rgba(24,22,19,.68),rgba(24,22,19,.34) 50%,rgba(24,22,19,.12));
}
.company-hero-copy .company-eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.36);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#f3dfb6;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:16px;
}
.company-page{
  width:min(1120px,calc(100% - 48px));
  margin:58px auto 76px;
}
.company-greeting-card{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  align-items:stretch;
}
.company-greeting-main,
.company-profile-box,
.company-point-grid article,
.company-process-grid div{
  border:1px solid #e3d7c6;
  background:#fffaf4;
  box-shadow:0 16px 36px rgba(84,66,44,.07);
}
.company-greeting-main{
  border-radius:30px;
  padding:44px 42px;
  background:linear-gradient(135deg,#fffaf4,#f3eadc);
}
.company-greeting-main>span,
.company-section-head span,
.company-final-cta>span{
  color:#b3905e;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
}
.company-greeting-main h2{
  margin-top:14px;
  color:#3f382f;
  font-size:42px;
  line-height:1.18;
  letter-spacing:-.055em;
}
.company-signature{
  margin-top:18px;
  padding:22px 24px;
  border-left:4px solid var(--gold);
  border-radius:18px;
  background:rgba(255,255,255,.58);
  color:#4b4238;
  font-size:22px;
  line-height:1.65;
  letter-spacing:-.04em;
  word-break:keep-all;
}
.company-signature strong{
  color:#9c7441;
  font-weight:900;
}
.company-signature b{
  color:#2f2a24;
  font-weight:900;
}
.company-greeting-main>p:not(.company-signature){
  margin-top:22px;
  color:#665d54;
  font-size:16px;
  line-height:1.9;
  word-break:keep-all;
}
.company-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:28px;
}
.company-profile-box{
  border-radius:30px;
  padding:34px 30px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:#f8f3ec;
}
.company-profile-mark{
  width:82px;
  height:82px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--gold);
  color:#fff;
  font-family:"Cormorant Garamond",serif;
  font-size:23px;
  font-weight:700;
  letter-spacing:.08em;
  margin-bottom:24px;
}
.company-profile-box h3{
  color:#3f382f;
  font-size:28px;
  letter-spacing:-.045em;
  margin-bottom:20px;
}
.company-profile-box dl{
  display:grid;
  gap:12px;
}
.company-profile-box dl div{
  padding:14px 0;
  border-top:1px solid #e5d9c8;
}
.company-profile-box dt{
  color:#9a8566;
  font-size:13px;
  font-weight:900;
  margin-bottom:4px;
}
.company-profile-box dd{
  color:#51483e;
  font-size:15px;
  font-weight:800;
  line-height:1.55;
}
.company-section{
  margin-top:64px;
}
.company-section-head{
  text-align:center;
  margin-bottom:28px;
}
.company-section-head h2{
  margin-top:10px;
  color:#3f382f;
  font-size:38px;
  line-height:1.3;
  letter-spacing:-.055em;
  word-break:keep-all;
}
.company-section-head p{
  margin-top:12px;
  color:#776b5f;
  font-size:16px;
  line-height:1.8;
  word-break:keep-all;
}
.company-point-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.company-point-grid article{
  min-height:260px;
  border-radius:24px;
  padding:28px 24px;
}
.company-point-grid strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:50%;
  background:#efe3d0;
  color:#8b6b3d;
  font-family:"Cormorant Garamond",serif;
  font-size:20px;
  font-weight:800;
  margin-bottom:22px;
}
.company-point-grid h3,
.company-process-grid h3{
  color:#3f382f;
  font-size:22px;
  line-height:1.35;
  letter-spacing:-.04em;
  margin-bottom:12px;
}
.company-point-grid p,
.company-process-grid p{
  color:#6b6259;
  font-size:15px;
  line-height:1.82;
  word-break:keep-all;
}
.company-process-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.company-process-grid div{
  border-radius:22px;
  padding:24px 20px;
  min-height:210px;
}
.company-process-grid b{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:#efe3d0;
  color:#8b6b3d;
  font-size:12px;
  font-weight:900;
  margin-bottom:18px;
}
.company-final-cta{
  margin-top:64px;
  padding:48px 42px;
  border-radius:32px;
  background:linear-gradient(135deg,rgba(62,55,47,.96),rgba(118,93,59,.92));
  color:#fff;
  text-align:center;
  box-shadow:0 22px 56px rgba(39,31,22,.18);
}
.company-final-cta h2{
  margin-top:12px;
  font-size:34px;
  line-height:1.3;
  letter-spacing:-.045em;
}
.company-final-cta p{
  max-width:680px;
  margin:12px auto 0;
  color:rgba(255,255,255,.88);
  font-size:16px;
  line-height:1.8;
}
.company-final-cta>div{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:12px;
  margin-top:26px;
}
@media(max-width:1100px){
  .company-greeting-card,
  .company-point-grid,
  .company-process-grid{
    grid-template-columns:1fr 1fr;
  }
  .company-greeting-main{
    grid-column:1/-1;
  }
}
@media(max-width:768px){
  .company-hero{
    min-height:410px;
  }
  .company-page{
    width:min(100% - 30px,1120px);
    margin:36px auto 54px;
  }
  .company-greeting-card,
  .company-point-grid,
  .company-process-grid{
    grid-template-columns:1fr;
  }
  .company-greeting-main,
  .company-profile-box,
  .company-final-cta{
    border-radius:22px;
    padding:28px 20px;
  }
  .company-greeting-main h2{
    font-size:31px;
  }
  .company-signature{
    padding:18px 18px;
    font-size:18px;
  }
  .company-actions,
  .company-final-cta>div{
    flex-direction:column;
  }
  .company-actions .member-primary-btn,
  .company-actions .member-outline-btn,
  .company-final-cta .member-primary-btn,
  .company-final-cta .member-kakao-btn{
    width:100%;
  }
  .company-section{
    margin-top:44px;
  }
  .company-section-head{
    text-align:left;
  }
  .company-section-head h2,
  .company-final-cta h2{
    font-size:27px;
  }
  .company-point-grid article,
  .company-process-grid div{
    min-height:auto;
    padding:24px 20px;
  }
  .sns a.sns-blog{
    min-width:54px;
  }
}

/* v35: 메인 히어로 회원권 문구 추가 */
.hero-copy{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  z-index:14;
  width:min(1120px, calc(100% - 96px));
  color:#fff;
  text-align:left;
  pointer-events:none;
  text-shadow:0 3px 18px rgba(0,0,0,.32);
}
.hero-copy span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 15px;
  border:1px solid rgba(255,255,255,.45);
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#f3dfb6;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}
.hero-copy h1{
  max-width:760px;
  font-size:56px;
  line-height:1.12;
  font-weight:900;
  letter-spacing:-.06em;
  word-break:keep-all;
}
.hero-copy p{
  max-width:720px;
  margin-top:18px;
  font-size:19px;
  line-height:1.8;
  font-weight:600;
  color:rgba(255,255,255,.93);
  letter-spacing:-.035em;
  word-break:keep-all;
}
@media(max-width:900px){
  .hero-copy{
    width:min(100% - 48px, 1120px);
    top:54%;
  }
  .hero-copy span{
    min-height:30px;
    padding:0 12px;
    font-size:10px;
    letter-spacing:.12em;
    margin-bottom:12px;
  }
  .hero-copy h1{
    font-size:36px;
    line-height:1.18;
  }
  .hero-copy p{
    margin-top:13px;
    font-size:15px;
    line-height:1.65;
    max-width:420px;
  }
}
@media(max-width:520px){
  .hero-copy{
    width:calc(100% - 36px);
  }
  .hero-copy h1{
    font-size:30px;
  }
  .hero-copy p{
    font-size:14px;
  }
  .hero-copy p br{
    display:none;
  }
}

/* v35: STORY 영역 - 브랜드명 제거 후 제목/슬라이드 제목 간격 보정 */
.story-text .story-title {
  margin-bottom: 16px !important;
}

.story-text .story-title::after {
  content: "";
  display: block;
  width: 34px;
  height: 2px;
  background: var(--gold);
  margin-top: 14px;
}

.story-text .story-slide-title {
  margin-top: 0 !important;
}

@media (max-width: 768px) {
  .story-text .story-title {
    margin-bottom: 12px !important;
  }

  .story-text .story-title::after {
    margin-top: 10px;
  }
}

/* v36: 모바일 햄버거 메뉴 그룹형 정리
   - 기본 메뉴 / SONO STORY / 고객 안내 / 상담신청 분리
   - header.php의 mobile-nav-panel 내부에 mobile-menu-group 구조를 넣으면 적용됩니다. */
@media (max-width: 900px) {
  .mobile-nav-panel {
    left: 14px !important;
    right: 14px !important;
    top: 68px !important;
    display: none !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    max-height: calc(100vh - 88px) !important;
    overflow-y: auto !important;
    padding: 16px !important;
    border-radius: 24px !important;
    background: rgba(63,54,45,.98) !important;
    box-shadow: 0 22px 50px rgba(0,0,0,.22) !important;
    -webkit-overflow-scrolling: touch;
  }

  .site-header.mobile-open .mobile-nav-panel {
    display: block !important;
  }

  .mobile-menu-group {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .mobile-menu-group.mobile-menu-story {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .mobile-menu-group.mobile-menu-sub {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .mobile-menu-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 16px 4px 8px;
    color: #d8c094;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .14em;
  }

  .mobile-menu-section-title::after {
    content: "";
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,.15);
  }

  .mobile-menu-group a,
  .mobile-nav-panel .mobile-consult-btn {
    aspect-ratio: auto !important;
    min-height: 40px !important;
    height: auto !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    line-height: 1.2 !important;
    background: rgba(255,255,255,.09) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    color: #fff !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    letter-spacing: -.045em !important;
    white-space: nowrap !important;
    box-shadow: none !important;
  }

  .mobile-menu-group a::after,
  .mobile-nav-panel .mobile-consult-btn::after {
    display: none !important;
    content: none !important;
  }

  .mobile-menu-primary a:nth-child(1),
  .mobile-menu-primary a:nth-child(4),
  .mobile-menu-story a,
  .mobile-menu-sub a:hover {
    background: rgba(200,175,131,.20) !important;
  }

  .mobile-nav-panel .mobile-consult-btn {
    width: 100% !important;
    margin-top: 14px !important;
    min-height: 44px !important;
    background: linear-gradient(135deg, #c8af83, #b99661) !important;
    border-color: rgba(255,255,255,.18) !important;
    cursor: pointer !important;
    font-family: "Noto Sans KR", sans-serif !important;
  }
}

@media (max-width: 420px) {
  .mobile-nav-panel {
    left: 10px !important;
    right: 10px !important;
    top: 66px !important;
    gap: 10px !important;
    padding: 12px !important;
    border-radius: 20px !important;
  }

  .mobile-menu-group {
    gap: 7px !important;
  }

  .mobile-menu-group a,
  .mobile-nav-panel .mobile-consult-btn {
    min-height: 36px !important;
    padding: 0 7px !important;
    font-size: 11px !important;
  }

  .mobile-menu-section-title {
    margin: 14px 3px 7px !important;
    font-size: 10px !important;
  }
}

/* v37: 이미지 관리 페이지 CSS 복구/정리 - 현재 style.css 기준 추가 */
.admin-image-manager{
  overflow:hidden;
}
.admin-image-manager .admin-section-title{
  margin-top:0;
}
.admin-image-note{
  margin:16px 0 20px;
  padding:18px 20px;
  border:1px solid #e7d7c0;
  border-radius:20px;
  background:linear-gradient(135deg,#fffaf2,#f7efe3);
  color:#5f5449;
  font-size:14px;
  line-height:1.75;
  word-break:keep-all;
}
.admin-image-note strong{
  color:#3f382f;
  font-weight:900;
}
.admin-image-summary{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:20px 0 22px;
}
.admin-image-summary-card{
  min-height:118px;
  padding:22px 20px;
  border:1px solid #e3d6c4;
  border-radius:22px;
  background:linear-gradient(135deg,#fffaf4,#f5ecdf);
  box-shadow:0 14px 30px rgba(86,67,43,.07);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.admin-image-summary-card span{
  color:#8f7b61;
  font-size:13px;
  font-weight:900;
  letter-spacing:-.02em;
}
.admin-image-summary-card strong{
  color:#3f382f;
  font-size:36px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.045em;
}
.admin-image-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin:0 0 20px;
  padding:16px;
  border:1px solid #e4d7c4;
  border-radius:22px;
  background:#fffaf4;
  box-shadow:0 12px 28px rgba(86,67,43,.055);
}
.admin-image-filter{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.admin-image-filter a{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 14px;
  border:1px solid #e0d2bf;
  border-radius:999px;
  background:#fff;
  color:#6f604f;
  font-size:13px;
  font-weight:900;
  letter-spacing:-.025em;
  transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
}
.admin-image-filter a:hover,
.admin-image-filter a.active{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
  transform:translateY(-1px);
}
.admin-image-filter select,
.admin-image-filter input[type="text"]{
  height:38px;
  border:1px solid #ddd1c0;
  border-radius:999px;
  background:#fff;
  color:#4a433b;
  font-size:13px;
  padding:0 13px;
  outline:none;
}
.admin-image-filter select{
  min-width:140px;
}
.admin-image-filter input[type="text"]{
  min-width:230px;
}
.admin-image-filter button{
  min-height:38px;
  padding:0 16px;
  border:0;
  border-radius:999px;
  background:#574c40;
  color:#fff;
  font-size:13px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(73,58,39,.12);
}
.admin-image-page-info{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  margin:0 0 12px;
  padding:0 14px;
  border-radius:999px;
  background:#efe3d0;
  color:#7b6040;
  font-size:13px;
  font-weight:900;
}
.admin-image-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.admin-image-manager .admin-table{
  overflow:hidden;
  border:1px solid #e4d7c4;
  box-shadow:0 12px 28px rgba(86,67,43,.055);
}
.admin-image-manager .admin-table th{
  background:#efe4d3;
  color:#4b4035;
  font-weight:900;
  white-space:nowrap;
}
.admin-image-manager .admin-table td{
  background:#fffdf9;
  vertical-align:middle;
}
.admin-image-check{
  width:17px;
  height:17px;
  accent-color:var(--gold);
}
.admin-image-preview{
  width:118px;
  height:78px;
  object-fit:cover;
  border-radius:14px;
  border:1px solid #e0d2bf;
  background:#f2eadf;
  box-shadow:0 8px 18px rgba(65,51,35,.08);
}
.admin-image-path{
  display:block;
  max-width:360px;
  color:#3f382f;
  font-size:13px;
  font-weight:900;
  line-height:1.45;
  word-break:break-all;
}
.admin-image-meta{
  display:block;
  margin-top:6px;
  color:#8a7a65;
  font-size:12px;
  font-weight:700;
}
.admin-image-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.admin-image-status.used{
  background:#e1eadf;
  color:#3f6b45;
}
.admin-image-status.unused{
  background:#fff1d8;
  color:#9a6429;
}
.admin-image-status.archived{
  background:#e7e1d8;
  color:#6f6252;
}
.admin-image-usedby{
  display:flex;
  flex-direction:column;
  gap:5px;
  max-width:340px;
}
.admin-image-usedby span{
  display:block;
  color:#6b6259;
  font-size:12px;
  line-height:1.45;
  word-break:keep-all;
}
.admin-image-missing-list{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.admin-image-missing-list>div{
  padding:15px 16px;
  border:1px solid #e4d7c4;
  border-radius:16px;
  background:#fffaf4;
  color:#6b6259;
  font-size:13px;
  line-height:1.7;
}
.admin-image-missing-list strong{
  color:#9b4d4d;
  word-break:break-all;
}
.admin-image-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:28px auto 0;
  flex-wrap:wrap;
}
.admin-image-pagination a,
.admin-image-pagination span{
  min-width:40px;
  height:40px;
  padding:0 13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #e0d2bf;
  border-radius:999px;
  background:#fffaf4;
  color:#6f604f;
  font-size:13px;
  font-weight:900;
  box-shadow:0 10px 22px rgba(92,76,54,.05);
}
.admin-image-pagination span{
  border-color:transparent;
  background:transparent;
  box-shadow:none;
  min-width:auto;
  padding:0 4px;
}
.admin-image-pagination a.active,
.admin-image-pagination a:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
}

@media(max-width:1100px){
  .admin-image-summary{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .admin-image-toolbar{
    align-items:stretch;
  }
  .admin-image-filter{
    width:100%;
  }
  .admin-image-filter input[type="text"]{
    flex:1 1 220px;
  }
}
@media(max-width:760px){
  .admin-image-note{
    padding:15px 14px;
    border-radius:16px;
    font-size:13px;
  }
  .admin-image-summary{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:9px;
    margin:16px 0;
  }
  .admin-image-summary-card{
    min-height:96px;
    padding:16px 14px;
    border-radius:16px;
  }
  .admin-image-summary-card strong{
    font-size:28px;
  }
  .admin-image-toolbar{
    padding:12px;
    border-radius:18px;
  }
  .admin-image-filter a{
    flex:1 1 calc(50% - 6px);
    min-height:36px;
    padding:0 10px;
    font-size:12px;
  }
  .admin-image-filter select,
  .admin-image-filter input[type="text"],
  .admin-image-filter button{
    width:100%;
    min-width:0;
    height:40px;
  }
  .admin-image-page-info{
    width:100%;
    justify-content:center;
    white-space:normal;
    text-align:center;
    border-radius:14px;
    padding:9px 12px;
    line-height:1.45;
  }
  .admin-image-actions .btn{
    width:100%;
  }
  .admin-image-preview{
    width:100%;
    max-width:220px;
    height:130px;
  }
  .admin-image-path,
  .admin-image-usedby{
    max-width:100%;
  }
  .admin-image-manager .admin-responsive-table td[data-label="미리보기"]{
    padding-left:0 !important;
    padding-top:34px !important;
  }
  .admin-image-manager .admin-responsive-table td[data-label="미리보기"]::before{
    top:9px !important;
  }
  .admin-image-pagination{
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:8px;
  }
  .admin-image-pagination a,
  .admin-image-pagination span{
    flex:0 0 auto;
    min-width:36px;
    height:36px;
    font-size:12px;
  }
}
@media(max-width:420px){
  .admin-image-summary{
    grid-template-columns:1fr;
  }
  .admin-image-filter a{
    flex-basis:100%;
  }
}
