/* =========================================================
   JULY SHORTS - LANDING AI GUIDE WIDGET
   소개페이지 전용 고정 안내톡
========================================================= */

#july-ai-guide-button { position: fixed; right: 22px; bottom: 26px; z-index: 9998; width: 64px; height: 64px; border: 1px solid rgba(255,255,255,.55); border-radius: 50%; padding: 0; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg,#ffffff 0%,#f3f7ff 48%,#efe8ff 100%); color: #111827; cursor: pointer; box-shadow: 0 16px 42px rgba(119,201,255,.26),0 10px 30px rgba(215,152,255,.22),0 0 0 7px rgba(255,255,255,.08); animation: julyAiGuideFloat 2.8s ease-in-out infinite,julyAiGuideGlow 2.6s ease-in-out infinite; }
#july-ai-guide-button::before { content: ""; position: absolute; inset: -5px; border-radius: 50%; background: linear-gradient(135deg,rgba(119,201,255,.55),rgba(215,152,255,.55)); z-index: -1; filter: blur(8px); opacity: .65; }
#july-ai-guide-button img { width: 42px; display: block; filter: drop-shadow(0 3px 8px rgba(17,24,39,.18)); }
#july-ai-guide-button:hover { animation-play-state: paused; transform: translateY(-3px) scale(1.05); }
@keyframes julyAiGuideGlow {
    0%,100% { box-shadow: 0 16px 42px rgba(119,201,255,.22),0 10px 30px rgba(215,152,255,.18),0 0 0 7px rgba(255,255,255,.07); }
    50% { box-shadow: 0 20px 50px rgba(119,201,255,.38),0 14px 38px rgba(215,152,255,.30),0 0 0 10px rgba(255,255,255,.10); }
}
@keyframes julyAiGuideFloat {
    0%,100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}
.july-ai-guide-toast { position: fixed; right: 24px; bottom: 112px; z-index: 9997; max-width: 310px; padding: 13px 16px; border: 1px solid rgba(255,255,255,.70); border-radius: 18px; background: linear-gradient(135deg,#ffffff 0%,#f5f8ff 52%,#f4ecff 100%); color: #111827; font-size: 13px; font-weight: 900; line-height: 1.48; box-shadow: 0 18px 44px rgba(15,23,42,.20),0 8px 24px rgba(119,201,255,.18); opacity: 0; transform: translateY(10px) scale(.98); pointer-events: none; transition: opacity .35s ease,transform .35s ease; word-break: keep-all; }
.july-ai-guide-toast.is-show { opacity: 1; transform: translateY(0) scale(1); }
.july-ai-guide-toast::before { content: "AI GUIDE"; display: inline-flex; align-items: center; height: 20px; margin: 0 0 6px; padding: 0 8px; border-radius: 999px; background: #111827; color: #fff; font-size: 10px; font-weight: 900; letter-spacing: .06em; }
.july-ai-guide-toast::after { content: ""; position: absolute; right: 28px; bottom: -7px; width: 14px; height: 14px; background: #f4ecff; border-right: 1px solid rgba(255,255,255,.70); border-bottom: 1px solid rgba(255,255,255,.70); transform: rotate(45deg); }
#july-ai-guide-panel { position: fixed; right: 24px; bottom: 104px; z-index: 9999; width: 372px; max-width: calc(100vw - 32px); height: 590px; max-height: calc(100vh - 142px); background: #fff; border: 1px solid #e5e7eb; border-radius: 22px; box-shadow: 0 22px 64px rgba(0,0,0,.22); overflow: hidden; display: none; flex-direction: column; }
#july-ai-guide-panel.is-open { display: flex; }
#july-ai-guide-panel,#july-ai-guide-panel * { text-align: left; box-sizing: border-box; }
.july-ai-guide-header { position: relative; flex: 0 0 auto; padding: 18px 18px 14px; background: radial-gradient(circle at 12% 18%,rgba(119,201,255,.24),transparent 30%),radial-gradient(circle at 84% 12%,rgba(215,152,255,.22),transparent 32%),#111827; color: #fff; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; overflow: hidden; }
.july-ai-guide-header::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: linear-gradient(90deg,rgba(119,201,255,.65),rgba(215,152,255,.65)); }
.july-ai-guide-title { font-size: 16px; font-weight: 800; margin: 0 0 4px; letter-spacing: -.02em; }
.july-ai-guide-desc { font-size: 12px; font-weight: 500; color: rgba(255,255,255,.75); margin: 0; line-height: 1.45; word-break: keep-all; }
.july-ai-guide-close { border: 0; background: transparent; color: #fff; font-size: 24px; font-weight: 500; cursor: pointer; line-height: 1; padding: 0; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; }
.july-ai-guide-body { flex: 1 1 auto; min-height: 0; padding: 16px; overflow-y: auto; background: #f9fafb; -webkit-overflow-scrolling: touch; }
.july-ai-guide-body::-webkit-scrollbar { width: 7px; }
.july-ai-guide-body::-webkit-scrollbar-track { background: #f3f4f6; }
.july-ai-guide-body::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 999px; }
.july-ai-guide-message { margin-bottom: 12px; display: flex; }
.july-ai-guide-message.assistant { justify-content: flex-start; }
.july-ai-guide-message.user { justify-content: flex-end; }
.july-ai-guide-bubble { max-width: 84%; padding: 12px 13px; border-radius: 16px; font-size: 14px; line-height: 1.58; word-break: keep-all; overflow-wrap: break-word; white-space: pre-line; }
.july-ai-guide-message.assistant .july-ai-guide-bubble { background: #fff; color: #111827; border: 1px solid #e5e7eb; border-top-left-radius: 4px; }
.july-ai-guide-message.user .july-ai-guide-bubble { background: #111827; color: #fff; border-top-right-radius: 4px; }
.july-ai-guide-typing .july-ai-guide-bubble { color: #4b5563; }
.july-ai-guide-quick { flex: 0 0 auto; display: flex; flex-wrap: wrap; gap: 8px; max-height: 118px; overflow-y: auto; padding: 0 16px 14px; background: #f9fafb; -webkit-overflow-scrolling: touch; }
.july-ai-guide-quick::-webkit-scrollbar { width: 5px; }
.july-ai-guide-quick::-webkit-scrollbar-track { background: #f3f4f6; }
.july-ai-guide-quick::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 999px; }
.july-ai-guide-quick-btn { border: 1px solid #d1d5db; background: #fff; color: #374151; border-radius: 999px; padding: 8px 11px; font-size: 12px; font-weight: 700; line-height: 1.25; cursor: pointer; transition: background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease; }
.july-ai-guide-quick-btn:hover { background: #111827; border-color: #111827; color: #fff; transform: translateY(-1px); }
.july-ai-guide-disabled-input { flex: 0 0 auto; padding: 14px; border-top: 1px solid #e5e7eb; background: #fff; }
.july-ai-guide-disabled-input span { display: flex; align-items: center; width: 100%; min-height: 42px; border: 1px solid #d1d5db; border-radius: 12px; padding: 0 13px; color: #9ca3af; background: #f9fafb; font-size: 14px; font-weight: 600; word-break: keep-all; }
.july-ai-guide-cta { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.july-ai-guide-cta a { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 12px; border-radius: 999px; text-decoration: none; font-size: 12px; font-weight: 800; line-height: 1; color: #fff; background: #111827; }
.july-ai-guide-cta a:nth-child(2) { background: #6941ff; }
.july-ai-guide-cta a:hover { color: #fff; text-decoration: none; filter: brightness(1.04); }
.july-ai-guide-thumb { display: block; width: 100%; margin-top: 12px; padding: 0; border: 0; background: transparent; cursor: pointer; text-align: left; }
.july-ai-guide-thumb img { display: block; width: 100%; max-height: 180px; object-fit: cover; border-radius: 14px; border: 1px solid #e5e7eb; background: #f3f4f6; }
.july-ai-guide-thumb span { display: inline-flex; align-items: center; height: 28px; margin-top: 7px; padding: 0 10px; border-radius: 999px; background: #f3f0ff; color: #6941ff; font-size: 12px; font-weight: 900; }
.july-ai-guide-thumb:hover img { box-shadow: 0 10px 28px rgba(17,24,39,.14); }
.july-ai-guide-thumb-list { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 7px; margin-top: 12px; }
.july-ai-guide-thumb-list .july-ai-guide-thumb { margin-top: 0; min-width: 0; }
.july-ai-guide-thumb-list .july-ai-guide-thumb img { height: 82px; max-height: none; object-fit: cover; border-radius: 12px; }
.july-ai-guide-thumb-list .july-ai-guide-thumb span { width: 100%; height: 24px; margin-top: 6px; justify-content: center; padding: 0 5px; font-size: 10.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.july-ai-guide-image-viewer { position: fixed; inset: 0; z-index: 100000; display: none; align-items: center; justify-content: center; padding: 20px; background: transparent; }
.july-ai-guide-image-viewer.is-open { display: flex; }
.july-ai-guide-image-viewer__dim { position: absolute; inset: 0; background: rgba(15,23,42,.66); backdrop-filter: blur(4px); }
.july-ai-guide-image-viewer__box { position: relative; z-index: 1; width: min(430px,calc(100vw - 40px)); max-height: calc(100vh - 64px); border-radius: 22px; background: #fff; padding: 10px; box-shadow: 0 24px 70px rgba(15,23,42,.30); overflow: hidden; }
.july-ai-guide-image-viewer__box img { display: block; width: 100%; height: auto; max-height: calc(100vh - 84px); object-fit: contain; border-radius: 16px; background: #f8fafc; }
.july-ai-guide-image-viewer__close { position: absolute; right: 8px; top: 8px; z-index: 2; width: 34px; height: 34px; border: 0; border-radius: 999px; background: rgba(17,24,39,.92); color: #fff; font-size: 22px; font-weight: 500; line-height: 1; cursor: pointer; box-shadow: 0 10px 24px rgba(0,0,0,.24); }
body.july-ai-guide-image-open { overflow: hidden; }
@supports (height:100dvh) {
    .july-ai-guide-image-viewer__box { max-height: calc(100dvh - 64px); }
    .july-ai-guide-image-viewer__box img { max-height: calc(100dvh - 84px); }
}
@supports (height:100dvh) {
    #july-ai-guide-panel { max-height: calc(100dvh - 142px); }
}
/* 소개페이지 하단 모바일 바로가기와 겹침 방지 */
@media(max-width:768px) {
    #july-ai-guide-button { right: 16px; bottom: calc(70px + env(safe-area-inset-bottom)); width: 52px; height: 52px; }
    #july-ai-guide-button img { width: 35px; }
    .july-ai-guide-toast { right: 16px; bottom: calc(138px + env(safe-area-inset-bottom)); max-width: 250px; padding: 10px 12px; border-radius: 15px; font-size: 11.5px; line-height: 1.42; }
    .july-ai-guide-toast::before { height: 17px; margin: 0 0 5px; padding: 0 7px; font-size: 9px; }
    .july-ai-guide-toast::after { right: 24px; }
    #july-ai-guide-panel { left: 12px; right: 12px; top: auto; bottom: calc(144px + env(safe-area-inset-bottom)); width: auto; max-width: none; height: auto; max-height: calc(100vh - 170px - env(safe-area-inset-bottom)); border-radius: 20px; -webkit-transform: translateZ(0); transform: translateZ(0); }
    @supports (height:100dvh) {
        #july-ai-guide-panel { max-height: calc(100dvh - 170px - env(safe-area-inset-bottom)); }
    }
    .july-ai-guide-header { padding: 16px 16px 13px; }
    .july-ai-guide-body { padding: 14px; }
    .july-ai-guide-bubble { max-width: 88%; font-size: 14px; }
    .july-ai-guide-quick { max-height: 98px; padding: 0 14px 12px; }
    .july-ai-guide-disabled-input { padding: 12px 12px calc(12px + env(safe-area-inset-bottom)); }
    .july-ai-guide-disabled-input span { font-size: 13px; }
    .july-ai-guide-thumb img { max-height: 160px; }
    .july-ai-guide-image-viewer { align-items: center; padding: 14px; }
    .july-ai-guide-image-viewer__box { width: min(360px,100%); max-height: calc(100vh - 36px); padding: 8px; border-radius: 20px; }
    .july-ai-guide-image-viewer__box img { max-height: calc(100vh - 52px); border-radius: 15px; }
    .july-ai-guide-image-viewer__close { right: 10px; top: 10px; width: 32px; height: 32px; font-size: 21px; }
    @supports (height:100dvh) {
        .july-ai-guide-image-viewer__box { max-height: calc(100dvh - 36px); }
        .july-ai-guide-image-viewer__box img { max-height: calc(100dvh - 52px); }
    }
}
@media(max-width:480px) {
    #july-ai-guide-button { right: 16px; bottom: calc(66px + env(safe-area-inset-bottom)); width: 50px; height: 50px; }
    #july-ai-guide-button img { width: 34px; }
    .july-ai-guide-toast { right: 16px; bottom: calc(132px + env(safe-area-inset-bottom)); max-width: 235px; padding: 9px 11px; border-radius: 14px; font-size: 11px; line-height: 1.38; }
    .july-ai-guide-toast::before { height: 16px; margin-bottom: 4px; padding: 0 6px; font-size: 8.5px; }
    .july-ai-guide-toast::after { right: 22px; }
    #july-ai-guide-panel { left: 10px; right: 10px; bottom: calc(136px + env(safe-area-inset-bottom)); max-height: calc(100vh - 158px - env(safe-area-inset-bottom)); border-radius: 18px; }
    .july-ai-guide-thumb-list { gap: 6px; }
    .july-ai-guide-thumb-list .july-ai-guide-thumb img { height: 74px; border-radius: 10px; }
    .july-ai-guide-thumb-list .july-ai-guide-thumb span { height: 22px; font-size: 10px; padding: 0 4px; }
    @supports (height:100dvh) {
        #july-ai-guide-panel { max-height: calc(100dvh - 158px - env(safe-area-inset-bottom)); }
    }
    .july-ai-guide-title { font-size: 15px; }
    .july-ai-guide-desc { font-size: 11px; }
    .july-ai-guide-bubble { max-width: 90%; font-size: 13.5px; padding: 11px 12px; }
    .july-ai-guide-quick-btn { font-size: 11.5px; padding: 7px 10px; }
    .july-ai-guide-cta a { width: 100%; }
    .july-ai-guide-image-viewer { padding: 10px; }
    .july-ai-guide-image-viewer__box { width: min(330px,100%); max-height: calc(100vh - 28px); padding: 7px; border-radius: 18px; }
    .july-ai-guide-image-viewer__box img { max-height: calc(100vh - 42px); border-radius: 14px; }
    @supports (height:100dvh) {
        .july-ai-guide-image-viewer__box { max-height: calc(100dvh - 28px); }
        .july-ai-guide-image-viewer__box img { max-height: calc(100dvh - 42px); }
    }
}