html, body { margin: 0; padding: 0; background: #050816; }
.shorts_btn{position:fixed;left:0;bottom:15%;z-index:999;display:inline-flex;align-items:flex-start;justify-content:center;flex-direction:column;min-width:96px;min-height:142px;padding:18px 14px 18px 13px;border:1px solid rgba(255,255,255,.60);border-left:0;border-radius:0 28px 28px 0;text-decoration:none;cursor:pointer;overflow:hidden;background:linear-gradient(135deg,#ffffff 0%,#f3f7ff 48%,#efe8ff 100%);color:#111827!important;box-shadow:0 16px 42px rgba(119,201,255,.24),0 10px 30px rgba(215,152,255,.20),0 0 0 7px rgba(255,255,255,.07);animation:shortsFloat 2.8s ease-in-out infinite,shortsGlow 2.6s ease-in-out infinite;transition:transform .22s ease,box-shadow .22s ease;}
.shorts_btn::before{content:"";position:absolute;inset:-30%;background:linear-gradient(120deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.72) 46%,rgba(255,255,255,0) 72%);transform:translateX(-85%) rotate(14deg);animation:shortsShine 3.2s ease-in-out infinite;pointer-events:none;}
.shorts_btn::after{content:"";position:absolute;inset:auto -18px -22px auto;width:78px;height:78px;border-radius:999px;background:radial-gradient(circle,rgba(119,201,255,.32),rgba(215,152,255,.05) 68%,transparent 72%);pointer-events:none;}
.shorts_btn:hover{transform:translateY(-4px);box-shadow:0 22px 54px rgba(119,201,255,.34),0 14px 36px rgba(215,152,255,.28),0 0 0 9px rgba(255,255,255,.10);text-decoration:none;}
.shorts_btn div{position:relative;z-index:1;width:46px;height:46px;margin-bottom:12px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#111827;box-shadow:0 10px 24px rgba(17,24,39,.20);}
.shorts_btn img{width:34px;margin:0;border-radius:11px;display:block;animation:shortsPop 1.8s ease-in-out infinite;}
.shorts_btn h3{position:relative;z-index:1;margin:0 0 7px;padding:4px 8px;border-radius:999px;background:#111827;color:#fff;font-size:11px;font-weight:900;line-height:1;letter-spacing:-.02em;}
.shorts_btn h1{position:relative;z-index:1;margin:0;color:#111827;font-size:16px;font-weight:900;line-height:1.34;letter-spacing:-.055em;word-break:keep-all;}
.shorts_btn span{font-size:40px;font-weight:900;letter-spacing:-1.8px;background:linear-gradient(90deg,#77c9ff 0%,#d798ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
@keyframes shortsFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-7px);}
}
@keyframes shortsPop{
  0%,100%{transform:scale(1) rotate(0deg);}
  22%{transform:scale(1.08) rotate(-4deg);}
  44%{transform:scale(.98) rotate(3deg);}
  66%{transform:scale(1.05) rotate(-2deg);}
  82%{transform:scale(1) rotate(0deg);}
}
@keyframes shortsGlow{
  0%,100%{box-shadow:0 16px 42px rgba(119,201,255,.24),0 10px 30px rgba(215,152,255,.20),0 0 0 7px rgba(255,255,255,.07);}
  50%{box-shadow:0 22px 56px rgba(119,201,255,.40),0 14px 38px rgba(215,152,255,.32),0 0 0 10px rgba(255,255,255,.10);}
}
@keyframes shortsShine{
  0%{transform:translateX(-95%) rotate(14deg);}
  52%{transform:translateX(115%) rotate(14deg);}
  100%{transform:translateX(115%) rotate(14deg);}
}
.shorts_btn_mobile { display: none; }
/* hero */
.july-hero { position: relative; overflow: hidden; background: radial-gradient(circle at 18% 20%, rgba(103, 184, 255, 0.18), transparent 24%), radial-gradient(circle at 82% 18%, rgba(138, 125, 255, 0.16), transparent 24%), radial-gradient(circle at 70% 72%, rgba(239, 154, 215, 0.08), transparent 22%), linear-gradient(180deg, #050816 0%, #0a0f21 48%, #0d1329 100%); color: #fff; }
.july-hero__bg { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 28px 28px; mask-image: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.08)); }
.july-hero__inner { position: relative; z-index: 1; width: 100%; max-width: 1600px; margin: 0 auto; padding: 110px 56px 80px; display: grid; grid-template-columns: minmax(0, 660px) minmax(0, 1fr); gap: 40px; align-items: center; }
.july-hero__content { position: relative; z-index: 5; max-width: 660px; }
.july-hero__eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 20px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.06); backdrop-filter: blur(8px); color: #86b6ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; }
.july-hero__title { margin: 0 0 18px; font-size: clamp(52px, 6vw, 52px); line-height: 1.02; letter-spacing: -0.06em; font-weight: 300; color: #fff; }
.july-hero__title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-hero__desc { margin: 0; color: rgba(255,255,255,0.82); font-size: 20px; line-height: 1.5; font-weight: 500; letter-spacing: -0.03em; }
.july-hero__actions { display: flex; align-items: center; flex-wrap: wrap; gap: 16px; margin-top: 36px; }
.july-hero__actions .july-btn { display: inline-flex; align-items: center; justify-content: center; min-width: 190px; height: 62px; padding: 0 30px; border-radius: 999px; font-size: 18px; font-weight: 800; text-decoration: none; transition: .25s ease; }
.july-hero__actions .july-btn:hover { transform: translateY(-2px); }
.july-hero__actions .july-btn--primary { background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f !important; box-shadow: 0 12px 30px rgba(119, 130, 255, 0.2); }
.july-hero__actions .july-btn--ghost { border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: #fff !important; backdrop-filter: blur(10px); }
.july-hero__actions .july-btn--ghost:hover { background: rgba(255,255,255,0.12); }
.july-hero__chips { display: flex; flex-wrap: wrap; gap: 12px; margin: 32px 0 0; }
.july-hero__chip { display: inline-flex; align-items: center; min-height: 44px; padding: 0 18px; border: 1px solid rgba(255,255,255,0.10); border-radius: 999px; background: rgba(9, 12, 26, 0.34); color: rgba(255,255,255,0.92); font-size: 15px; font-weight: 600; backdrop-filter: blur(12px); }
.july-hero__visual { position: relative; min-height: 720px; display: flex; align-items: center; justify-content: center; }
.july-hero__glow { position: absolute; border-radius: 999px; filter: blur(90px); pointer-events: none; }
.july-hero__glow--1 { width: 300px; height: 300px; right: 18%; top: 24%; background: rgba(144, 92, 255, 0.14); }
.july-hero__glow--2 { width: 220px; height: 220px; left: 48%; top: 32%; background: rgba(88, 190, 255, 0.08); }
.july-device { position: absolute; user-select: none; }
.july-device--desktop { width: min(760px, 100%); right: 0; top: 50%; transform: translate(20px, -50%); z-index: 6; }
.july-device__frame { position: relative; border-radius: 28px; padding: 14px; background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 100%); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 30px 80px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.10); backdrop-filter: blur(12px); }
.july-device__topbar { display: flex; gap: 7px; align-items: center; height: 18px; margin-bottom: 10px; padding-left: 6px; }
.july-device__topbar span { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,0.22); }
.july-device__viewport { position: relative; overflow-y: auto; overflow-x: hidden; scrollbar-width: none; -ms-overflow-style: none; background: #09111f; }
.july-device__viewport::-webkit-scrollbar { display: none; }
.july-device__viewport.is-paused { outline: 1px solid rgba(103, 184, 255, 0.24); box-shadow: 0 0 0 4px rgba(103, 184, 255, 0.08); }
.july-device__screen { width: 100%; }
.july-device__screen img { display: block; width: 100%; height: auto; }
.july-device--desktop .july-device__viewport { height: 490px; border-radius: 20px; background: linear-gradient(180deg, #0d1528 0%, #111b31 100%); }
.july-device__phone { position: relative; padding: 12px; border-radius: 42px; background: linear-gradient(180deg, #151a24 0%, #080b12 100%); border: 1px solid rgba(255,255,255,0.16); box-shadow: 0 25px 70px rgba(0,0,0,0.46), inset 0 1px 0 rgba(255,255,255,0.08); }
.july-device__notch { position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 92px; height: 18px; border-radius: 999px; background: rgba(0,0,0,0.85); z-index: 3; }
.july-device--mobile .july-device__viewport { height: 560px; border-radius: 32px; background: linear-gradient(180deg, #0d1528 0%, #111b31 100%); }
/* intro */
.july-intro { position: relative; padding: 120px 0 130px; background: radial-gradient(circle at 50% 10%, rgba(118, 90, 255, 0.12) 0%, rgba(118, 90, 255, 0) 38%), linear-gradient(180deg, #090d1d 0%, #0b1022 100%); overflow: hidden; border-bottom: 0; }
.july-intro::before { content: ""; position: absolute; top: 50%; left: 50%; width: 760px; height: 760px; transform: translate(-50%, -50%); border-radius: 999px; background: rgba(131, 92, 255, 0.05); filter: blur(120px); pointer-events: none; }
.july-intro .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-intro__head { max-width: 1080px; margin: 0 auto; text-align: center; }
.july-intro__eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 18px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; backdrop-filter: blur(8px); }
.july-intro__title { margin: 0; color: #fff; font-size: clamp(34px, 4.2vw, 52px); line-height: 1.18; letter-spacing: -0.055em; font-weight: 300; word-break: keep-all; }
.july-intro__title strong { color: #fff; font-weight: 700; }
.july-intro__title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight: 300; }
.july-intro__desc { margin: 28px auto 0; max-width: 860px; color: rgba(255,255,255,0.74); font-size: 20px; line-height: 1.8; font-weight: 500; letter-spacing: -0.02em; word-break: keep-all; }
.july-intro__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; margin-top: 56px; }
.july-intro__card { position: relative; min-height: 300px; padding: 30px 28px 28px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.05) 100%); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.18); backdrop-filter: blur(12px); transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease; }
.july-intro__card:hover { transform: translateY(-8px); box-shadow: 0 26px 58px rgba(3, 6, 18, 0.24); border-color: rgba(119, 201, 255, 0.20); }
.july-intro__card::after { content: ""; position: absolute; left: 28px; right: 28px; bottom: 0; height: 3px; border-radius: 999px; background: linear-gradient(90deg, #7bc9ff 0%, #d89aff 100%); opacity: 0.82; }
.july-intro__icon { display: inline-flex; align-items: center; justify-content: center; min-width: 56px; height: 56px; margin-bottom: 22px; padding: 0 16px; border-radius: 999px; background: linear-gradient(135deg, #77c9ff 0%, #d798ff 100%); color: #08111f; font-size: 15px; font-weight: 300; letter-spacing: 0.04em; box-shadow: 0 10px 25px rgba(119, 201, 255, 0.18); }
.july-intro__card h3 { margin: 0; color: #fff; font-size: 28px; line-height: 1.28; letter-spacing: -0.045em; font-weight: 300; text-align: center; }
.july-intro__card p { margin: 18px 0 0; color: rgba(255,255,255,0.68); font-size: 17px; line-height: 1.8; font-weight: 500; letter-spacing: -0.02em; word-break: keep-all; }
.july-intro__bottom { margin-top: 44px; text-align: center; }
.july-intro__bottom-text { margin: 0 0 22px; color: #fff; font-size: 22px; line-height: 1.7; font-weight: 500; letter-spacing: -0.03em; word-break: keep-all; }
.july-intro__bottom-text strong { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight: 300; }
.july-intro__cta { display: inline-flex; align-items: center; justify-content: center; min-width: 220px; height: 60px; padding: 0 28px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 17px; font-weight: 800; text-decoration: none; letter-spacing: -0.02em; box-shadow: 0 14px 32px rgba(115, 126, 255, 0.24); transition: .25s ease; }
.july-intro__cta:hover { transform: translateY(-2px); color: #08111f; text-decoration: none; }
.mobile-only { display: none; }
/* desktop hero full screen */
@media (min-width:992px) {
  .july-hero { min-height: 110vh; padding:0; display: flex; align-items: center; }
  .july-hero__inner { min-height: 100vh; padding: 0px 56px 0px; align-items: center; }
  .july-hero__content { padding-top: 40px; }
  .july-hero__visual { min-height: 100vh; }
}
/* 1600 */
@media (max-width:1600px) {
  .july-hero__content { max-width: 590px; }
  .july-hero__desc { font-size: 22px; }
  .july-hero__inner { grid-template-columns: minmax(0, 590px) minmax(0, 1fr); gap: 20px; }
}
/* 1280 */
@media (max-width:1280px) {
  .july-hero__inner { padding: 100px 28px 48px; }
  .july-hero__content { max-width: 520px; padding-top: 10px; }
  .july-hero__desc { font-size: 20px; }
  .july-hero__actions .july-btn { height: 56px; min-width: 170px; font-size: 16px; }
  .july-device--desktop { width: min(680px, 100%); transform: translate(8px, -50%); }
  .july-intro { padding: 100px 0 110px; }
  .july-intro .container { padding: 0 28px; }
  .july-intro__grid { gap: 18px; }
  .july-intro__card { min-height: 280px; padding: 28px 24px 24px; border-radius: 24px; }
  .july-intro__card::after { left: 24px; right: 24px; }
  .july-intro__card h3 { font-size: 24px; }
  .july-intro__card p { font-size: 16px; }
  .july-hero__inner { grid-template-columns: minmax(0, 500px) minmax(0, 1fr); gap: 20px; }
}
/* tablet */
@media (max-width:1024px) {
  .container { padding: 0 28px; }
  .july-hero { min-height: auto; }
  .july-hero__inner { min-height: auto; grid-template-columns: 1fr; gap: 28px; padding: 90px 28px 40px; }
  .july-hero__content { max-width: 100%; text-align: center; padding-top: 0; order: 1; }
  .july-hero__visual { order: 2; min-height: auto; margin: 0; }
  .july-hero__eyebrow { margin-left: auto; margin-right: auto; }
  .july-hero__desc { font-size: 18px; }
  .july-hero__actions, .july-hero__chips { justify-content: center; }
  .july-device--desktop { position: relative; right: auto; top: auto; transform: none; width: min(76vw, 680px); margin: 0 auto; }
  .july-intro .container { padding: 0 28px; }
  .july-intro__grid { grid-template-columns: 1fr; gap: 18px; }
  .july-intro__card { min-height: auto; }
  .july-intro__desc { font-size: 18px; max-width: 720px; }
  .july-intro__bottom-text { font-size: 20px; }
}
@media (max-width:961px) {
  .header { display: none; }
}
/* mobile */
@media (max-width:768px) {
  .footer { padding-bottom: 90px !important}
  .container { padding: 0 15px; }
  .shorts_btn { display: none; }

  .shorts_btn_mobile{display:flex!important;position:fixed;left:0;right:0;bottom:0;width:100%;height:62px;z-index:9999;align-items:center;justify-content:center;gap:12px;padding:0 16px 0;border:1px solid rgba(255,255,255,.64);border-left:0;border-right:0;border-bottom:0;border-radius:24px 24px 0 0;background:linear-gradient(135deg,#ffffff 0%,#f3f7ff 48%,#efe8ff 100%);color:#08111f!important;text-decoration:none;overflow:hidden;box-shadow:0 -8px 28px rgba(119,201,255,.22),0 -4px 18px rgba(15,23,42,.16);animation:mobileBarPulse 2.6s ease-in-out infinite;}
  .shorts_btn_mobile::before{content:"";position:absolute;top:-16px;left:-42%;width:34%;height:120%;background:linear-gradient(90deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.82) 50%,rgba(255,255,255,0) 100%);transform:skewX(-20deg);animation:mobileShine 3s ease-in-out infinite;}
  .shorts_btn_mobile::after{content:"";position:absolute;right:-30px;bottom:-42px;width:116px;height:116px;border-radius:999px;background:radial-gradient(circle,rgba(119,201,255,.34),rgba(215,152,255,.07) 66%,transparent 72%);pointer-events:none;}
  .shorts_btn_mobile img{position:relative;z-index:1;width:31px;border-radius:10px;display:block;animation:mobileIconPop 1.7s ease-in-out infinite;box-shadow:0 7px 16px rgba(17,24,39,.18);}
  .shorts_btn_mobile_text{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;}
  .shorts_btn_mobile span{display:inline-flex;align-items:center;height:18px;margin-bottom:4px;padding:0 8px;border-radius:999px;background:#111827;color:#fff;font-size:10.5px;font-weight:900;letter-spacing:-.2px;line-height:1;}
  .shorts_btn_mobile_title{display:flex;align-items:center;gap:7px;}
  .shorts_btn_mobile h1{margin:0;color:#111827;font-size:15px;font-weight:900;line-height:1.1;letter-spacing:-.5px;}
  .shorts_btn_mobile_arrow{display:inline-flex;align-items:center;justify-content:center;width:27px;height:27px;border-radius:999px;background:linear-gradient(90deg,#77c9ff 0%,#d798ff 100%);color:#08111f;margin-top:-1px;animation:mobileArrowMove 1.2s ease-in-out infinite;}
  .shorts_btn_mobile_arrow svg{width:17px;height:17px;display:block;}

  @keyframes mobileIconPop{
    0%,100%{transform:scale(1) rotate(0deg);}
    20%{transform:scale(1.08) rotate(-4deg);}
    40%{transform:scale(.98) rotate(3deg);}
    60%{transform:scale(1.05) rotate(-2deg);}
    80%{transform:scale(1) rotate(0deg);}
  }
  @keyframes mobileShine{
    0%{left:-42%;}
    58%{left:124%;}
    100%{left:124%;}
  }
  @keyframes mobileArrowMove{
    0%,100%{transform:translateX(0);}
    50%{transform:translateX(4px);}
  }
  @keyframes mobileBarPulse{
    0%,100%{box-shadow:0 -8px 28px rgba(119,201,255,.20),0 -4px 18px rgba(15,23,42,.15);}
    50%{box-shadow:0 -10px 34px rgba(119,201,255,.32),0 -6px 24px rgba(215,152,255,.22);}
  }

  .july-hero { min-height: auto; padding: 72px 0 56px; }
  .july-hero__inner { grid-template-columns: 1fr; gap: 24px; padding: 0 18px; }
  .july-hero__content { order: 1; max-width: none; text-align: center; }
  .july-hero__visual { order: 2; min-height: auto; margin: 0; }
  .july-hero__title { font-size: clamp(30px, 8vw, 42px); line-height: 1.06; }
  .july-hero__desc { margin-top: 20px; font-size: 16px; line-height: 1.7; }
  .july-hero__actions { flex-direction: column; align-items: stretch; gap: 12px; margin-top: 28px; }
  .july-hero__actions .july-btn { width: 100%; min-width: 0; height: 52px; font-size: 15px; max-width: 220px; margin: 0 auto; }
  .july-hero__chips { gap: 5px; margin-top: 22px; }
  .july-hero__chip { width: 100%; justify-content: center; min-height: 40px; padding: 0 10px; font-size: 12px; }
  .july-device--mobile { position: relative; left: auto; bottom: auto; width: min(88vw, 360px) !important; margin: 0 auto; }
  .july-device--mobile .july-device__viewport { height: 600px; }
  .july-intro { padding: 84px 0 90px; }
  .july-intro .container { padding: 0 18px; }
  .july-intro__eyebrow { margin-bottom: 14px; font-size: 11px; }
  .july-intro__title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-intro__title br { display: none; }
  .july-intro__title br.mobile-only { display: inline; }
  .mobile-only { display: inline; }
  .july-intro__desc { margin-top: 18px; font-size: 16px; line-height: 1.7; }
  .july-intro__grid { gap: 16px; margin-top: 34px; }
  .july-intro__card { padding: 24px 20px 22px; border-radius: 22px; }
  .july-intro__card::after { left: 20px; right: 20px; }
  .july-intro__icon { min-width: 48px; height: 48px; margin-bottom: 18px; font-size: 13px; }
  .july-intro__card h3 { font-size: 22px; line-height: 1.35; }
  .july-intro__card p { margin-top: 16px; font-size: 15px; line-height: 1.7; }
  .july-intro__bottom { margin-top: 30px; }
  .july-intro__bottom-text { margin-bottom: 18px; font-size: 17px; line-height: 1.7; }
  .july-intro__cta { width: 100%; min-width: 100%; height: 52px; font-size: 15px; }
  .july-hero__chips { flex-wrap: nowrap; }
}
@media (max-width:480px) {
  .july-hero__inner, .july-intro .container { padding-left: 15px; padding-right: 15px; }
  .july-device--mobile { width: min(92vw, 360px) !important; }
  .july-device--mobile .july-device__viewport { height: 560px; }
  .shorts_btn_mobile{left:0;right:0;bottom:0;width:100%;height:60px;padding:0 13px;border-radius:22px 22px 0 0;}
  .shorts_btn_mobile img{width:29px;}
  .shorts_btn_mobile h1{font-size:14.5px;}
  .shorts_btn_mobile span{font-size:10px;height:17px;}
}
/* hero - intro 사이 키워드 마키 */
.main-keyword-marquee { position: relative; overflow: hidden; padding: 38px 0 34px; background: linear-gradient(180deg, #070b1a 0%, #0b1022 100%); border-top: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.main-keyword-marquee::before, .main-keyword-marquee::after { content: ""; position: absolute; top: 0; width: 140px; height: 100%; z-index: 2; pointer-events: none; }
.main-keyword-marquee::before { left: 0; background: linear-gradient(90deg, #0a0f21 0%, rgba(10,15,33,0) 100%); }
.main-keyword-marquee::after { right: 0; background: linear-gradient(270deg, #0a0f21 0%, rgba(10,15,33,0) 100%); }
.main-keyword-marquee .marquee-track { display: flex; width: max-content; align-items: center; gap: 0; white-space: nowrap; will-change: transform; }
.main-keyword-marquee .marquee-track-1 { animation: marqueeLeft 34s linear infinite; margin-bottom: 14px; }
.main-keyword-marquee .marquee-track-2 { animation: marqueeRight 30s linear infinite; }
.main-keyword-marquee .marquee-group { display: flex; align-items: center; gap: 18px; padding-right: 18px; }
.main-keyword-marquee .marquee-group span { position: relative; display: inline-flex; align-items: center; justify-content: center; height: 52px; padding: 0 22px; border: 1px solid rgba(255,255,255,0.10); border-radius: 999px; background: rgba(255,255,255,0.04); backdrop-filter: blur(10px); color: rgba(255,255,255,0.88); font-size: 17px; font-weight: 600; letter-spacing: -0.02em; box-shadow: inset 0 1px 0 rgba(255,255,255,0.04); }
.main-keyword-marquee .marquee-track-1 .marquee-group span:nth-child(3n) { color: #9ad7ff; border-color: rgba(103,199,255,0.20); }
.main-keyword-marquee .marquee-track-2 .marquee-group span:nth-child(4n) { color: #d9a8ff; border-color: rgba(203,126,255,0.18); }
@keyframes marqueeLeft {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes marqueeRight {
  0% { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}
/* hover 시 잠깐 멈춤 */
.main-keyword-marquee:hover .marquee-track { animation-play-state: paused; }
@media (max-width:1024px) {
  .main-keyword-marquee { padding: 30px 0 28px; }
  .main-keyword-marquee .marquee-track-1 { margin-bottom: 12px; animation-duration: 28s; }
  .main-keyword-marquee .marquee-track-2 { animation-duration: 24s; }
  .main-keyword-marquee .marquee-group { gap: 14px; padding-right: 14px; }
  .main-keyword-marquee .marquee-group span { height: 46px; padding: 0 18px; font-size: 15px; }
  .main-keyword-marquee::before, .main-keyword-marquee::after { width: 90px; }
}
@media (max-width:768px) {
  .main-keyword-marquee { padding: 24px 0 22px; }
  .main-keyword-marquee .marquee-track-1 { margin-bottom: 10px; animation-duration: 24s; }
  .main-keyword-marquee .marquee-track-2 { animation-duration: 20s; }
  .main-keyword-marquee .marquee-group { gap: 10px; padding-right: 10px; }
  .main-keyword-marquee .marquee-group span { height: 40px; padding: 0 14px; font-size: 13px; }
  .main-keyword-marquee::before, .main-keyword-marquee::after { width: 48px; }
}
/* AI 코딩 세계관 배경 */
.july-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(90, 170, 255, 0.06) 0%, rgba(90, 170, 255, 0) 18%, rgba(0,0,0,0) 82%, rgba(206, 141, 255, 0.06) 100%), repeating-linear-gradient( 180deg, rgba(255,255,255,0.015) 0px, rgba(255,255,255,0.015) 1px, transparent 1px, transparent 24px ); pointer-events: none; z-index: 0; }
.july-hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 22% 26%, rgba(96, 183, 255, 0.10), transparent 28%), radial-gradient(circle at 76% 30%, rgba(190, 117, 255, 0.10), transparent 30%); filter: blur(10px); pointer-events: none; z-index: 0; }
.july-hero__visual { overflow: visible; }
/* 배경에 흐르는 희미한 코드 */
.july-hero__code-layer { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.july-hero__code-layer span { position: absolute; color: rgba(140, 196, 255, 0.12); font-size: 14px; font-weight: 500; letter-spacing: 0.01em; white-space: nowrap; text-shadow: 0 0 18px rgba(119, 201, 255, 0.04); animation: julyCodeFloat 16s linear infinite; }
.july-hero__code-layer span:nth-child(1) { top: 8%; left: 12%; animation-duration: 18s; }
.july-hero__code-layer span:nth-child(2) { top: 18%; right: 6%; animation-duration: 15s; }
.july-hero__code-layer span:nth-child(3) { top: 34%; left: 6%; animation-duration: 19s; }
.july-hero__code-layer span:nth-child(4) { top: 48%; right: 14%; animation-duration: 17s; }
.july-hero__code-layer span:nth-child(5) { bottom: 26%; left: 14%; animation-duration: 20s; }
.july-hero__code-layer span:nth-child(6) { bottom: 18%; right: 20%; animation-duration: 16s; }
.july-hero__code-layer span:nth-child(7) { top: 62%; left: 28%; animation-duration: 21s; }
.july-hero__code-layer span:nth-child(8) { top: 12%; left: 44%; animation-duration: 18s; }
@keyframes julyCodeFloat {
  0% { transform: translate3d(0, 18px, 0); opacity: 0; }
  15% { opacity: 1; }
  50% { opacity: .75; }
  100% { transform: translate3d(0, -28px, 0); opacity: 0; }
}
/* 플로팅 카드 공통 */
.july-floating, .july-console-card { position: absolute; z-index: 8; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.22); }
.july-floating { display: inline-flex; align-items: center; gap: 10px; min-height: 50px; padding: 0 18px; border-radius: 999px; background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.92); font-size: 14px; font-weight: 700; letter-spacing: -0.02em; animation: julyFloat 4.8s ease-in-out infinite; }
.july-floating__dot { width: 8px; height: 8px; border-radius: 50%; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); box-shadow: 0 0 14px rgba(119, 201, 255, 0.5); }
.july-floating__score { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 10px; border-radius: 999px; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); color: #08111f; font-size: 15px; font-weight: 800; }
/* 콘솔 카드 */
.july-console-card { width: 280px; padding: 16px 18px 18px; border-radius: 24px; background: linear-gradient(180deg, rgba(8, 13, 29, 0.86) 0%, rgba(13, 19, 41, 0.78) 100%); color: #fff; animation: julyFloat 5.6s ease-in-out infinite; }
.july-console-card__head { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; color: rgba(255,255,255,0.72); font-size: 12px; font-weight: 700; letter-spacing: 0.08em; }
.july-console-card__status { width: 8px; height: 8px; border-radius: 50%; background: #77c9ff; box-shadow: 0 0 14px rgba(119, 201, 255, 0.55); }
.july-console-card__body { display: grid; gap: 10px; }
.july-console-card__line { margin: 0; min-height: 20px; color: rgba(255,255,255,0.92); font-size: 14px; line-height: 1.45; font-weight: 500; letter-spacing: -0.01em; word-break: keep-all; }
.july-console-card__line::before { content: ">"; display: inline-block; margin-right: 8px; color: #8ec8ff; }
/* 위치 */
.july-floating--top-left { top: 10%; left: 4%; animation-delay: -.8s; }
.july-floating--top-right { top: 14%; right: 2%; animation-delay: -.2s; }
.july-console-card { left: -2%; bottom: 12%; animation-delay: -.4s; }
.july-floating--bottom-right { right: 8%; bottom: 12%; animation-delay: -1.1s; }
.july-floating--bottom-left { left: 18%; bottom: 2%; animation-delay: -.6s; }
@keyframes julyFloat {
  0% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
  100% { transform: translateY(0); }
}
/* 모바일 최적화 */
@media (max-width:991px) {
  .july-hero__code-layer span { font-size: 11px; opacity: .6; }
  .july-floating { min-height: 42px; padding: 0 14px; font-size: 12px; }
  .july-floating__score { min-width: 32px; height: 32px; font-size: 13px; }
  .july-console-card { width: min(72vw, 260px); padding: 14px 14px 15px; border-radius: 20px; }
  .july-console-card__head { margin-bottom: 10px; font-size: 11px; }
  .july-console-card__line { font-size: 12px; min-height: 17px; }
  .july-floating--top-left { top: 4%; left: 4%; }
  .july-floating--top-right { top: 9%; right: 4%; }
  .july-console-card { left: 50%; bottom: -3%; transform: translateX(-50%); }
  .july-floating--bottom-right { right: 50%; bottom: 30%; transform: translateX(50%); }
  .july-floating--bottom-left { display: none; }
}
@media (max-width:768px) {
  .july-hero__code-layer span:nth-child(3), .july-hero__code-layer span:nth-child(5), .july-hero__code-layer span:nth-child(7) { display: none; }
  .july-floating--top-left { top: 2%; left: 50%; transform: translateX(-50%); }
  .july-floating--top-right { top: auto; right: auto; left: 50%; bottom: 24%; transform: translateX(-50%); }
  .july-console-card { left: 50%; bottom: -6%; width: min(84vw, 290px); transform: translateX(-50%); }
  .mobile-hide { display: none !important; }
}
@media (max-width:480px) {
  .july-floating { font-size: 11px; padding: 0 12px; }
  .july-console-card { width: min(88vw, 290px); }
}
/* 배경 코드 더 많이, 더 잘 보이게 */
.july-hero__code-layer { position: absolute; inset: -4% -2%; z-index: 1; pointer-events: none; overflow: hidden; }
.july-hero__code-layer span { position: absolute; color: rgba(150, 205, 255, 0.16); font-size: 13px; font-weight: 500; letter-spacing: 0.01em; white-space: nowrap; text-shadow: 0 0 18px rgba(119, 201, 255, 0.05); animation: julyCodeFloat 16s linear infinite; }
.july-hero__code-layer span:nth-child(1) { top: 4%; left: 8%; animation-duration: 19s; }
.july-hero__code-layer span:nth-child(2) { top: 8%; right: 6%; animation-duration: 16s; }
.july-hero__code-layer span:nth-child(3) { top: 14%; left: 38%; animation-duration: 18s; }
.july-hero__code-layer span:nth-child(4) { top: 22%; left: 4%; animation-duration: 21s; }
.july-hero__code-layer span:nth-child(5) { top: 26%; right: 14%; animation-duration: 17s; }
.july-hero__code-layer span:nth-child(6) { top: 34%; left: 48%; animation-duration: 18s; }
.july-hero__code-layer span:nth-child(7) { top: 40%; left: 10%; animation-duration: 20s; }
.july-hero__code-layer span:nth-child(8) { top: 46%; right: 4%; animation-duration: 16s; }
.july-hero__code-layer span:nth-child(9) { top: 54%; left: 26%; animation-duration: 22s; }
.july-hero__code-layer span:nth-child(10) { top: 60%; right: 18%; animation-duration: 17s; }
.july-hero__code-layer span:nth-child(11) { top: 66%; left: 6%; animation-duration: 19s; }
.july-hero__code-layer span:nth-child(12) { top: 72%; left: 42%; animation-duration: 18s; }
.july-hero__code-layer span:nth-child(13) { bottom: 20%; right: 8%; animation-duration: 21s; }
.july-hero__code-layer span:nth-child(14) { bottom: 16%; left: 16%; animation-duration: 17s; }
.july-hero__code-layer span:nth-child(15) { bottom: 10%; left: 46%; animation-duration: 19s; }
.july-hero__code-layer span:nth-child(16) { bottom: 8%; right: 26%; animation-duration: 22s; }
.july-hero__code-layer span:nth-child(17) { top: 18%; right: 34%; animation-duration: 15s; }
.july-hero__code-layer span:nth-child(18) { top: 58%; right: 34%; animation-duration: 18s; }
.july-hero__code-layer span:nth-child(19) { bottom: 28%; left: 34%; animation-duration: 21s; }
.july-hero__code-layer span:nth-child(20) { bottom: 4%; right: 4%; animation-duration: 16s; }
@keyframes julyCodeFloat {
  0% { transform: translate3d(0, 24px, 0); opacity: 0; }
  15% { opacity: .85; }
  50% { opacity: .95; }
  100% { transform: translate3d(0, -34px, 0); opacity: 0; }
}
/* 플로팅 간격 압축 */
.july-floating, .july-console-card { position: absolute; z-index: 8; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.22); }
.july-floating { display: inline-flex; align-items: center; gap: 10px; min-height: 46px; padding: 0 16px; border-radius: 999px; background: #fff; color: rgba(26, 26, 26, 0.9); font-size: 13px; font-weight: 700; letter-spacing: -0.02em; animation: julyFloat 4.6s ease-in-out infinite; }
.july-console-card { width: 330px; padding: 16px 18px 18px; border-radius: 22px; background: linear-gradient(180deg, rgba(8, 13, 29, 0.88) 0%, rgba(13, 19, 41, 0.82) 100%); color: #fff; animation: julyFloat 5.2s ease-in-out infinite; }
.july-console-card__head { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; color: rgba(255,255,255,0.72); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; }
.july-console-card__line { margin: 0; min-height: 18px; color: rgba(255,255,255,0.92); font-size: 12px; line-height: 1.45; font-weight: 500; letter-spacing: -0.01em; word-break: break-all; }
/* 위치 재배치 - 전체를 더 촘촘하게 */
.july-floating--copy-top { top: 26%; left: 6%; animation-delay: -.5s; }
.july-floating--copy-bottom-left { left: 5%; bottom: 24%; animation-delay: -.2s; }
.july-floating--copy-bottom-right { left: 25%; bottom: 15%; animation-delay: -.8s; }
.july-floating--top-left { top: 14%; left: 15%; animation-delay: -.8s; }
.july-floating--top-right { top: 24%; right: 4%; animation-delay: -.2s; }
.july-floating--monitor-extra { top: 53%; right: 3%; animation-delay: -.9s; }
.july-console-card { left: 43%; bottom: 8%; animation-delay: -.4s; }
.july-floating--bottom-right { right: 6%; bottom: 9%; animation-delay: -1.1s; }
.july-floating--bottom-left { right: 25%; bottom: 2%; animation-delay: -.6s; }
@keyframes julyFloat {
  0% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
  100% { transform: translateY(0); }
}
/* 모바일 */
@media (max-width:991px) {
  .july-hero__code-layer span { font-size: 10px; color: rgba(150, 205, 255, 0.12); }
  .july-floating { min-height: 40px; padding: 0 13px; font-size: 11px; }
  .july-console-card { width: min(82vw, 320px); padding: 14px 14px 15px; border-radius: 18px; }
  .july-console-card__line { font-size: 11px; min-height: 16px; }
  .july-floating--copy-top { top: 0%; left: 50%; transform: translateX(-50%); }
  .july-floating--top-left { top: 10%; left: 4%; }
  .july-floating--top-right { top: 10%; right: 4%; }
  .july-floating--monitor-extra { top: auto; right: 50%; bottom: 32%; transform: translateX(50%); }
  .july-console-card { left: 50%; bottom: -3%; transform: translateX(-50%); }
  .july-floating--bottom-right { left: 50%; right: auto; bottom: 23%; transform: translateX(-50%); }
  .july-floating--copy-bottom-left, .july-floating--copy-bottom-right, .july-floating--bottom-left { display: none; }
}
@media (max-width:768px) {
  .july-hero__code-layer span:nth-child(2), .july-hero__code-layer span:nth-child(4), .july-hero__code-layer span:nth-child(6), .july-hero__code-layer span:nth-child(8), .july-hero__code-layer span:nth-child(10), .july-hero__code-layer span:nth-child(12), .july-hero__code-layer span:nth-child(14), .july-hero__code-layer span:nth-child(16), .july-hero__code-layer span:nth-child(18), .july-hero__code-layer span:nth-child(20) { display: none; }
  .july-floating--copy-top { top: 20%; right: 0%; }
  .july-floating--top-left { top: 10%; right: 50%; transform: translateX(-50%); }
  .july-floating--top-right { top: auto; left: 0%; right: auto; bottom: 31%; transform: translateX(-50%); }
  .july-floating--monitor-extra { display: none; }
  .july-console-card { bottom: 20%; width: min(88vw, 320px); }
  .july-floating--bottom-right { bottom: 20%; left: 5%; }
}
/* 글씨 영역 쪽 PC 전용 플로팅 */
.july-hero__content { position: relative; z-index: 6; }
.july-copy-floating, .july-copy-console { position: absolute; z-index: 9; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.20); }
.july-copy-floating { display: inline-flex; align-items: center; gap: 10px; min-height: 44px; padding: 0 16px; border-radius: 999px; background: #fff; color: rgba(26, 26, 26, 0.9); font-size: 12px; font-weight: 700; letter-spacing: -0.02em; animation: julyCopyFloat 4.8s ease-in-out infinite; white-space: nowrap; }
.july-copy-floating__dot { width: 8px; height: 8px; border-radius: 50%; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); box-shadow: 0 0 14px rgba(119, 201, 255, 0.45); }
.july-copy-console { width: 320px; padding: 15px 16px 16px; border-radius: 22px; background: linear-gradient(180deg, rgba(8, 13, 29, 0.86) 0%, rgba(13, 19, 41, 0.82) 100%); color: #fff; animation: julyCopyFloat 5.6s ease-in-out infinite; }
.july-copy-console__head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; color: rgba(255,255,255,0.70); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; }
.july-copy-console__status { width: 8px; height: 8px; border-radius: 50%; background: #77c9ff; box-shadow: 0 0 14px rgba(119, 201, 255, 0.55); }
.july-copy-console__body { display: grid; gap: 8px; }
.july-copy-console__line { margin: 0; min-height: 17px; color: rgba(255,255,255,0.92); font-size: 11px; line-height: 1.45; font-weight: 500; letter-spacing: -0.01em; word-break: break-all; }
.july-copy-console__line::before { content: ">"; display: inline-block; margin-right: 7px; color: #8ec8ff; }
/* 위치 */
.july-copy-floating--top { top: -30%; right: 18%; animation-delay: -.3s; }
.july-copy-floating--mid { right: 20%; bottom: -108px; animation-delay: -.8s; }
.july-copy-console { left: 5%; top: -25%; animation-delay: -.5s; }
@keyframes julyCopyFloat {
  0% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
  100% { transform: translateY(0); }
}
/* 모바일/태블릿에서는 전부 숨김 */
@media (max-width:991px) {
  .pc-only-hero-float { display: none !important; }
}
/* 너무 좁은 PC에서 겹침 방지 */
@media (min-width:992px) and (max-width:1280px) {
  .july-copy-floating--top { top: -24px; right: 0; max-width: 180px; }
  .july-copy-floating--mid { left: 20px; bottom: -20%; max-width: 160px}
  .july-copy-console { width: 270px; top: -40%; left: 0; bottom: -64px; max-height: 170px; }
}
/* effect */
.july-effect { position: relative; padding: 120px 0 130px; background: radial-gradient(circle at 20% 10%, rgba(116, 142, 255, 0.10) 0%, rgba(116, 142, 255, 0) 30%), radial-gradient(circle at 80% 70%, rgba(220, 146, 255, 0.10) 0%, rgba(220, 146, 255, 0) 34%), linear-gradient(180deg, #0a0f21 0%, #0d1329 100%); overflow: hidden; border-bottom: 0; }
.july-effect::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 28px 28px; mask-image: linear-gradient(180deg, rgba(0,0,0,.32), rgba(0,0,0,.08)); pointer-events: none; }
.july-effect .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-effect__head { max-width: 980px; margin: 0 auto; text-align: center; }
.july-effect__eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 18px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; backdrop-filter: blur(8px); }
.july-effect__title { margin: 0; color: #fff; font-size: clamp(34px, 4.4vw, 52px); line-height: 1.18; letter-spacing: -0.055em; font-weight: 300; }
.july-effect__title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-effect__desc { margin: 24px auto 0; max-width: 820px; color: rgba(255,255,255,0.72); font-size: 20px; line-height: 1.8; font-weight: 500; letter-spacing: -0.02em; }
.july-effect__nav { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 36px; }
.july-effect__nav-btn { min-height: 46px; padding: 0 18px; border: 1px solid rgba(255,255,255,0.10); border-radius: 999px; background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.82); font-size: 14px; font-weight: 700; cursor: pointer; transition: .25s ease; backdrop-filter: blur(10px); }
.july-effect__nav-btn:hover, .july-effect__nav-btn.is-active { background: rgba(255,255,255,0.10); border-color: rgba(119,201,255,0.24); color: #fff; }
.july-effect__block { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr); gap: 44px; align-items: center; margin-top: 84px; }
.july-effect__block--reverse .july-effect__media { order: 2; }
.july-effect__block--reverse .july-effect__content { order: 1; }
.july-effect__media { position: relative; }
.july-effect__screen { position: relative; padding: 20px; border-radius: 30px; background: linear-gradient(180deg, rgba(255,255,255,0.09) 0%, rgba(255,255,255,0.05) 100%); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 70px rgba(4, 6, 18, 0.24); backdrop-filter: blur(14px); }
.july-effect__screen-label { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 14px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; }
.july-effect__screen img { display: block; width: 100%; height: auto; border-radius: 22px; background: #fff; }
.july-effect__floating { position: absolute; display: inline-flex; align-items: center; min-height: 46px; padding: 0 16px; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.92); font-size: 13px; font-weight: 700; backdrop-filter: blur(12px); box-shadow: 0 18px 40px rgba(3, 6, 18, 0.18); white-space: nowrap; }
.july-effect__floating--top { top: -18px; left: 18px; }
.july-effect__floating--bottom { right: 18px; bottom: -18px; }
.july-effect__content { position: relative; }
.july-effect__label { display: inline-block; margin-bottom: 18px; color: #8db9ff; font-size: 14px; font-weight: 800; letter-spacing: 0.12em; }
.july-effect__block-title { margin: 0; color: #fff; font-size: clamp(28px, 3.2vw, 46px); line-height: 1.22; letter-spacing: -0.05em; font-weight: 300; }
.july-effect__block-desc { margin: 22px 0 0; color: rgba(255,255,255,0.72); font-size: 18px; line-height: 1.85; font-weight: 500; letter-spacing: -0.02em; }
.july-effect__point-list { display: grid; gap: 14px; margin-top: 28px; }
.july-effect__point { padding: 18px 20px; border-radius: 22px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 14px 34px rgba(15,23,42,0.08); }
.july-effect__point strong { display: block; color: #fff; font-size: 17px; line-height: 1.4; font-weight: 600; letter-spacing: -0.03em; }
.july-effect__point span { display: block; margin-top: 8px; color: rgba(255,255,255,0.62); font-size: 15px; line-height: 1.65; font-weight: 500; }
.july-effect__impact { margin-top: 26px; padding: 24px 24px 22px; border-radius: 24px; background: linear-gradient(180deg, rgba(119,201,255,0.08) 0%, rgba(215,152,255,0.08) 100%); border: 1px solid rgba(255,255,255,0.08); }
.july-effect__impact span { display: inline-block; margin-bottom: 12px; color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.10em; }
.july-effect__impact p { margin: 0; color: #fff; font-size: 17px; line-height: 1.8; font-weight: 300; letter-spacing: -0.02em; }
.july-effect__impact strong { font-weight: 600; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-effect__summary { margin-top: 96px; padding: 56px 40px; border-radius: 36px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); text-align: center; box-shadow: 0 24px 70px rgba(4, 6, 18, 0.24); }
.july-effect__summary-label { display: inline-block; margin-bottom: 16px; color: #8db9ff; font-size: 13px; font-weight: 800; letter-spacing: 0.12em; }
.july-effect__summary-title { margin: 0; color: #fff; font-size: clamp(30px, 4vw, 52px); line-height: 1.2; letter-spacing: -0.055em; font-weight: 300; }
.july-effect__summary-title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-effect__summary-desc { max-width: 840px; margin: 22px auto 0; color: rgba(255,255,255,0.72); font-size: 19px; line-height: 1.85; font-weight: 500; }
.july-effect__summary-chips { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.july-effect__summary-chips span { display: inline-flex; align-items: center; min-height: 44px; padding: 0 18px; border-radius: 999px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.08); color: rgba(255,255,255,0.88); font-size: 14px; font-weight: 700; }
/* reveal animation */
.effect-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.effect-reveal.is-visible { opacity: 1; transform: translateY(0); }
/* responsive */
@media (max-width:1280px) {
  .july-effect { padding: 100px 0 110px; }
  .july-effect .container { padding: 0 28px; }
  .july-effect__block { gap: 30px; margin-top: 72px; }
  .july-effect__block-desc { font-size: 17px; }
  .july-effect__summary { padding: 48px 28px; border-radius: 30px; }
}
@media (max-width:1024px) {
  .july-effect__block, .july-effect__block--reverse { grid-template-columns: 1fr; gap: 24px; }
  .july-effect__block--reverse .july-effect__media, .july-effect__block--reverse .july-effect__content { order: initial; }
  .july-effect__floating--top { top: -14px; left: 14px; }
  .july-effect__floating--bottom { right: 14px; bottom: -14px; }
}
@media (max-width:768px) {
  .july-effect { padding: 82px 0 88px; }
  .july-effect .container { padding: 0 18px; }
  .july-effect__eyebrow { margin-bottom: 14px; font-size: 11px; }
  .july-effect__title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-effect__desc { margin-top: 18px; font-size: 16px; line-height: 1.7; }
  .july-effect__nav { gap: 10px; margin-top: 28px; }
  .july-effect__nav-btn { min-height: 40px; padding: 0 14px; font-size: 12px; }
  .july-effect__block { margin-top: 56px; }
  .july-effect__screen { padding: 14px; border-radius: 22px; }
  .july-effect__screen img { border-radius: 16px; }
  .july-effect__floating { display: none; }
  .july-effect__label { margin-bottom: 14px; font-size: 12px; }
  .july-effect__block-title { font-size: clamp(24px, 7vw, 34px); line-height: 1.28; }
  .july-effect__block-desc { margin-top: 16px; font-size: 15px; line-height: 1.75; }
  .july-effect__point-list { gap: 12px; margin-top: 22px; }
  .july-effect__point { padding: 16px 16px; border-radius: 18px; }
  .july-effect__point strong { font-size: 15px; }
  .july-effect__point span { margin-top: 6px; font-size: 13px; }
  .july-effect__impact { margin-top: 20px; padding: 18px 18px 16px; border-radius: 18px; }
  .july-effect__impact p { font-size: 15px; line-height: 1.7; }
  .july-effect__summary { margin-top: 72px; padding: 36px 18px; border-radius: 24px; }
  .july-effect__summary-label { margin-bottom: 12px; font-size: 11px; }
  .july-effect__summary-title { font-size: clamp(26px, 8vw, 38px); line-height: 1.24; }
  .july-effect__summary-desc { margin-top: 16px; font-size: 15px; line-height: 1.7; }
  .july-effect__summary-chips { gap: 10px; margin-top: 22px; }
  .july-effect__summary-chips span { width: 100%; justify-content: center; min-height: 40px; font-size: 13px; }
}
/* guide - 구매유도형 포괄 이용가이드 */
.july-guide { position: relative; padding: 120px 0 130px; background: #f7f8fc; overflow: hidden; border-bottom: 0; }
.july-guide::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 18% 18%, rgba(116, 142, 255, 0.08) 0%, rgba(116, 142, 255, 0) 30%), radial-gradient(circle at 82% 74%, rgba(220, 146, 255, 0.08) 0%, rgba(220, 146, 255, 0) 32%); pointer-events: none; }
.july-guide .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-guide__head { max-width: 980px; margin: 0 auto; text-align: center; }
.july-guide__eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 18px; border-radius: 999px; background: rgba(108, 141, 255, 0.08); border: 1px solid rgba(108, 141, 255, 0.14); color: #6c8dff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; }
.july-guide__title { margin: 0; color: #111827; font-size: clamp(34px, 4.2vw, 62px); line-height: 1.18; letter-spacing: -0.055em; font-weight: 300; }
.july-guide__title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-guide__desc { margin: 24px auto 0; max-width: 840px; color: #667085; font-size: 20px; line-height: 1.8; font-weight: 500; letter-spacing: -0.02em; }
.july-guide__flow { margin-top: 70px; display: grid; gap: 28px; }
.july-guide__card { position: relative; padding: 34px; border-radius: 34px; background: rgba(255,255,255,0.92); border: 1px solid rgba(17,24,39,0.06); box-shadow: 0 20px 54px rgba(15,23,42,0.07); transition: transform .25s ease, box-shadow .25s ease; }
.july-guide__card:hover { transform: translateY(-4px); box-shadow: 0 28px 60px rgba(15,23,42,0.10); }
.july-guide__number { position: absolute; top: 28px; right: 30px; color: #d0d6e3; font-size: 52px; line-height: 1; font-weight: 600; letter-spacing: -0.05em; }
.july-guide__card-main { display: grid; grid-template-columns: minmax(0, 0.98fr) minmax(0, 1.02fr); gap: 28px; align-items: center; }
.july-guide__card--reverse .july-guide__content { order: 2; }
.july-guide__card--reverse .july-guide__media { order: 1; }
.july-guide__label { display: inline-block; margin-bottom: 16px; color: #6c8dff; font-size: 13px; font-weight: 800; letter-spacing: 0.12em; }
.july-guide__card-title { margin: 0; color: #111827; font-size: clamp(28px, 3vw, 44px); line-height: 1.22; letter-spacing: -0.05em; font-weight: 300; }
.july-guide__card-desc { margin: 20px 0 0; color: #667085; font-size: 18px; line-height: 1.85; font-weight: 500; letter-spacing: -0.02em; }
.july-guide__points { display: grid; gap: 12px; margin-top: 24px; }
.july-guide__point { padding: 18px 18px; border-radius: 20px; background: #f8fafc; border: 1px solid rgba(17,24,39,0.06); box-shadow: 0 10px 24px rgba(15,23,42,0.04); }
.july-guide__point strong { display: block; color: #111827; font-size: 16px; line-height: 1.4; font-weight: 600; letter-spacing: -0.03em; }
.july-guide__point span { display: block; margin-top: 7px; color: #667085; font-size: 14px; line-height: 1.7; font-weight: 500; }
.july-guide__media { position: relative; }
.july-guide__screen { position: relative; padding: 18px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,248,252,0.94) 100%); border: 1px solid rgba(17,24,39,0.06); box-shadow: 0 18px 50px rgba(15,23,42,0.08); }
.july-guide__screen-label { display: inline-flex; align-items: center; min-height: 32px; padding: 0 12px; margin-bottom: 14px; border-radius: 999px; background: rgba(108,141,255,0.08); border: 1px solid rgba(108,141,255,0.12); color: #6c8dff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; }
.july-guide__screen img { display: block; width: 100%; height: auto; border-radius: 18px; background: #fff; }
.july-guide__summary { margin-top: 90px; padding: 56px 40px; border-radius: 36px; background: linear-gradient(180deg, #0a0f21 0%, #0d1329 100%); box-shadow: 0 24px 70px rgba(4, 6, 18, 0.22); text-align: center; overflow: hidden; position: relative; }
.july-guide__summary::before { content: ""; position: absolute; top: -120px; left: 50%; width: 620px; height: 620px; transform: translateX(-50%); border-radius: 999px; background: rgba(126, 108, 255, 0.10); filter: blur(110px); pointer-events: none; }
.july-guide__summary-label, .july-guide__summary-title, .july-guide__summary-desc, .july-guide__summary-chips, .july-guide__summary-cta { position: relative; z-index: 2; }
.july-guide__summary-label { display: inline-block; margin-bottom: 16px; color: #8db9ff; font-size: 13px; font-weight: 800; letter-spacing: 0.12em; }
.july-guide__summary-title { margin: 0; color: #fff; font-size: clamp(30px, 4vw, 54px); line-height: 1.2; letter-spacing: -0.055em; font-weight: 300; }
.july-guide__summary-title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-guide__summary-desc { max-width: 860px; margin: 20px auto 0; color: rgba(255,255,255,0.74); font-size: 18px; line-height: 1.8; font-weight: 500; }
.july-guide__summary-chips { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.july-guide__summary-chips span { display: inline-flex; align-items: center; min-height: 42px; padding: 0 16px; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.90); font-size: 14px; font-weight: 700; }
.july-guide__summary-cta { display: inline-flex; align-items: center; justify-content: center; min-width: 240px; height: 58px; margin-top: 28px; padding: 0 28px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 16px; font-weight: 800; text-decoration: none; letter-spacing: -0.02em; box-shadow: 0 14px 32px rgba(115, 126, 255, 0.24); transition: .25s ease; }
.july-guide__summary-cta:hover { transform: translateY(-2px); color: #08111f; text-decoration: none; }
/* reveal */
.guide-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.guide-reveal.is-visible { opacity: 1; transform: translateY(0); }
/* responsive */
@media (max-width:1280px) {
  .july-guide { padding: 100px 0 110px; }
  .july-guide .container { padding: 0 28px; }
  .july-guide__card { padding: 28px; border-radius: 28px; }
  .july-guide__summary { padding: 46px 28px; border-radius: 30px; }
}
@media (max-width:1024px) {
  .july-guide__card-main { grid-template-columns: 1fr; }
  .july-guide__card--reverse .july-guide__content, .july-guide__card--reverse .july-guide__media { order: initial; }
}
@media (max-width:768px) {
  .july-guide { padding: 82px 0 88px; }
  .july-guide .container { padding: 0 18px; }
  .july-guide__eyebrow { margin-bottom: 14px; font-size: 11px; }
  .july-guide__title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-guide__desc { margin-top: 18px; font-size: 16px; line-height: 1.7; }
  .july-guide__flow { margin-top: 44px; gap: 18px; }
  .july-guide__card { padding: 20px; border-radius: 22px; }
  .july-guide__number { top: 18px; right: 18px; font-size: 34px; }
  .july-guide__card-main { gap: 18px; }
  .july-guide__label { margin-bottom: 12px; font-size: 12px; }
  .july-guide__card-title { font-size: clamp(24px, 7vw, 34px); line-height: 1.28; }
  .july-guide__card-desc { margin-top: 14px; font-size: 15px; line-height: 1.75; }
  .july-guide__points { gap: 10px; margin-top: 18px; }
  .july-guide__point { padding: 14px 14px; border-radius: 16px; }
  .july-guide__point strong { font-size: 15px; }
  .july-guide__point span { margin-top: 6px; font-size: 13px; }
  .july-guide__screen { padding: 12px; border-radius: 20px; }
  .july-guide__screen img { border-radius: 14px; }
  .july-guide__summary { margin-top: 56px; padding: 34px 18px; border-radius: 24px; }
  .july-guide__summary-label { margin-bottom: 12px; font-size: 11px; }
  .july-guide__summary-title { font-size: clamp(26px, 8vw, 38px); line-height: 1.24; }
  .july-guide__summary-desc { margin-top: 16px; font-size: 15px; line-height: 1.7; }
  .july-guide__summary-chips { gap: 10px; margin-top: 20px; }
  .july-guide__summary-chips span { width: 100%; justify-content: center; min-height: 40px; font-size: 13px; }
  .july-guide__summary-cta { width: 100%; min-width: 100%; height: 52px; margin-top: 22px; font-size: 15px; }
}
/* price */
.july-price { position: relative; padding: 120px 0 130px; background: radial-gradient(circle at 20% 8%, rgba(116, 142, 255, 0.10) 0%, rgba(116, 142, 255, 0) 28%), radial-gradient(circle at 80% 72%, rgba(220, 146, 255, 0.10) 0%, rgba(220, 146, 255, 0) 30%), linear-gradient(180deg, #0a0f21 0%, #0d1329 100%); overflow: hidden; border-bottom: 0; }
.july-price::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 28px 28px; mask-image: linear-gradient(180deg, rgba(0,0,0,.32), rgba(0,0,0,.08)); pointer-events: none; }
.july-price .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-price__head { max-width: 980px; margin: 0 auto; text-align: center; }
.july-price__eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 18px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; backdrop-filter: blur(8px); }
.july-price__title { margin: 0; color: #fff; font-size: clamp(34px, 4.4vw, 64px); line-height: 1.18; letter-spacing: -0.055em; font-weight: 300; }
.july-price__title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-price__desc { margin: 24px auto 0; max-width: 840px; color: rgba(255,255,255,0.72); font-size: 20px; line-height: 1.8; font-weight: 500; letter-spacing: -0.02em; }
.july-price__top-copy { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 42px; }
.july-price__top-copy-card { padding: 24px 24px; border-radius: 26px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.16); }
.july-price__top-copy-card strong { display: block; color: #fff; font-size: 22px; line-height: 1.35; letter-spacing: -0.04em; font-weight: 300; }
.july-price__top-copy-card p { margin: 12px 0 0; color: rgba(255,255,255,0.68); font-size: 16px; line-height: 1.75; font-weight: 500; }
.july-price__top-copy-card--accent { background: linear-gradient(180deg, rgba(119,201,255,0.08) 0%, rgba(215,152,255,0.08) 100%); }
.july-price__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; margin-top: 38px; }
.july-price__card { position: relative; padding: 28px 26px 26px; border-radius: 30px; background: rgba(255,255,255,0.94); border: 1px solid rgba(17,24,39,0.06); box-shadow: 0 24px 60px rgba(4, 6, 18, 0.14); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.july-price__card:hover { transform: translateY(-6px); box-shadow: 0 30px 70px rgba(4, 6, 18, 0.18); }
.july-price__card--featured { border-color: rgba(108,141,255,0.38); box-shadow: 0 28px 70px rgba(76, 102, 255, 0.12); }
.july-price__badge { display: inline-flex; align-items: center; min-height: 36px; padding: 0 14px; border-radius: 999px; background: #f3f4f6; color: #111827; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; }
.july-price__badge--dark { background: #111827; color: #fff; }
.july-price__recommend { position: absolute; top: 26px; right: 26px; display: inline-flex; align-items: center; min-height: 34px; padding: 0 12px; border-radius: 999px; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); color: #08111f; font-size: 12px; font-weight: 800; }
.july-price__card-title { margin: 20px 0 0; color: #111827; font-size: 48px; line-height: 1.05; letter-spacing: -0.06em; font-weight: 600; }
.july-price__card-sub { margin: 14px 0 0; color: #667085; font-size: 17px; line-height: 1.7; font-weight: 500; }
.july-price__price-box { margin-top: 22px; padding: 24px 22px; border-radius: 24px; background: #f8fafc; border: 1px solid rgba(17,24,39,0.06); }
.july-price__price-box--year { background: linear-gradient(180deg, rgba(119,201,255,0.10) 0%, rgba(215,152,255,0.10) 100%); }
.july-price__price-label { display: inline-block; margin-bottom: 10px; color: #111827; font-size: 14px; font-weight: 800; letter-spacing: -0.02em; }
.july-price__price-main { display: block; color: #111827; font-size: 54px; line-height: 1.05; letter-spacing: -0.06em; font-weight: 800; }
.july-price__price-main small { font-size: 22px; font-weight: 700; color: #667085; }
.july-price__price-desc { margin: 12px 0 0; color: #667085; font-size: 15px; line-height: 1.7; font-weight: 500; }
.july-price__discount { color: #5b5bd6; font-weight: 700; }
.july-price__feature-list { margin: 24px 0 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.july-price__feature-list li { position: relative; padding-left: 18px; color: #344054; font-size: 15px; line-height: 1.7; font-weight: 500; }
.july-price__feature-list li::before { content: ""; position: absolute; top: 10px; left: 0; width: 7px; height: 7px; border-radius: 50%; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); }
.july-price__impact { margin-top: 24px; padding: 18px 18px; border-radius: 20px; background: #f8fafc; border: 1px solid rgba(17,24,39,0.06); }
.july-price__impact span { display: inline-block; margin-bottom: 10px; color: #6c8dff; font-size: 12px; font-weight: 800; letter-spacing: 0.10em; }
.july-price__impact p { margin: 0; color: #667085; font-size: 15px; line-height: 1.75; font-weight: 500; }
.july-price__impact strong { color: #111827; font-weight: 700; }
.july-price__cta { display: inline-flex; align-items: center; justify-content: center; width: 100%; min-height: 56px; margin-top: 24px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 15px; font-weight: 800; text-decoration: none; box-shadow: 0 14px 32px rgba(115, 126, 255, 0.16); transition: .25s ease; }
.july-price__cta:hover { transform: translateY(-2px); color: #08111f; text-decoration: none; }
.july-price__cta--featured { box-shadow: 0 18px 38px rgba(115, 126, 255, 0.24); }
.july-price__bottom { margin-top: 72px; }
.july-price__bottom-box { padding: 52px 38px; border-radius: 34px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 70px rgba(4, 6, 18, 0.18); text-align: center; }
.july-price__bottom-label { display: inline-block; margin-bottom: 16px; color: #8db9ff; font-size: 13px; font-weight: 800; letter-spacing: 0.12em; }
.july-price__bottom-title { margin: 0; color: #fff; font-size: clamp(30px, 4vw, 54px); line-height: 1.2; letter-spacing: -0.055em; font-weight: 300; }
.july-price__bottom-title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-price__bottom-desc { max-width: 860px; margin: 20px auto 0; color: rgba(255,255,255,0.74); font-size: 18px; line-height: 1.8; font-weight: 500; }
.july-price__bottom-chips { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.july-price__bottom-chips span { display: inline-flex; align-items: center; min-height: 42px; padding: 0 16px; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.90); font-size: 14px; font-weight: 700; }
/* reveal */
.price-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.price-reveal.is-visible { opacity: 1; transform: translateY(0); }
/* responsive */

@media (min-width:769px) {
  .july-price__feature-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:1280px) {
  .july-price { padding: 100px 0 110px; }
  .july-price .container { padding: 0 28px; }
  .july-price__grid { gap: 16px; }
  .july-price__card { padding: 24px 20px 22px; border-radius: 24px; }
  .july-price__price-main { font-size: 42px; }
  .july-price__bottom-box { padding: 44px 28px; border-radius: 30px; }
}
@media (max-width:1024px) {
  .july-price__top-copy, .july-price__grid { grid-template-columns: 1fr; }
}
@media (max-width:768px) {
  .july-price { padding: 82px 0 88px; }
  .july-price .container { padding: 0 18px; }
  .july-price__eyebrow { margin-bottom: 14px; font-size: 11px; }
  .july-price__title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-price__desc { margin-top: 18px; font-size: 16px; line-height: 1.7; }
  .july-price__top-copy { gap: 12px; margin-top: 28px; }
  .july-price__top-copy-card { padding: 18px 18px; border-radius: 18px; }
  .july-price__top-copy-card strong { font-size: 18px; line-height: 1.4; }
  .july-price__top-copy-card p { margin-top: 10px; font-size: 14px; line-height: 1.7; }
  .july-price__grid { gap: 14px; margin-top: 24px; }
  .july-price__card { padding: 20px 16px 18px; border-radius: 20px; }
  .july-price__recommend { top: 16px; right: 16px; min-height: 30px; padding: 0 10px; font-size: 11px; }
  .july-price__card-title { margin-top: 16px; font-size: 36px; }
  .july-price__card-sub { margin-top: 10px; font-size: 15px; line-height: 1.7; }
  .july-price__price-box { margin-top: 16px; padding: 18px 16px; border-radius: 18px; }
  .july-price__price-label { margin-bottom: 8px; font-size: 13px; }
  .july-price__price-main { font-size: 36px; }
  .july-price__price-main small { font-size: 18px; }
  .july-price__price-desc { margin-top: 10px; font-size: 14px; line-height: 1.65; }
  .july-price__feature-list { gap: 10px; margin-top: 18px; }
  .july-price__feature-list li { font-size: 14px; line-height: 1.65; }
  .july-price__impact { margin-top: 18px; padding: 16px; border-radius: 16px; }
  .july-price__impact p { font-size: 14px; line-height: 1.7; }
  .july-price__cta { min-height: 52px; margin-top: 18px; font-size: 14px; }
  .july-price__bottom { margin-top: 48px; }
  .july-price__bottom-box { padding: 34px 18px; border-radius: 24px; }
  .july-price__bottom-label { margin-bottom: 12px; font-size: 11px; }
  .july-price__bottom-title { font-size: clamp(26px, 8vw, 38px); line-height: 1.24; }
  .july-price__bottom-desc { margin-top: 16px; font-size: 15px; line-height: 1.7; }
  .july-price__bottom-chips { gap: 10px; margin-top: 20px; }
  .july-price__bottom-chips span { width: 100%; justify-content: center; min-height: 40px; font-size: 13px; }
}
.july-price__year-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; flex-wrap: wrap; }
.july-price__save-badge { display: inline-flex; align-items: center; justify-content: center; min-height: 32px; padding: 0 12px; border-radius: 999px; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); color: #08111f; font-size: 16px; font-weight: 800; letter-spacing: -0.02em; box-shadow: 0 10px 24px rgba(115, 126, 255, 0.16); }
.july-price__year-compare { display: inline-block; margin-top: 6px; color: #5b5bd6; font-size: 14px; line-height: 1.7; font-weight: 700; letter-spacing: -0.02em; }
@media (max-width:768px) {
  .july-price__year-head { gap: 8px; margin-bottom: 8px; }
  .july-price__save-badge { min-height: 28px; padding: 0 10px; font-size: 14px; }
  .july-price__year-compare { font-size: 13px; line-height: 1.6; }
}
/* review */
.july-review-slider { position: relative; padding: 120px 20px 130px; background: linear-gradient(180deg, #0a0f21 0%, #0d1329 100%); overflow: hidden; border-bottom: 0; }
.july-review-slider::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 20%, rgba(114, 170, 255, 0.10) 0%, rgba(114, 170, 255, 0) 32%), radial-gradient(circle at 80% 70%, rgba(212, 150, 255, 0.10) 0%, rgba(212, 150, 255, 0) 32%); pointer-events: none; }
.july-review-slider .review-slider-inner { position: relative; z-index: 2; max-width: 1320px; margin: 0 auto; }
.july-review-slider .review-slider-head { text-align: center; margin-bottom: 48px; }
.july-review-slider .review-slider-label { margin: 0 0 18px; color: #8db9ff; font-size: 14px; font-weight: 200; letter-spacing: 0.14em; }
.july-review-slider .review-slider-title { margin: 0; color: #fff; font-size: clamp(34px, 4vw, 60px); line-height: 1.18; letter-spacing: -0.05em; font-weight: 300; }
.july-review-slider .review-slider-desc { margin: 20px auto 0; max-width: 760px; color: rgba(255,255,255,0.68); font-size: 20px; line-height: 1.8; font-weight: 500; }
.july-review-slider .review-slider-wrap { position: relative; display: flex; align-items: center; gap: 20px; }
.july-review-slider .review-slider-viewport { flex: 1; overflow: hidden; }
.july-review-slider .review-slider-track { display: flex; gap: 24px; transition: transform 0.6s ease; will-change: transform; }
.july-review-slider .review-card { flex: 0 0 calc((100% - 24px) / 2); min-height: 360px; padding: 28px 28px 30px; border-radius: 32px; background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.05) 100%); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.18); backdrop-filter: blur(12px); }
.july-review-slider .review-card-top { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding-bottom: 22px; border-bottom: 1px solid rgba(255,255,255,0.10); }
.july-review-slider .review-client { display: flex; align-items: center; gap: 14px; min-width: 0; flex: 1; }
.july-review-slider .review-avatar { flex: 0 0 64px; width: 64px; height: 64px; border-radius: 999px; overflow: hidden; background: linear-gradient(135deg, #77c9ff 0%, #d89aff 100%); box-shadow: 0 10px 25px rgba(119, 201, 255, 0.18); position: relative; }
.july-review-slider .review-avatar--text { display: flex; align-items: center; justify-content: center; color: #08111f; font-size: 24px; font-weight: 600; letter-spacing: -0.03em; }
.july-review-slider .review-client-info strong, .july-review-slider .review-project strong { display: block; color: #fff; font-size: 16px; line-height: 1.45; font-weight: 800; letter-spacing: -0.02em; }
.july-review-slider .review-client-info span, .july-review-slider .review-project span { display: block; margin-top: 6px; color: rgba(255,255,255,0.58); font-size: 14px; line-height: 1.5; font-weight: 500; }
.july-review-slider .review-project span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight: 600; }
.july-review-slider .review-project { flex: 0 0 auto; text-align: right; max-width: 220px; }
.july-review-slider .review-card-bottom { padding-top: 28px; }
.july-review-slider .review-quote { margin: 0; color: #fff; font-size: 24px; line-height: 1.55; letter-spacing: -0.045em; font-weight: 300; word-break: keep-all; }
.july-review-slider .review-nav { flex: 0 0 auto; width: 58px; height: 58px; border: 1px solid rgba(255,255,255,0.12); border-radius: 999px; background: rgba(255,255,255,0.06); color: #fff; font-size: 22px; cursor: pointer; backdrop-filter: blur(10px); transition: 0.25s ease; }
.july-review-slider .review-nav:hover { background: rgba(255,255,255,0.12); transform: translateY(-2px); }
.july-review-slider .review-dots { display: flex; justify-content: center; gap: 10px; margin-top: 28px; }
.july-review-slider .review-dots button { width: 12px; height: 12px; padding: 0; border: 0; border-radius: 999px; background: rgba(255,255,255,0.20); cursor: pointer; transition: 0.25s ease; }
.july-review-slider .review-dots button.is-active { width: 34px; background: linear-gradient(90deg, #77c9ff 0%, #d89aff 100%); }
/* reveal */
.review-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.review-reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width:1280px) {
  .july-review-slider { padding: 100px 20px 110px; }
  .july-review-slider .review-card { min-height: 320px; padding: 24px 24px 26px; border-radius: 26px; }
  .july-review-slider .review-slider-track { gap: 18px; }
  .july-review-slider .review-card { flex: 0 0 calc((100% - 18px) / 2); }
  .july-review-slider .review-avatar { width: 56px; height: 56px; flex-basis: 56px; }
  .july-review-slider .review-avatar--text { font-size: 22px; }
  .july-review-slider .review-client-info strong, .july-review-slider .review-project strong { font-size: 15px; }
  .july-review-slider .review-client-info span, .july-review-slider .review-project span { font-size: 13px; }
  .july-review-slider .review-quote { font-size: 25px; }
}
@media (max-width:768px) {
  .july-review-slider { padding: 84px 18px 90px; }
  .july-review-slider .review-slider-head { margin-bottom: 32px; }
  .july-review-slider .review-slider-label { margin-bottom: 14px; font-size: 12px; }
  .july-review-slider .review-slider-title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-review-slider .review-slider-desc { margin-top: 16px; font-size: 16px; line-height: 1.7; }
  .july-review-slider .review-slider-wrap { gap: 8px; }
  .july-review-slider .review-slider-track { gap: 0; }
  .july-review-slider .review-card { flex: 0 0 100%; min-height: 280px; padding: 22px 18px 22px; border-radius: 22px; }
  .july-review-slider .review-card-top { flex-direction: column; align-items: flex-start; gap: 16px; padding-bottom: 18px; }
  .july-review-slider .review-project { text-align: left; max-width: none; }
  .july-review-slider .review-avatar { width: 52px; height: 52px; flex-basis: 52px; }
  .july-review-slider .review-avatar--text { font-size: 20px; }
  .july-review-slider .review-client-info strong, .july-review-slider .review-project strong { font-size: 15px; }
  .july-review-slider .review-client-info span, .july-review-slider .review-project span { font-size: 13px; }
  .july-review-slider .review-card-bottom { padding-top: 20px; }
  .july-review-slider .review-quote { font-size: 16px; line-height: 1.6; }
  .july-review-slider .review-nav { width: 26px; height: 26px; font-size: 13px; }
}
/* 공통 reveal 상태 */
.effect-reveal, .guide-reveal, .price-reveal, .review-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; will-change: opacity, transform; }
.effect-reveal.is-visible, .guide-reveal.is-visible, .price-reveal.is-visible, .review-reveal.is-visible { opacity: 1; transform: translateY(0); }
/* final cta */
.july-final-cta { position: relative; padding: 120px 0 140px; background: radial-gradient(circle at 20% 10%, rgba(116, 142, 255, 0.12) 0%, rgba(116, 142, 255, 0) 30%), radial-gradient(circle at 80% 80%, rgba(220, 146, 255, 0.12) 0%, rgba(220, 146, 255, 0) 34%), linear-gradient(180deg, #090d1d 0%, #070b18 100%); overflow: hidden; border-bottom: 0; }
.july-final-cta::before { content: ""; position: absolute; top: 50%; left: 50%; width: 920px; height: 920px; transform: translate(-50%, -50%); border-radius: 999px; background: rgba(125, 108, 255, 0.06); filter: blur(140px); pointer-events: none; }
.july-final-cta .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-final-cta__inner { max-width: 1320px; margin: 0 auto; padding: 68px 42px; border-radius: 42px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 70px rgba(4, 6, 18, 0.28); backdrop-filter: blur(16px); text-align: center; }
.july-final-cta__label { display: inline-block; margin-bottom: 18px; color: #8db9ff; font-size: 14px; font-weight: 800; letter-spacing: 0.14em; }
.july-final-cta__title { margin: 0; color: #fff; font-size: clamp(34px, 4.4vw, 64px); line-height: 1.18; letter-spacing: -0.055em; font-weight: 300; }
.july-final-cta__title span, .july-final-cta__bottom-title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-final-cta__desc { max-width: 920px; margin: 24px auto 0; color: rgba(255,255,255,0.74); font-size: 19px; line-height: 1.85; font-weight: 500; letter-spacing: -0.02em; }
.july-final-cta__desc strong { color: #fff; font-weight: 700; }
.july-final-cta__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 42px; }
.july-final-cta__card { padding: 28px 24px 24px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.05) 100%); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.18); text-align: left; }
.july-final-cta__card strong { display: block; color: #fff; font-size: 22px; line-height: 1.4; letter-spacing: -0.04em; font-weight: 300; }
.july-final-cta__card p { margin: 14px 0 0; color: rgba(255,255,255,0.68); font-size: 16px; line-height: 1.8; font-weight: 500; }
.july-final-cta__message { margin-top: 30px; padding: 24px 24px; border-radius: 26px; background: linear-gradient(180deg, rgba(119,201,255,0.08) 0%, rgba(215,152,255,0.08) 100%); border: 1px solid rgba(255,255,255,0.08); }
.july-final-cta__message p { margin: 0; color: rgba(255,255,255,0.82); font-size: 18px; line-height: 1.85; font-weight: 400; letter-spacing: -0.02em; }
.july-final-cta__message strong { color: #fff; font-weight: 700; }
.july-final-cta__bottom { margin-top: 44px; }
.july-final-cta__bottom-title { margin: 0; color: #fff; font-size: clamp(30px, 4vw, 56px); line-height: 1.2; letter-spacing: -0.055em; font-weight: 300; }
.july-final-cta__bottom-desc { max-width: 860px; margin: 22px auto 0; color: rgba(255,255,255,0.72); font-size: 18px; line-height: 1.8; font-weight: 500; }
.july-final-cta__chips { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.july-final-cta__chips span { display: inline-flex; align-items: center; min-height: 42px; padding: 0 16px; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.90); font-size: 14px; font-weight: 700; }
.july-final-cta__actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.july-final-cta__btn { display: inline-flex; align-items: center; justify-content: center; min-width: 220px; height: 58px; padding: 0 28px; border-radius: 999px; font-size: 16px; font-weight: 800; text-decoration: none; transition: .25s ease; }
.july-final-cta__btn:hover { transform: translateY(-2px); text-decoration: none; }
.july-final-cta__btn--primary { background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; box-shadow: 0 14px 32px rgba(115, 126, 255, 0.24); }
.july-final-cta__btn--primary:hover { color: #08111f; }
.july-final-cta__btn--ghost { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: #fff; backdrop-filter: blur(10px); }
.july-final-cta__btn--ghost:hover { background: rgba(255,255,255,0.12); color: #fff; }
/* reveal */
.final-cta-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.final-cta-reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width:1280px) {
  .july-final-cta { padding: 100px 0 110px; }
  .july-final-cta .container { padding: 0 28px; }
  .july-final-cta__inner { padding: 52px 28px; border-radius: 30px; }
  .july-final-cta__grid { gap: 14px; }
  .july-final-cta__card { padding: 24px 20px 20px; border-radius: 22px; }
  .july-final-cta__card strong { font-size: 20px; }
  .july-final-cta__card p { font-size: 15px; }
}
@media (max-width:1024px) {
  .july-final-cta__grid { grid-template-columns: 1fr; }
}
@media (max-width:768px) {
  .july-final-cta { padding: 82px 0 90px; }
  .july-final-cta .container { padding: 0 18px; }
  .july-final-cta__inner { padding: 36px 18px; border-radius: 24px; }
  .july-final-cta__label { margin-bottom: 14px; font-size: 11px; }
  .july-final-cta__title { font-size: clamp(28px, 8vw, 42px); line-height: 1.24; }
  .july-final-cta__desc { margin-top: 18px; font-size: 15px; line-height: 1.75; }
  .july-final-cta__grid { gap: 12px; margin-top: 28px; }
  .july-final-cta__card { padding: 18px 16px; border-radius: 18px; }
  .july-final-cta__card strong { font-size: 18px; line-height: 1.45; }
  .july-final-cta__card p { margin-top: 10px; font-size: 14px; line-height: 1.7; }
  .july-final-cta__message { margin-top: 20px; padding: 18px 16px; border-radius: 18px; }
  .july-final-cta__message p { font-size: 14px; line-height: 1.75; }
  .july-final-cta__bottom { margin-top: 30px; }
  .july-final-cta__bottom-title { font-size: clamp(26px, 8vw, 38px); line-height: 1.24; }
  .july-final-cta__bottom-desc { margin-top: 16px; font-size: 15px; line-height: 1.7; }
  .july-final-cta__chips { gap: 10px; margin-top: 20px; }
  .july-final-cta__chips span { width: 100%; justify-content: center; min-height: 40px; font-size: 13px; }
  .july-final-cta__actions { gap: 10px; margin-top: 22px; }
  .july-final-cta__btn { width: 100%; min-width: 100%; height: 52px; font-size: 15px; }
}
/* =========================
   FINAL CTA ENHANCED EFFECT
========================= */

/* inner 강화 */
.july-final-cta__inner { position: relative; transform-style: preserve-3d; will-change: transform; transition: transform .18s ease-out, box-shadow .25s ease-out; overflow: hidden; }
/* 오로라 배경 */
.july-final-cta__aurora { position: absolute; border-radius: 999px; filter: blur(80px); pointer-events: none; opacity: .7; z-index: 0; animation-timing-function: ease-in-out; animation-iteration-count: infinite; animation-direction: alternate; }
.july-final-cta__aurora--1 { width: 320px; height: 320px; top: -80px; left: 8%; background: rgba(119, 201, 255, 0.20); animation: finalAuroraMove1 10s infinite; }
.july-final-cta__aurora--2 { width: 360px; height: 360px; right: 6%; bottom: -120px; background: rgba(215, 152, 255, 0.18); animation: finalAuroraMove2 12s infinite; }
.july-final-cta__aurora--3 { width: 240px; height: 240px; top: 36%; left: 50%; transform: translateX(-50%); background: rgba(129, 108, 255, 0.16); animation: finalAuroraPulse 8s infinite; }
@keyframes finalAuroraMove1 {
  0% { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(46px, 22px, 0) scale(1.08); }
}
@keyframes finalAuroraMove2 {
  0% { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(-52px, -28px, 0) scale(1.1); }
}
@keyframes finalAuroraPulse {
  0% { transform: translateX(-50%) scale(.95); opacity: .45; }
  50% { transform: translateX(-50%) scale(1.08); opacity: .8; }
  100% { transform: translateX(-50%) scale(.98); opacity: .55; }
}
/* 코드/입자 흐름 */
.july-final-cta__code-layer { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.july-final-cta__code-layer span { position: absolute; color: rgba(160, 210, 255, 0.12); font-size: 13px; font-weight: 500; white-space: nowrap; letter-spacing: 0.01em; text-shadow: 0 0 16px rgba(119, 201, 255, 0.04); animation: finalCodeFloat 14s linear infinite; }
.july-final-cta__code-layer span:nth-child(1) { top: 8%; left: 8%; animation-duration: 15s; }
.july-final-cta__code-layer span:nth-child(2) { top: 14%; right: 10%; animation-duration: 12s; }
.july-final-cta__code-layer span:nth-child(3) { top: 26%; left: 42%; animation-duration: 14s; }
.july-final-cta__code-layer span:nth-child(4) { top: 34%; left: 6%; animation-duration: 16s; }
.july-final-cta__code-layer span:nth-child(5) { top: 42%; right: 18%; animation-duration: 13s; }
.july-final-cta__code-layer span:nth-child(6) { top: 54%; left: 28%; animation-duration: 15s; }
.july-final-cta__code-layer span:nth-child(7) { top: 64%; right: 8%; animation-duration: 14s; }
.july-final-cta__code-layer span:nth-child(8) { bottom: 22%; left: 12%; animation-duration: 17s; }
.july-final-cta__code-layer span:nth-child(9) { bottom: 18%; right: 24%; animation-duration: 13s; }
.july-final-cta__code-layer span:nth-child(10) { bottom: 10%; left: 46%; animation-duration: 16s; }
.july-final-cta__code-layer span:nth-child(11) { top: 18%; left: 60%; animation-duration: 15s; }
.july-final-cta__code-layer span:nth-child(12) { bottom: 6%; right: 6%; animation-duration: 14s; }
@keyframes finalCodeFloat {
  0% { transform: translate3d(0, 22px, 0); opacity: 0; }
  15% { opacity: .72; }
  50% { opacity: .9; }
  100% { transform: translate3d(0, -30px, 0); opacity: 0; }
}
/* 콘텐츠를 코드/오로라 위로 */
.july-final-cta__label, .july-final-cta__title, .july-final-cta__desc, .july-final-cta__grid, .july-final-cta__message, .july-final-cta__bottom { position: relative; z-index: 2; }
/* 카드도 살짝 입체감 */
.july-final-cta__card, .july-final-cta__message, .july-final-cta__chips span, .july-final-cta__btn { transform: translateZ(0); transition: transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease; }
/* stagger 등장 기본 상태 */
.july-final-cta__chips span, .july-final-cta__actions .july-final-cta__btn { opacity: 0; transform: translateY(16px); }
/* reveal 후 stagger */
.final-cta-reveal.is-visible .july-final-cta__chips span, .final-cta-reveal.is-visible .july-final-cta__actions .july-final-cta__btn { opacity: 1; transform: translateY(0); }
.final-cta-reveal.is-visible .july-final-cta__chips span:nth-child(1) { transition: opacity .5s ease .05s, transform .5s ease .05s; }
.final-cta-reveal.is-visible .july-final-cta__chips span:nth-child(2) { transition: opacity .5s ease .12s, transform .5s ease .12s; }
.final-cta-reveal.is-visible .july-final-cta__chips span:nth-child(3) { transition: opacity .5s ease .19s, transform .5s ease .19s; }
.final-cta-reveal.is-visible .july-final-cta__chips span:nth-child(4) { transition: opacity .5s ease .26s, transform .5s ease .26s; }
.final-cta-reveal.is-visible .july-final-cta__actions .july-final-cta__btn:nth-child(1) { transition: opacity .55s ease .34s, transform .55s ease .34s, box-shadow .25s ease, background .25s ease; }
.final-cta-reveal.is-visible .july-final-cta__actions .july-final-cta__btn:nth-child(2) { transition: opacity .55s ease .42s, transform .55s ease .42s, box-shadow .25s ease, background .25s ease; }
/* hover glow 강화 */
.july-final-cta__btn--primary:hover { box-shadow: 0 18px 38px rgba(115, 126, 255, 0.34), 0 0 0 1px rgba(255,255,255,0.08), 0 0 28px rgba(119, 201, 255, 0.22); }
.july-final-cta__btn--ghost:hover { box-shadow: 0 14px 32px rgba(115, 126, 255, 0.14), 0 0 22px rgba(215, 152, 255, 0.12); }
/* 칩 hover도 살짝 */
.july-final-cta__chips span:hover { transform: translateY(-2px); background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.16); }
/* 카드 hover 입체감 */
.july-final-cta__card:hover, .july-final-cta__message:hover { transform: translateY(-4px); }
/* 모바일 최적화 */
@media (max-width:991px) {
  .july-final-cta__inner { transform: none !important; }
}
@media (max-width:768px) {
  .july-final-cta__aurora--1 { width: 220px; height: 220px; top: -40px; left: -20px; filter: blur(60px); }
  .july-final-cta__aurora--2 { width: 240px; height: 240px; right: -30px; bottom: -70px; filter: blur(60px); }
  .july-final-cta__aurora--3 { width: 180px; height: 180px; top: 46%; filter: blur(55px); }
  .july-final-cta__code-layer span { font-size: 10px; color: rgba(160, 210, 255, 0.08); }
  .july-final-cta__code-layer span:nth-child(2), .july-final-cta__code-layer span:nth-child(4), .july-final-cta__code-layer span:nth-child(6), .july-final-cta__code-layer span:nth-child(8), .july-final-cta__code-layer span:nth-child(10), .july-final-cta__code-layer span:nth-child(12) { display: none; }
  .july-final-cta__chips span, .july-final-cta__actions .july-final-cta__btn { opacity: 1; transform: none; }
}
/* =========================
   EFFECT / GUIDE IMAGE MOTION
========================= */

/* 공통 motion screen */
.july-effect__screen--motion, .july-guide__screen--motion { overflow: hidden; }
.july-effect__viewport, .july-guide__viewport { position: relative; overflow-y: auto; overflow-x: hidden; width: 100%; background: #fff; border-radius: 22px; -ms-overflow-style: none; scrollbar-width: none; box-shadow: inset 0 0 0 1px rgba(17, 24, 39, 0.04); }
.july-effect__viewport::-webkit-scrollbar, .july-guide__viewport::-webkit-scrollbar { width: 0; height: 0; display: none; }
.july-effect__screen-inner, .july-guide__screen-inner { width: 100%; }
.july-effect__screen-inner img, .july-guide__screen-inner img { display: block; width: 100%; height: auto; border-radius: 18px; }
/* pause 시 살짝 강조 */
.july-effect__viewport.is-paused, .july-guide__viewport.is-paused { box-shadow: inset 0 0 0 1px rgba(119, 201, 255, 0.22), 0 0 0 4px rgba(119, 201, 255, 0.06); }
/* desktop heights */
.july-effect__viewport { height: 560px; }
.july-guide__viewport { height: 520px; }
/* tablet */
@media (max-width:1280px) {
  .july-effect__viewport { height: 500px; }
  .july-guide__viewport { height: 460px; }
}
@media (max-width:1024px) {
  .july-effect__viewport { height: 440px; }
  .july-guide__viewport { height: 400px; }
}
/* mobile */
@media (max-width:768px) {
  .july-effect__viewport { height: 340px; border-radius: 16px; }
  .july-guide__viewport { height: 320px; border-radius: 16px; }
  .july-effect__screen-inner img, .july-guide__screen-inner img { border-radius: 14px; }
  .july-effect__viewport::before, .july-effect__viewport::after, .july-guide__viewport::before, .july-guide__viewport::after { height: 22px; }
  .july-effect__viewport::before, .july-guide__viewport::before { margin-bottom: -22px; }
  .july-effect__viewport::after, .july-guide__viewport::after { margin-top: -22px; }
}
.july-intro__card img { width: 100%; margin-bottom: 25px; border-radius: 24px; }
/* =========================
   Manual intro modal
========================= */
body.is-july-manual-modal-open { overflow: hidden; }
.july-manual-modal { position: fixed; inset: 0; z-index: 99990; display: flex; align-items: center; justify-content: center; padding: 10px; }
.july-manual-modal[hidden] { display: none !important; }
.july-manual-modal__backdrop { position: absolute; inset: 0; background: rgba(15, 22, 48, .62); backdrop-filter: blur(10px); }
.july-manual-modal__dialog { position: relative; z-index: 2; width: min(1520px, calc(100vw - 20px)); height: min(1040px, calc(100dvh - 20px)); margin: 0; display: flex; flex-direction: column; overflow: hidden; border-radius: 32px; background: #f7f9ff; box-shadow: 0 30px 100px rgba(0, 0, 0, .28); }
.july-manual-modal__top { flex: 0 0 auto; height: 40px; padding: 0 14px 0 18px; display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,.84); border-bottom: 1px solid rgba(20, 30, 60, .08); }
.july-manual-modal__top strong { color: #0f1630; font-size: 14px; font-weight: 600; }
.july-manual-modal__close { width: 30px; height: 30px; border: 0; border-radius: 50%; background: rgba(15, 22, 48, .07); color: #0f1630; font-size: 20px; line-height: 1; font-weight: 300; cursor: pointer; }
.july-manual-modal__body { flex: 1 1 auto; min-height: 0; overflow: hidden; padding: 8px; }
/* modal inner manual layout */
.july-manual-modal .july-manual-shell { height: 100%; min-height: 0; display: flex; flex-direction: column; padding: 12px; border-radius: 24px; }
.july-manual-modal .july-manual-tabs { flex: 0 0 auto; margin-bottom: 8px; }
.july-manual-modal .july-manual-controls { flex: 0 0 auto; margin-top: 8px; padding-top: 8px; }
.july-manual-modal .july-manual-stage { flex: 1 1 auto; min-height: 0; overflow-y: auto !important; overflow-x: hidden; -webkit-overflow-scrolling: touch; overscroll-behavior: contain; border-radius: 22px; }
.july-manual-modal .july-manual-track { min-height: 100%; height: auto !important; display: flex; flex-direction: column; }
.july-manual-modal .july-manual-slide { width: 100%; min-height: 100%; height: auto !important; overflow: visible !important; }
.july-manual-modal .july-manual-slide.is-active { display: flex !important; flex-direction: column; flex: 0 0 auto; }
.july-manual-modal .july-manual-slide:not(.is-active) { display: none !important; }
/* 핵심: 짧으면 100% 채우고, 길면 내용만큼 늘어나 stage가 스크롤 */
.july-manual-modal .july-manual-slide > * { width: 100%; min-height: 100%; height: auto !important; flex: 0 0 auto !important; overflow: visible !important; }
.july-manual-modal .july-manual-feature, .july-manual-modal .july-manual-hello, .july-manual-modal .manual-final, .july-manual-modal .manual-update { min-height: 100%; height: auto !important; overflow: visible !important; }
/* modal scrollbar */
.july-manual-modal .july-manual-stage::-webkit-scrollbar { width: 6px; }
.july-manual-modal .july-manual-stage::-webkit-scrollbar-thumb { background: rgba(138, 125, 255, .35); border-radius: 999px; }
.july-manual-modal .july-manual-stage::-webkit-scrollbar-track { background: transparent; }
/* test button */
.july-manual-test-open { position: fixed; right: 18px; bottom: 18px; z-index: 9990; height: 42px; padding: 0 16px; border: 0; border-radius: 999px; background: #0f1630; color: #fff; font-size: 13px; font-weight: 600; box-shadow: 0 14px 30px rgba(15, 22, 48, .22); }
/* mobile */
@media (max-width:767px) {
  .july-manual-modal { padding: 8px; align-items: flex-start; }
  .july-manual-modal__dialog { width: 100%; height: calc(100dvh - 16px); margin: 0; border-radius: 22px; }
  .july-manual-modal__top { height: 46px; padding: 0 12px 0 16px; }
  .july-manual-modal__top strong { font-size: 13px; }
  .july-manual-modal__body { padding: 8px; overflow: hidden; }
  .july-manual-modal .july-manual-shell { height: 100%; min-height: 0; padding: 10px; border-radius: 18px; }
  .july-manual-modal .july-manual-stage { overflow-y: auto !important; -webkit-overflow-scrolling: touch; }
  .july-manual-test-open { right: 12px; bottom: 82px; height: 38px; padding: 0 13px; font-size: 12px; }
}
/* PC modal: HELLO slide fixed visual height */
@media (min-width:768px) {
  .july-manual-modal .july-manual-slide--hello .july-manual-hello { min-height: 820px; height: auto; }
}
.july-manual-modal__top-actions { display: flex; align-items: center; gap: 8px; }
.july-manual-modal__today { height: 30px; padding: 0 11px; border: 0; border-radius: 999px; background: rgba(15, 22, 48, .06); color: #687089; font-size: 12px; font-weight: 800; cursor: pointer; }
.july-manual-modal__today:hover { background: rgba(15, 22, 48, .10); color: #0f1630; }
@media (max-width:767px) {
  .july-manual-modal__today { height: 28px; padding: 0 9px; font-size: 11px; }
}
/* review photo ticker */
.july-review-slider .review-photo-ticker { position: relative; margin: 0 auto 46px; overflow: hidden; }
.july-review-slider .review-photo-ticker__viewport { position: relative; overflow: hidden; width: 100%; }
.july-review-slider .review-photo-ticker__viewport::before, .july-review-slider .review-photo-ticker__viewport::after { content: ""; position: absolute; top: 0; width: 120px; height: 100%; z-index: 3; pointer-events: none; }
.july-review-slider .review-photo-ticker__viewport::before { left: 0; background: linear-gradient(90deg, #0a0f21 0%, rgba(10, 15, 33, 0) 100%); }
.july-review-slider .review-photo-ticker__viewport::after { right: 0; background: linear-gradient(270deg, #0a0f21 0%, rgba(10, 15, 33, 0) 100%); }
.july-review-slider .review-photo-ticker__track { display: flex; width: max-content; animation: reviewPhotoTicker 42s linear infinite; will-change: transform; }
.july-review-slider .review-photo-ticker:hover .review-photo-ticker__track { animation-play-state: paused; }
.july-review-slider .review-photo-ticker__group { display: flex; gap: 20px; padding-right: 20px; }
.july-review-slider .review-photo-ticker__item { flex: 0 0 calc((1320px - 60px) / 4); width: calc((1320px - 60px) / 4); aspect-ratio: 4 / 5; margin: 0; overflow: hidden; border-radius: 28px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(3, 6, 18, 0.24); }
.july-review-slider .review-photo-ticker__item img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.july-review-slider .review-photo-ticker__item:hover img { transform: scale(1.04); }
@keyframes reviewPhotoTicker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@media (max-width:1400px) {
  .july-review-slider .review-photo-ticker__item { flex-basis: calc((100vw - 100px) / 4); width: calc((100vw - 100px) / 4); }
}
@media (max-width:768px) {
  .july-review-slider .review-photo-ticker { margin-bottom: 34px; }
  .july-review-slider .review-photo-ticker__viewport { width: 100%; }
  .july-review-slider .review-photo-ticker__viewport::before, .july-review-slider .review-photo-ticker__viewport::after { width: 28px; }
  .july-review-slider .review-photo-ticker__group { gap: 10px; padding-right: 10px; }
  .july-review-slider .review-photo-ticker__item { flex: 0 0 calc((100vw - 42px) / 2); width: calc((100vw - 42px) / 2); aspect-ratio: 4 / 5; border-radius: 18px; }
  .july-review-slider .review-photo-ticker__track { animation-duration: 34s; }
}
/* =========================
   HERO MARKETING SCENES
========================= */

.july-hero-scenes { position: relative; width: min(100%, 780px); min-height: 700px; display: flex; align-items: center; justify-content: center; }
.july-hero-scenes__glow { position: absolute; border-radius: 999px; filter: blur(90px); pointer-events: none; }
.july-hero-scenes__glow--one { width: 280px; height: 280px; left: 4%; top: 8%; background: rgba(119, 201, 255, .16); }
.july-hero-scenes__glow--two { width: 260px; height: 260px; right: 4%; bottom: 10%; background: rgba(215, 152, 255, .15); }
.july-hero-scenes__grid { position: relative; z-index: 2; width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.july-scene { position: relative; overflow: hidden; min-height: 250px; padding: 18px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.82)); border: 1px solid rgba(255,255,255,.42); box-shadow: 0 26px 60px rgba(15, 22, 48, .16), inset 0 1px 0 rgba(255,255,255,.55); backdrop-filter: blur(16px); animation: julySceneFloat 6s ease-in-out infinite; }
.july-scene:nth-child(2) { animation-delay: -.7s; }
.july-scene:nth-child(3) { animation-delay: -1.2s; }
.july-scene:nth-child(4) { animation-delay: -1.8s; }
.july-scene__head small { display: block; margin-bottom: 6px; color: #8a7dff; font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-scene__head strong { display: block; color: #0f1630; font-size: 20px; line-height: 1.25; font-weight: 600; }
/* 공통 rank chip */
.july-rank-chip { position: relative; width: 54px; height: 20px; overflow: hidden; border-radius: 999px; background: rgba(138,125,255,.12); color: #5d54d6; font-size: 10px; font-weight: 600; }
.july-rank-chip span { display: flex; align-items: center; justify-content: center; height: 20px; }
.july-rank-chip--insta span, .july-rank-chip--place span { animation: julyRankLoop 6s ease-in-out infinite; }
.july-rank-chip--insta span:nth-child(2), .july-rank-chip--place span:nth-child(2) { animation-delay: .18s; }
.july-rank-chip--insta span:nth-child(3), .july-rank-chip--place span:nth-child(3) { animation-delay: .36s; }
.july-rank-static { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 20px; border-radius: 999px; background: #f1f4fc; color: #7b849b; font-size: 10px; font-weight: 600; }
/* 1. 영상 생성 */
.july-video-build { margin-top: 16px; }
.july-video-build__phone { position: relative; width: 126px; height: 188px; margin: 0 auto; border-radius: 28px; background: #101726; padding: 10px; box-shadow: 0 18px 44px rgba(15,22,48,.22); }
.july-video-build__frame { position: absolute; left: 50%; top: 18px; width: 92px; height: 152px; border-radius: 18px; transform: translateX(-50%); background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.8), transparent 14%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.65), transparent 24%), linear-gradient(135deg, #f6d8e4, #9bded4); opacity: 0; animation: julyVideoFrames 6s ease-in-out infinite; }
.july-video-build__frame--2 { background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.8), transparent 14%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.65), transparent 24%), linear-gradient(135deg, #dbe7ff, #f0d9ff); animation-delay: 1.2s; }
.july-video-build__frame--3 { background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.8), transparent 14%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.65), transparent 24%), linear-gradient(135deg, #ffe4cf, #ffd4ea); animation-delay: 2.4s; }
.july-video-build__play { position: absolute; right: 12px; bottom: 16px; width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.92); color: #0f1630; font-size: 12px; font-weight: 600; z-index: 2; animation: julyPulse 2.6s ease-in-out infinite; }
.july-video-build__meta { display: grid; grid-template-columns: 1fr; gap: 7px; margin-top: 16px; }
.july-video-build__meta span { display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: #f7f9ff; color: #616b85; font-size: 11px; font-weight: 800; }
.july-video-build__progress { position: relative; height: 8px; margin-top: 14px; overflow: hidden; border-radius: 999px; background: #edf1fb; }
.july-video-build__bar { position: absolute; inset: 0 auto 0 0; width: 0; border-radius: inherit; background: linear-gradient(90deg, #77c9ff, #d798ff); animation: julyProgressBar 6s ease-in-out infinite; }
/* 2. 인스타 */
.july-insta-ui { margin-top: 16px; }
.july-insta-ui__search { display: flex; align-items: center; min-height: 34px; padding: 0 12px; border-radius: 12px; background: #f7f9ff; color: #6e7790; font-size: 11px; font-weight: 800; }
.july-insta-ui__list { display: grid; gap: 10px; margin-top: 14px; }
.july-insta-post { display: grid; grid-template-columns: 44px minmax(0,1fr) auto; gap: 10px; align-items: center; padding: 10px; border-radius: 16px; background: #f8faff; border: 1px solid rgba(20,30,60,.05); }
.july-insta-post--main { background: linear-gradient(90deg, rgba(119,201,255,.10), rgba(215,152,255,.12)); animation: julyLiftCard 4.2s ease-in-out infinite; }
.july-insta-post__thumb { width: 44px; height: 44px; border-radius: 12px; background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #f6d365, #fda085, #d798ff); }
.july-insta-post__thumb.is-second { background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #9bded4, #dbe7ff); }
.july-insta-post__thumb.is-third { background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #ffd6d6, #f2d8ff); }
.july-insta-post__body strong { display: block; color: #0f1630; font-size: 12px; font-weight: 600; }
.july-insta-post__body p { margin: 3px 0 0; color: #7a839b; font-size: 10px; line-height: 1.45; font-weight: 700; }
/* 3. 플레이스 */
.july-place-ui { margin-top: 16px; }
.july-place-ui__card { padding: 16px; border-radius: 20px; background: linear-gradient(180deg, #ffffff, #f8fbff); border: 1px solid rgba(20,30,60,.06); }
.july-place-ui__title strong { display: block; color: #0f1630; font-size: 17px; font-weight: 600; }
.july-place-ui__title p { margin: 4px 0 0; color: #7d869e; font-size: 11px; font-weight: 700; }
.july-place-ui__rankbox { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 14px; padding: 12px 14px; border-radius: 16px; background: #f7fafc; }
.july-place-ui__rank-label { color: #657089; font-size: 11px; font-weight: 800; }
.july-place-ui__bars { display: grid; gap: 8px; margin-top: 14px; }
.july-place-ui__bars span { position: relative; display: block; height: 10px; overflow: hidden; border-radius: 999px; background: #edf2fb; }
.july-place-ui__bars span::after { content: ""; position: absolute; inset: 0 auto 0 0; width: 0; border-radius: inherit; background: linear-gradient(90deg, #03c75a, #77c9ff); animation: julyPlaceBars 5.4s ease-in-out infinite; }
.july-place-ui__bars span:nth-child(2)::after { animation-delay: .3s; }
.july-place-ui__bars span:nth-child(3)::after { animation-delay: .6s; }
/* 4. 공유 */
.july-share-ui { margin-top: 16px; }
.july-share-ui__card { display: grid; grid-template-columns: 72px minmax(0,1fr); gap: 12px; align-items: center; padding: 12px; border-radius: 18px; background: #fffbe8; border: 1px solid rgba(245, 214, 88, .35); }
.july-share-ui__thumb { width: 72px; height: 72px; border-radius: 18px; background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #f6d8e4, #9bded4); }
.july-share-ui__body strong { display: block; color: #0f1630; font-size: 14px; font-weight: 600; }
.july-share-ui__body p { margin: 4px 0 0; color: #6f7890; font-size: 11px; line-height: 1.5; font-weight: 700; }
.july-share-ui__sendline { position: relative; height: 28px; margin: 16px 0 12px; }
.july-share-ui__sendline::before { content: ""; position: absolute; left: 18px; right: 18px; top: 50%; height: 2px; transform: translateY(-50%); background: linear-gradient(90deg, rgba(245,214,88,.0), rgba(245,214,88,.65), rgba(245,214,88,.0)); }
.july-share-ui__dot { position: absolute; top: 50%; width: 9px; height: 9px; margin-top: -4.5px; border-radius: 50%; background: #f5d658; box-shadow: 0 0 0 6px rgba(245,214,88,.18); animation: julyShareDots 3.2s linear infinite; }
.july-share-ui__dot--1 { left: 18px; }
.july-share-ui__dot--2 { left: 18px; animation-delay: .9s; }
.july-share-ui__dot--3 { left: 18px; animation-delay: 1.8s; }
.july-share-ui__receivers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.july-chat-bubble { display: flex; align-items: center; justify-content: center; min-height: 34px; border-radius: 999px; background: #f7f9ff; color: #5d667f; font-size: 11px; font-weight: 800; opacity: .45; transform: translateY(8px); animation: julyBubbleReceive 3.6s ease-in-out infinite; }
.july-chat-bubble--2 { animation-delay: .8s; }
.july-chat-bubble--3 { animation-delay: 1.6s; }
/* 플로팅 배지 */
.july-scene-float { position: absolute; z-index: 5; display: inline-flex; align-items: center; gap: 8px; min-height: 42px; padding: 0 14px; border-radius: 999px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.16); color: #000; font-size: 12px; font-weight: 800; backdrop-filter: blur(14px); box-shadow: 0 16px 36px rgba(0,0,0,.18); }
.july-scene-float span { width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(90deg, #77c9ff, #d798ff); color: #08111f; font-size: 11px; font-weight: 600; }
.july-scene-float--1 { left: 12px; top: 70px; animation: julyFloatBubble 5.4s ease-in-out infinite; }
.july-scene-float--2 { right: 30px; top: 110px; animation: julyFloatBubble 5.8s ease-in-out infinite; }
.july-scene-float--3 { left: 34px; bottom: 62px; animation: julyFloatBubble 6.2s ease-in-out infinite; }
.july-scene-float--4 { right: 12px; bottom: 34px; animation: julyFloatBubble 5s ease-in-out infinite; }
/* keyframes */
@keyframes julySceneFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@keyframes julyVideoFrames {
  0%, 18% { opacity: 0; transform: translateX(-50%) translateY(20px) scale(.96); }
  24%, 54% { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
  70%, 100% { opacity: 0; transform: translateX(-50%) translateY(-12px) scale(1.02); }
}
@keyframes julyProgressBar {
  0%, 18% { width: 0; }
  30%, 85% { width: 88%; }
  100% { width: 0; }
}
@keyframes julyPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
@keyframes julyRankLoop {
  0% { transform: translateY(0); }
  25% { transform: translateY(0); }
  35% { transform: translateY(-20px); }
  60% { transform: translateY(-20px); }
  70% { transform: translateY(-40px); }
  100% { transform: translateY(-40px); }
}
@keyframes julyLiftCard {
  0%, 100% { transform: translateY(0); box-shadow: 0 0 0 rgba(138,125,255,0); }
  50% { transform: translateY(-2px); box-shadow: 0 0 0 6px rgba(138,125,255,.08); }
}
@keyframes julyPlaceBars {
  0%, 15% { width: 0; }
  38%, 84% { width: 86%; }
  100% { width: 0; }
}
@keyframes julyShareDots {
  0% { left: 18px; opacity: 0; }
  10% { opacity: 1; }
  80% { left: calc(100% - 26px); opacity: 1; }
  100% { left: calc(100% - 12px); opacity: 0; }
}
@keyframes julyBubbleReceive {
  0%, 100% { opacity: .45; transform: translateY(8px); }
  25%, 65% { opacity: 1; transform: translateY(0); background: #fff4b8; color: #5a4e14; }
}
@keyframes julyFloatBubble {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
/* responsive */
@media (max-width:1280px) {
  .july-hero-scenes { width: min(100%, 720px); min-height: 660px; }
}
@media (max-width:1024px) {
  .july-hero-scenes { margin: 0 auto; min-height: auto; }
}
@media (max-width:768px) {
  .july-hero-scenes { width: 100%; min-height: auto; display: block; }
  .july-hero-scenes__grid { grid-template-columns: 1fr; gap: 12px; }
  .july-scene { min-height: auto; padding: 16px; }
  .july-scene__head strong { font-size: 18px; }
  .july-scene-float, .july-hero-scenes__glow { display: none; }
}
/* =========================
   HERO SCENES REFINED
========================= */

/* 공통 순위 스택 */
.july-rank-stack { width: 58px; height: 22px; overflow: hidden; border-radius: 999px; background: rgba(138,125,255,.12); color: #5d54d6; font-size: 10px; font-weight: 600; }
.july-rank-stack span { display: flex; align-items: center; justify-content: center; height: 22px; animation: julyRankStackMove 6s ease-in-out infinite; }
.july-rank-stack span:nth-child(2) { animation-delay: .2s; }
.july-rank-stack span:nth-child(3) { animation-delay: .4s; }
/* =========================
   INSTAGRAM REFINED
========================= */

.july-insta-real { margin-top: 16px; padding: 14px; border-radius: 20px; background: #fff; border: 1px solid rgba(20,30,60,.06); }
.july-insta-real__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.july-insta-real__title { color: #111827; font-size: 14px; font-weight: 800; letter-spacing: -.02em; }
.july-insta-real__icons { display: flex; gap: 6px; }
.july-insta-real__icons span { width: 8px; height: 8px; border-radius: 50%; background: #d7deed; }
.july-insta-real__search { display: flex; align-items: center; min-height: 34px; padding: 0 12px; border-radius: 12px; background: #f6f8fc; color: #6d7690; font-size: 11px; font-weight: 800; }
.july-insta-real__tabs { display: flex; gap: 8px; margin-top: 10px; }
.july-insta-real__tabs span { display: inline-flex; align-items: center; justify-content: center; min-width: 48px; height: 28px; padding: 0 10px; border-radius: 999px; background: #f3f5fb; color: #7b849b; font-size: 10px; font-weight: 600; }
.july-insta-real__tabs span.is-active { background: linear-gradient(90deg, rgba(246, 211, 101, .25), rgba(215, 152, 255, .24)); color: #5d54d6; }
.july-insta-real__result { margin-top: 12px; }
.july-insta-real__profile { display: grid; grid-template-columns: 42px minmax(0,1fr) auto; gap: 10px; align-items: center; padding: 10px; border-radius: 16px; background: linear-gradient(90deg, rgba(119,201,255,.10), rgba(215,152,255,.12)); animation: julyInstaProfileLift 4.4s ease-in-out infinite; }
.july-insta-real__avatar { width: 42px; height: 42px; border-radius: 50%; background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.82), transparent 15%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #f6d365, #fda085, #d798ff); }
.july-insta-real__profile-body strong { display: block; color: #0f1630; font-size: 12px; font-weight: 600; }
.july-insta-real__profile-body p { margin: 3px 0 0; color: #7a839b; font-size: 10px; line-height: 1.45; font-weight: 700; }
.july-insta-real__feed { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 12px; }
.july-insta-real__tile { position: relative; aspect-ratio: 1 / 1; overflow: hidden; border-radius: 14px; background: #f2f5fb; }
.july-insta-real__tile i { position: absolute; inset: 0; background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 15%), radial-gradient(circle at 50% 84%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #f7dbe6, #a8ded6); }
.july-insta-real__tile.is-main { animation: julyInstaMainPulse 3.6s ease-in-out infinite; box-shadow: 0 0 0 0 rgba(215,152,255,0); }
.july-insta-real__tile.is-main em { position: absolute; left: 8px; bottom: 8px; display: inline-flex; align-items: center; height: 20px; padding: 0 8px; border-radius: 999px; background: rgba(17,24,39,.72); color: #fff; font-size: 9px; font-weight: 600; font-style: normal; }
/* =========================
   NAVER PLACE STRONG
========================= */

.july-scene--place-strong { background: linear-gradient(180deg, rgba(245,255,249,.94), rgba(255,255,255,.88)); }
.july-place-strong { margin-top: 16px; }
.july-place-strong__top { display: grid; grid-template-columns: 40px minmax(0,1fr); gap: 10px; align-items: center; margin-bottom: 12px; }
.july-place-strong__badge { width: 40px; height: 40px; border-radius: 14px; display: flex; align-items: center; justify-content: center; background: #03c75a; color: #fff; font-size: 19px; font-weight: 600; box-shadow: 0 10px 24px rgba(3,199,90,.22); }
.july-place-strong__search { display: flex; align-items: center; min-height: 36px; padding: 0 12px; border-radius: 12px; background: rgba(3,199,90,.08); color: #0f1630; font-size: 11px; font-weight: 800; }
.july-place-strong__card { padding: 16px; border-radius: 22px; background: #fff; border: 1px solid rgba(3,199,90,.12); box-shadow: 0 18px 36px rgba(3,199,90,.08); }
.july-place-strong__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.july-place-strong__header strong { display: block; color: #0f1630; font-size: 18px; font-weight: 600; }
.july-place-strong__header p { margin: 4px 0 0; color: #687089; font-size: 11px; line-height: 1.45; font-weight: 700; }
.july-place-strong__pin { font-size: 20px; line-height: 1; animation: julyPinBounce 2.8s ease-in-out infinite; }
.july-place-strong__rank-wrap { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 14px; padding: 12px 14px; border-radius: 16px; background: linear-gradient(90deg, rgba(3,199,90,.08), rgba(119,201,255,.08)); }
.july-place-strong__rank-text small { display: block; color: #6b748d; font-size: 10px; font-weight: 800; }
.july-place-strong__rank-text b { display: block; margin-top: 3px; color: #03a34d; font-size: 14px; font-weight: 600; }
.july-place-strong__metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 14px; }
.july-place-strong__metrics div { padding: 10px 8px; border-radius: 14px; background: #f6fff9; text-align: center; }
.july-place-strong__metrics small { display: block; margin-bottom: 4px; color: #7a839b; font-size: 10px; font-weight: 800; }
.july-place-strong__metrics b { color: #03a34d; font-size: 14px; font-weight: 600; }
.july-place-strong__graph { display: flex; align-items: flex-end; gap: 8px; height: 64px; margin-top: 16px; }
.july-place-strong__graph span { flex: 1; border-radius: 999px 999px 10px 10px; background: linear-gradient(180deg, #8ee7ba, #03c75a); animation: julyPlaceGraphUp 3.8s ease-in-out infinite; }
.july-place-strong__graph span:nth-child(1) { height: 26px; }
.july-place-strong__graph span:nth-child(2) { height: 34px; animation-delay: .2s; }
.july-place-strong__graph span:nth-child(3) { height: 42px; animation-delay: .4s; }
.july-place-strong__graph span:nth-child(4) { height: 52px; animation-delay: .6s; }
.july-place-strong__graph span:nth-child(5) { height: 60px; animation-delay: .8s; }
/* =========================
   KAKAO SHARE FLASHY
========================= */

.july-kakao-share { margin-top: 16px; }
.july-kakao-share__phone { position: relative; padding: 12px; border-radius: 22px; background: #1f1f1f; box-shadow: 0 20px 46px rgba(15,22,48,.22); }
.july-kakao-share__header { display: flex; align-items: center; height: 28px; padding: 0 10px; border-radius: 12px 12px 0 0; background: #ffe812; color: #3a3000; font-size: 11px; font-weight: 600; }
.july-kakao-share__room { position: relative; min-height: 176px; padding: 14px; border-radius: 0 0 16px 16px; background: #bfe8ff; overflow: hidden; }
.july-kakao-share__bubble--card { position: relative; z-index: 2; display: grid; grid-template-columns: 64px minmax(0,1fr); gap: 10px; padding: 10px; border-radius: 16px; background: #fff; box-shadow: 0 10px 24px rgba(15,22,48,.10); animation: julyKakaoCardPop 3.8s ease-in-out infinite; }
.july-kakao-share__card-thumb { width: 64px; height: 64px; border-radius: 16px; background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.72), transparent 24%), linear-gradient(135deg, #f6d8e4, #9bded4); }
.july-kakao-share__card-body strong { display: block; color: #0f1630; font-size: 13px; font-weight: 600; }
.july-kakao-share__card-body p { margin: 4px 0 0; color: #6f7890; font-size: 10px; line-height: 1.45; font-weight: 700; }
.july-kakao-share__buttons { display: flex; gap: 6px; margin-top: 8px; }
.july-kakao-share__buttons span { display: inline-flex; align-items: center; justify-content: center; min-width: 58px; height: 24px; padding: 0 8px; border-radius: 999px; background: #f7f9ff; color: #4d566f; font-size: 9px; font-weight: 600; }
.july-kakao-share__send-effect { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.july-kakao-share__send-effect i { position: absolute; left: 42px; top: 78px; width: 10px; height: 10px; border-radius: 50%; background: #ffe812; box-shadow: 0 0 0 8px rgba(255,232,18,.16); animation: julyKakaoSendOut 3s linear infinite; }
.july-kakao-share__send-effect i:nth-child(2) { animation-delay: .8s; }
.july-kakao-share__send-effect i:nth-child(3) { animation-delay: 1.6s; }
.july-kakao-share__users { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 12px; }
.july-kakao-share__user { display: flex; align-items: center; justify-content: center; min-height: 34px; border-radius: 999px; background: #f7f9ff; color: #5c667f; font-size: 11px; font-weight: 800; opacity: .45; transform: scale(.96) translateY(8px); animation: julyKakaoUserReceive 3.8s ease-in-out infinite; }
.july-kakao-share__user--2 { animation-delay: .8s; }
.july-kakao-share__user--3 { animation-delay: 1.6s; }
/* =========================
   KEYFRAMES
========================= */

@keyframes julyRankStackMove {
  0%, 24% { transform: translateY(0); }
  34%, 58% { transform: translateY(-22px); }
  68%, 100% { transform: translateY(-44px); }
}
@keyframes julyInstaProfileLift {
  0%, 100% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(215,152,255,0); }
  50% { transform: translateY(-2px); box-shadow: 0 0 0 6px rgba(215,152,255,.10); }
}
@keyframes julyInstaMainPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(215,152,255,0); }
  50% { transform: scale(1.03); box-shadow: 0 0 0 6px rgba(215,152,255,.10); }
}
@keyframes julyPinBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
@keyframes julyPlaceGraphUp {
  0%, 100% { transform: scaleY(.94); transform-origin: bottom; }
  50% { transform: scaleY(1.06); transform-origin: bottom; }
}
@keyframes julyKakaoCardPop {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-2px) scale(1.01); }
}
@keyframes julyKakaoSendOut {
  0% { left: 42px; top: 82px; opacity: 0; transform: scale(.4); }
  12% { opacity: 1; }
  70% { left: calc(100% - 42px); top: 120px; opacity: 1; transform: scale(1); }
  100% { left: calc(100% - 26px); top: 124px; opacity: 0; transform: scale(.6); }
}
@keyframes julyKakaoUserReceive {
  0%, 100% { opacity: .45; transform: scale(.96) translateY(8px); }
  28%, 62% { opacity: 1; transform: scale(1) translateY(0); background: #fff5b8; color: #5a4e14; }
}
/* =========================
   EFFECT BLOCK 1 - SHORTS GENERATION FINAL
========================= */

.july-effect__screen--shorts { overflow: hidden; background: radial-gradient(circle at 14% 14%, rgba(119,201,255,.13), transparent 25%), radial-gradient(circle at 82% 18%, rgba(215,152,255,.12), transparent 24%), linear-gradient(135deg, #0d1427 0%, #121c35 48%, #0b1224 100%) !important; border: 1px solid rgba(255,255,255,.09); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--shorts .july-effect__viewport, .july-effect__screen--shorts .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-shorts-flow { position: relative; height: 100%; min-height: 620px; padding: 34px 28px 26px; color: #fff; overflow: hidden; }
.july-shorts-flow::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 24px 24px; opacity: .55; pointer-events: none; }
.july-shorts-flow__head { position: relative; z-index: 10; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.july-shorts-flow__head small { display: block; margin-bottom: 5px; color: #8ec8ff; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-shorts-flow__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.25; font-weight: 600; letter-spacing: -.04em; }
.july-shorts-flow__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.10); color: rgba(255,255,255,.82); font-size: 11px; font-weight: 600; }
.july-shorts-flow__stage { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1.12fr 1fr; gap: 22px; align-items: center; }
.july-shorts-flow__section-title { margin-bottom: 14px; color: rgba(255,255,255,.70); font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-shorts-flow__upload, .july-shorts-flow__engine, .july-shorts-flow__result { position: relative; min-width: 0; }
.july-shorts-flow__upload-stack { position: relative; width: 158px; height: 218px; margin: 0 auto; }
.july-shorts-flow__photo { position: absolute; inset: 0; border-radius: 22px; overflow: hidden; border: 1px solid rgba(255,255,255,.10); box-shadow: 0 20px 50px rgba(0,0,0,.24); animation: julyShortsPhotoFloatFinal 5.2s ease-in-out infinite; }
.july-shorts-flow__photo::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.85), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.72), transparent 25%), linear-gradient(135deg, rgba(246,216,228,.95), rgba(155,222,212,.92)); }
.july-shorts-flow__photo span { position: absolute; left: 12px; bottom: 12px; display: inline-flex; align-items: center; height: 24px; padding: 0 10px; border-radius: 999px; background: rgba(17,24,39,.72); color: #fff; font-size: 10px; font-weight: 600; letter-spacing: .04em; }
.july-shorts-flow__photo.is-image::before { display: none; }
.july-shorts-flow__photo.is-image img { display: block; width: 100%; height: 100%; object-fit: cover; }
.july-shorts-flow__photo.is-image span { z-index: 2; }
.july-shorts-flow__video-frame.is-image { background: none !important; }
.july-shorts-flow__video-frame.is-image img { display: block; width: 100%; height: 100%; object-fit: cover; }
.july-shorts-flow__video .july-shorts-flow__badge, .july-shorts-flow__video .july-shorts-flow__caption, .july-shorts-flow__video .july-shorts-flow__chips { z-index: 2; }
.july-shorts-flow__photo--1 { --rot: -11deg; transform: rotate(-11deg) translateX(-18px); }
.july-shorts-flow__photo--2 { --rot: -2deg; transform: rotate(-2deg) translateY(8px); animation-delay: .45s; }
.july-shorts-flow__photo--2::before { background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.85), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.72), transparent 25%), linear-gradient(135deg, rgba(219,231,255,.95), rgba(240,217,255,.92)); }
.july-shorts-flow__photo--3 { --rot: 9deg; transform: rotate(9deg) translateX(18px); animation-delay: .9s; }
.july-shorts-flow__photo--3::before { background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.85), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.72), transparent 25%), linear-gradient(135deg, rgba(255,228,207,.95), rgba(255,212,234,.92)); }
.july-shorts-flow__upload-note { margin-top: 18px; text-align: center; color: rgba(255,255,255,.78); font-size: 13px; line-height: 1.65; font-weight: 800; }
.july-shorts-flow__engine { display: flex; flex-direction: column; align-items: center; }
.july-shorts-flow__ai-core { position: relative; width: 148px; height: 148px; margin: 0 auto 20px; }
.july-shorts-flow__ai-ring { position: absolute; inset: 0; border-radius: 50%; border: 1px solid rgba(119,201,255,.28); animation: julyShortsRingSpinFinal 8s linear infinite; }
.july-shorts-flow__ai-ring--2 { inset: 14px; border-color: rgba(215,152,255,.28); animation-direction: reverse; animation-duration: 6.5s; }
.july-shorts-flow__ai-center { position: absolute; inset: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #77c9ff, #d798ff); color: #0f1630; font-size: 28px; font-weight: 600; box-shadow: 0 0 0 12px rgba(255,255,255,.04), 0 0 40px rgba(119,201,255,.24); animation: julyShortsAiPulseFinal 3.2s ease-in-out infinite; }
.july-shorts-flow__meta-list { width: 100%; display: grid; gap: 9px; }
.july-shorts-flow__meta { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 14px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); color: rgba(255,255,255,.92); font-size: 11px; font-weight: 600; text-align: center; opacity: 0; transform: translateY(10px) scale(.98); animation: julyShortsMetaRevealFinal 6s ease-in-out infinite; }
.july-shorts-flow__meta--1 { animation-delay: .2s; }
.july-shorts-flow__meta--2 { animation-delay: .5s; }
.july-shorts-flow__meta--3 { animation-delay: .8s; }
.july-shorts-flow__meta--4 { animation-delay: 1.1s; }
.july-shorts-flow__meta--5 { animation-delay: 1.4s; }
.july-shorts-flow__phone { position: relative; width: 188px; height: 330px; margin: 0 auto; padding: 10px; border-radius: 34px; background: #0c1222; box-shadow: 0 24px 56px rgba(0,0,0,.34); }
.july-shorts-flow__phone-notch { position: absolute; top: 8px; left: 50%; width: 68px; height: 12px; margin-left: -34px; border-radius: 999px; background: rgba(255,255,255,.08); z-index: 4; }
.july-shorts-flow__video { position: relative; width: 100%; height: 100%; overflow: hidden; border-radius: 26px; background: #1b243e; }
.july-shorts-flow__video-frame { position: absolute; inset: 0; opacity: 0; animation: julyShortsVideoFrameFinal 6s ease-in-out infinite; }
.july-shorts-flow__video-frame--1 { background: radial-gradient(circle at 50% 26%, rgba(255,255,255,.82), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.70), transparent 23%), linear-gradient(180deg, rgba(246,216,228,.92), rgba(155,222,212,.88)); }
.july-shorts-flow__video-frame--2 { background: radial-gradient(circle at 50% 26%, rgba(255,255,255,.82), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.70), transparent 23%), linear-gradient(180deg, rgba(219,231,255,.92), rgba(240,217,255,.88)); animation-delay: 2.8s; }
.july-shorts-flow__badge { position: absolute; top: 14px; right: 14px; z-index: 3; display: inline-flex; align-items: center; height: 28px; padding: 0 12px; border-radius: 999px; background: rgba(3,199,90,.18); border: 1px solid rgba(3,199,90,.22); color: #d7ffe8; font-size: 10px; font-weight: 600; letter-spacing: .02em; animation: julyShortsBadgeFinal 2.8s ease-in-out infinite; }
.july-shorts-flow__caption { position: absolute; left: 14px; right: 14px; bottom: 88px; z-index: 3; padding: 10px 12px; border-radius: 14px; background: rgba(10,16,35,.56); color: #fff; font-size: 12px; font-weight: 600; line-height: 1.45; text-align: center; backdrop-filter: blur(6px); animation: julyShortsCaptionFinal 3.4s ease-in-out infinite; }
.july-shorts-flow__chips { position: absolute; left: 12px; right: 12px; bottom: 42px; z-index: 3; display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
.july-shorts-flow__chips span { display: inline-flex; align-items: center; height: 24px; padding: 0 9px; border-radius: 999px; background: rgba(255,255,255,.18); color: #fff; font-size: 9px; font-weight: 600; backdrop-filter: blur(4px); animation: julyShortsChipFinal 4s ease-in-out infinite; }
.july-shorts-flow__chips span:nth-child(2) { animation-delay: .2s; }
.july-shorts-flow__chips span:nth-child(3) { animation-delay: .4s; }
.july-shorts-flow__play { position:absolute; left:50%; top:50%; z-index:3; width:34px; height:34px; margin:-17px 0 0 -17px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.92); color:#111827; font-size:12px; font-weight:600; box-shadow:0 7px 16px rgba(0,0,0,.18); animation:julyShortsPlayFinal 2.8s ease-in-out infinite; }
.july-shorts-flow__timeline { position: relative; z-index: 4; display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 26px; }
.july-shorts-flow__step { display: flex; align-items: center; justify-content: center; min-height: 40px; padding: 0 10px; border-radius: 14px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.62); font-size: 11px; font-weight: 600; text-align: center; }
.july-shorts-flow__step.is-on { color: #fff; background: rgba(255,255,255,.10); }
.july-shorts-flow__step.is-accent { color: #0f1630; background: linear-gradient(90deg, #77c9ff, #d798ff); box-shadow: 0 10px 26px rgba(119,201,255,.18); animation: julyShortsStepFinal 2.8s ease-in-out infinite; }
/* animations */
@keyframes julyShortsPhotoFloatFinal {
  0%, 100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
  50% { transform: translateY(-8px) rotate(var(--rot, 0deg)); }
}
@keyframes julyShortsRingSpinFinal {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
@keyframes julyShortsAiPulseFinal {
  0%, 100% { box-shadow: 0 0 0 12px rgba(255,255,255,.04), 0 0 40px rgba(119,201,255,.24); }
  50% { box-shadow: 0 0 0 16px rgba(255,255,255,.05), 0 0 52px rgba(215,152,255,.28); }
}
@keyframes julyShortsMetaRevealFinal {
  0%, 14% { opacity: 0; transform: translateY(10px) scale(.98); }
  24%, 78% { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: .78; transform: translateY(0) scale(1); }
}
@keyframes julyShortsVideoFrameFinal {
  0%, 38% { opacity: 1; transform: scale(1); }
  50%, 100% { opacity: 0; transform: scale(1.04); }
}
@keyframes julyShortsBadgeFinal {
  0%, 100% { box-shadow: 0 0 0 0 rgba(3,199,90,0); }
  50% { box-shadow: 0 0 0 8px rgba(3,199,90,.10); }
}
@keyframes julyShortsCaptionFinal {
  0%, 100% { transform: translateY(0); opacity: .96; }
  50% { transform: translateY(-2px); opacity: 1; }
}
@keyframes julyShortsChipFinal {
  0%, 100% { opacity: .72; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-2px); }
}
@keyframes julyShortsPlayFinal {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.06); }
}
@keyframes julyShortsStepFinal {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
/* responsive */
@media (max-width:1024px) {
  .july-shorts-flow { min-height: 900px; padding: 28px 20px 22px; }
  .july-shorts-flow__stage { grid-template-columns: 1fr; gap: 26px; }
  .july-shorts-flow__upload-stack, .july-shorts-flow__phone { margin-left: auto; margin-right: auto; }
  .july-shorts-flow__timeline { grid-template-columns: 1fr 1fr; }
}
@media (max-width:640px) {
  .july-shorts-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-shorts-flow__head { display: block; }
  .july-shorts-flow__head > span { margin-top: 10px; }
  .july-shorts-flow__upload-stack { width: 142px; height: 196px; }
  .july-shorts-flow__phone { width: 170px; height: 300px; }
  .july-shorts-flow__timeline { grid-template-columns: 1fr; }
}
/* =========================
   EFFECT BLOCK 2 - CONTENT LIBRARY FINAL
========================= */

.july-effect__screen--history { overflow: hidden; background: radial-gradient(circle at 18% 12%, rgba(119,201,255,.12), transparent 25%), radial-gradient(circle at 82% 20%, rgba(215,152,255,.10), transparent 24%), linear-gradient(135deg, #0d1427 0%, #121c35 48%, #0b1224 100%) !important; border: 1px solid rgba(255,255,255,.09); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--history .july-effect__viewport, .july-effect__screen--history .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-history-flow { position: relative; height: 100%; min-height: 620px; padding: 34px 28px 26px; color: #fff; overflow: hidden; }
.july-history-flow::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 24px 24px; opacity: .55; pointer-events: none; }
.july-history-flow__head { position: relative; z-index: 10; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.july-history-flow__head small, .july-history-caption__head small { display: block; margin-bottom: 5px; color: #8ec8ff; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-history-flow__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.25; font-weight: 600; letter-spacing: -.04em; }
.july-history-flow__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.10); color: rgba(255,255,255,.82); font-size: 11px; font-weight: 600; }
.july-history-flow__list-wrap { position: relative; z-index: 3; height: 292px; overflow: hidden; padding: 2px 0 14px; mask-image: linear-gradient( 180deg, transparent 0%, #000 8%, #000 86%, transparent 100% ); -webkit-mask-image: linear-gradient( 180deg, transparent 0%, #000 8%, #000 86%, transparent 100% ); }
.july-history-flow__list { display: grid; gap: 10px; animation: julyHistoryListFinalMove 8s ease-in-out infinite; }
.july-history-item { display: grid; grid-template-columns: 64px minmax(0, 1fr) auto; gap: 12px; align-items: center; min-height: 104px; padding: 12px; border-radius: 20px; background: rgba(17, 27, 52, .94); border: 1px solid rgba(255,255,255,.08); box-shadow: 0 14px 30px rgba(0,0,0,.20); color: #fff; }
.july-history-item--2 { animation: julyHistorySelectedFinal 8s ease-in-out infinite; }
.july-history-item__thumb { position: relative; width: 64px; height: 82px; overflow: hidden; border-radius: 16px; background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.82), transparent 14%), radial-gradient(circle at 50% 84%, rgba(255,255,255,.68), transparent 24%), linear-gradient(135deg, #f7dbe6, #a8ded6); }
.july-history-item:nth-child(2) .july-history-item__thumb { background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.82), transparent 14%), radial-gradient(circle at 50% 84%, rgba(255,255,255,.68), transparent 24%), linear-gradient(135deg, #dbe7ff, #f0d9ff); }
.july-history-item:nth-child(3) .july-history-item__thumb { background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.82), transparent 14%), radial-gradient(circle at 50% 84%, rgba(255,255,255,.68), transparent 24%), linear-gradient(135deg, #ffe4cf, #ffd4ea); }
.july-history-item:nth-child(4) .july-history-item__thumb { background: radial-gradient(circle at 50% 30%, rgba(255,255,255,.82), transparent 14%), radial-gradient(circle at 50% 84%, rgba(255,255,255,.68), transparent 24%), linear-gradient(135deg, #dff8ee, #f5d6ff); }
.july-history-item__thumb span { position: absolute; left: 8px; bottom: 8px; display: inline-flex; align-items: center; height: 20px; padding: 0 8px; border-radius: 999px; background: rgba(17,24,39,.70); color: #fff; font-size: 9px; font-weight: 600; }
.july-history-item__thumb.is-image { background:#111827; }
.july-history-item__thumb.is-image img { display:block; width:100%; height:100%; object-fit:cover; }
.july-history-item__thumb.is-image span { z-index:2; }
.july-history-item__body { min-width: 0; }
.july-history-item__body strong { display: block; color: #fff; font-size: 14px; line-height: 1.35; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.july-history-item__body p { margin: 4px 0 8px; color: rgba(255,255,255,.62); font-size: 11px; line-height: 1.45; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.july-history-item__tags { display: flex; flex-wrap: wrap; gap: 5px; }
.july-history-item__tags span { display: inline-flex; align-items: center; height: 22px; padding: 0 8px; border-radius: 999px; background: rgba(255,255,255,.08); color: rgba(255,255,255,.72); font-size: 9px; font-weight: 600; }
.july-history-item button { height: 34px; padding: 0 12px; border: 0; border-radius: 999px; background: linear-gradient(90deg, #72b8ff, #b38cff); color: #08111f; font-size: 11px; font-weight: 600; box-shadow: 0 10px 24px rgba(114,184,255,.18); }
.july-history-item.is-downloading button { background: rgba(255,255,255,.12); color: #fff; animation: julyDownloadButtonFinal 8s ease-in-out infinite; }
.july-history-action-panel { position: relative; z-index: 8; margin-top: 14px; opacity: 1; transform: none; animation: julyHistoryActionFinalGlow 4.8s ease-in-out infinite; }
.july-history-download { display: grid; grid-template-columns: 42px minmax(0,1fr); gap: 12px; align-items: center; padding: 12px; border-radius: 18px; background: rgba(3,199,90,.12); border: 1px solid rgba(3,199,90,.18); animation: julyHistoryDownloadFinalPulse 4.2s ease-in-out infinite; }
.july-history-download__icon { width: 42px; height: 42px; border-radius: 15px; display: flex; align-items: center; justify-content: center; background: #03c75a; color: #fff; font-size: 22px; font-weight: 600; }
.july-history-download strong { display: block; color: #fff; font-size: 14px; font-weight: 600; }
.july-history-download p { margin: 4px 0 0; color: rgba(255,255,255,.68); font-size: 11px; font-weight: 700; }
.july-history-channel-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; margin-top: 10px; }
.july-history-channel { min-height: 76px; padding: 10px 8px; border-radius: 16px; background: rgba(17,27,52,.95); border: 1px solid rgba(255,255,255,.08); color: #fff; text-align: center; box-shadow: 0 12px 26px rgba(0,0,0,.18); animation: julyHistoryChannelFinalPop 5s ease-in-out infinite; }
.july-history-channel--insta { animation-delay: 0s; }
.july-history-channel--naver { animation-delay: .35s; }
.july-history-channel--place { animation-delay: .7s; }
.july-history-channel span { width: 32px; height: 32px; margin: 0 auto 6px; border-radius: 12px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 15px; font-weight: 600; }
.july-history-channel--insta span { background: radial-gradient(circle at 30% 110%, #ffdb7b 0%, #f77737 24%, #e1306c 48%, #833ab4 72%, #405de6 100%); }
.july-history-channel--naver span { background: #03c75a; }
.july-history-channel--place span { background: #0f1630; font-size: 15px; }
.july-history-channel strong { display: block; color: #fff; font-size: 12px; font-weight: 600; }
.july-history-caption { position: relative; z-index: 8; margin-top: 12px; padding: 14px; border-radius: 18px; background: rgba(17,27,52,.96); border: 1px solid rgba(255,255,255,.08); box-shadow: 0 14px 30px rgba(0,0,0,.20); animation: julyHistoryCaptionFinalGlow 5s ease-in-out infinite; }
.july-history-caption__head small { color: #8ec8ff; }
.july-history-caption__head strong { display: block; color: #fff; font-size: 15px; font-weight: 600; }
.july-history-caption p { margin: 10px 0 0; color: rgba(255,255,255,.70); font-size: 11px; line-height: 1.55; font-weight: 700; }
.july-history-caption__tags { margin-top: 9px; padding: 9px 11px; border-radius: 13px; background: rgba(255,255,255,.06); color: #b9bbff; font-size: 10px; line-height: 1.45; font-weight: 600; }
/* animations */
@keyframes julyHistoryListFinalMove {
  0%, 28% { transform: translateY(0); }
  44%, 68% { transform: translateY(-52px); }
  84%, 100% { transform: translateY(-104px); }
}
@keyframes julyHistorySelectedFinal {
  0%, 28% { transform: translateY(0) scale(1); box-shadow: 0 14px 30px rgba(0,0,0,.20); }
  40%, 62% { transform: translateY(-2px) scale(1.015); box-shadow: 0 18px 42px rgba(114,184,255,.18); }
  100% { transform: translateY(0) scale(1); box-shadow: 0 14px 30px rgba(0,0,0,.20); }
}
@keyframes julyDownloadButtonFinal {
  0%, 34% { background: linear-gradient(90deg, #72b8ff, #b38cff); color: #08111f; }
  44%, 100% { background: rgba(255,255,255,.12); color: #fff; }
}
@keyframes julyHistoryActionFinalGlow {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(114,184,255,0)); }
  50% { filter: drop-shadow(0 12px 26px rgba(114,184,255,.10)); }
}
@keyframes julyHistoryDownloadFinalPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(3,199,90,0); }
  50% { box-shadow: 0 0 0 6px rgba(3,199,90,.08); }
}
@keyframes julyHistoryChannelFinalPop {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-3px) scale(1.015); }
}
@keyframes julyHistoryCaptionFinalGlow {
  0%, 100% { box-shadow: 0 14px 30px rgba(0,0,0,.20); }
  50% { box-shadow: 0 18px 38px rgba(114,184,255,.14); }
}
/* responsive */
@media (max-width:1024px) {
  .july-history-flow { min-height: 680px; padding: 28px 20px 22px; }
  .july-history-flow__list-wrap { height: 286px; }
}
@media (max-width:640px) {
  .july-history-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-history-flow__head { display: block; }
  .july-history-flow__head > span { margin-top: 10px; }
  .july-history-flow__list-wrap { height: 330px; }
  .july-history-item { grid-template-columns: 56px minmax(0,1fr); min-height: auto; }
  .july-history-item button { grid-column: 1 / -1; width: 100%; }
  .july-history-item__thumb { width: 56px; height: 76px; }
  .july-history-channel-row { grid-template-columns: 1fr; }
}
/* =========================
   EFFECT BLOCK 3 - CUSTOMER FLOW FINAL
========================= */

.july-effect__screen--customer { overflow: hidden; background: radial-gradient(circle at 12% 12%, rgba(118, 221, 190, .12), transparent 24%), radial-gradient(circle at 86% 18%, rgba(120, 176, 255, .12), transparent 22%), linear-gradient(135deg, #0d1427 0%, #121c35 48%, #0b1224 100%) !important; border: 1px solid rgba(255,255,255,.09); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--customer .july-effect__viewport, .july-effect__screen--customer .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-customer-flow { position: relative; height: 100%; min-height: 640px; padding: 34px 28px 24px; color: #fff; overflow: hidden; }
.july-customer-flow::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 24px 24px; opacity: .55; pointer-events: none; }
.july-customer-flow__head { position: relative; z-index: 3; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.july-customer-flow__head small { display: block; margin-bottom: 5px; color: #8ec8ff; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-customer-flow__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.24; font-weight: 600; letter-spacing: -.04em; }
.july-customer-flow__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.10); color: rgba(255,255,255,.82); font-size: 11px; font-weight: 600; }
.july-customer-flow__body { position: relative; z-index: 2; display: grid; grid-template-columns: 1.02fr 1.18fr; gap: 22px; align-items: stretch; }
.july-customer-flow__left, .july-customer-flow__right { display: flex; flex-direction: column; gap: 18px; min-width: 0; }
/* upload */
.july-customer-upload, .july-customer-alert, .july-customer-chart, .july-customer-list, .july-customer-kpi { background: rgba(10,16,35,.42); border: 1px solid rgba(255,255,255,.08); border-radius: 24px; box-shadow: 0 18px 46px rgba(0,0,0,.18); backdrop-filter: blur(10px); }
.july-customer-upload { padding: 18px; }
.july-customer-upload__head, .july-customer-chart__head, .july-customer-list__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.july-customer-upload__head small, .july-customer-chart__head small, .july-customer-list__head small { display: block; margin-bottom: 4px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-customer-upload__head strong, .july-customer-chart__head strong, .july-customer-list__head strong { display: block; color: #fff; font-size: 15px; line-height: 1.35; font-weight: 800; }
.july-customer-upload__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; height: 28px; padding: 0 10px; border-radius: 999px; background: linear-gradient(90deg, rgba(118,221,190,.18), rgba(120,176,255,.18)); border: 1px solid rgba(118,221,190,.20); color: #d8fff2; font-size: 10px; font-weight: 600; }
.july-customer-upload__drop { position: relative; overflow: hidden; border-radius: 20px; padding: 24px 18px; min-height: 168px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); border: 1px dashed rgba(255,255,255,.14); text-align: center; }
.july-customer-upload__scan { position: absolute; left: 12px; right: 12px; top: -18%; height: 36px; background: linear-gradient(180deg, rgba(118,221,190,.00), rgba(118,221,190,.18), rgba(118,221,190,.00)); filter: blur(4px); animation: julyCustomerScan 3s ease-in-out infinite; }
.july-customer-upload__icon { position: relative; z-index: 2; font-size: 30px; margin-bottom: 10px; }
.july-customer-upload__text { position: relative; z-index: 2; color: #fff; font-size: 14px; font-weight: 800; line-height: 1.5; margin-bottom: 8px; }
.july-customer-upload__sub { position: relative; z-index: 2; color: rgba(255,255,255,.68); font-size: 12px; line-height: 1.55; font-weight: 700; }
.july-customer-upload__result { display: grid; gap: 10px; margin-top: 14px; }
.july-customer-upload__field { display: flex; align-items: center; justify-content: space-between; gap: 10px; min-height: 42px; padding: 0 14px; border-radius: 14px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.05); animation: julyCustomerFieldPulse 5s ease-in-out infinite; }
.july-customer-upload__field:nth-child(2) { animation-delay: .25s; }
.july-customer-upload__field:nth-child(3) { animation-delay: .5s; }
.july-customer-upload__field span { color: rgba(255,255,255,.58); font-size: 11px; font-weight: 800; }
.july-customer-upload__field strong { color: #fff; font-size: 13px; font-weight: 800; text-align: right; }
/* alert */
.july-customer-alert { position: relative; overflow: hidden; padding: 18px; display: flex; gap: 14px; align-items: center; background: radial-gradient(circle at 85% 25%, rgba(255,108,108,.18), transparent 34%), rgba(10,16,35,.48); }
.july-customer-alert__badge { flex: 0 0 56px; width: 56px; height: 56px; border-radius: 18px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #ff8a65, #ff5c7c); color: #fff; font-size: 12px; font-weight: 600; box-shadow: 0 12px 28px rgba(255,92,124,.26); animation: julyCustomerAlertPulse 2.8s ease-in-out infinite; }
.july-customer-alert__content small { display: block; margin-bottom: 5px; color: rgba(255,255,255,.60); font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-customer-alert__content strong { display: block; color: #fff; font-size: 22px; line-height: 1.2; font-weight: 600; margin-bottom: 6px; }
.july-customer-alert__content p { margin: 0; color: rgba(255,255,255,.74); font-size: 12px; line-height: 1.6; font-weight: 700; }
/* kpi */
.july-customer-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.july-customer-kpi { padding: 16px 14px; min-height: 108px; }
.july-customer-kpi small { display: block; margin-bottom: 8px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-customer-kpi strong { display: block; color: #fff; font-size: 22px; line-height: 1.2; font-weight: 600; margin-bottom: 6px; }
.july-customer-kpi span { display: block; color: rgba(255,255,255,.72); font-size: 11px; line-height: 1.45; font-weight: 700; }
.july-customer-kpi--sales { background: radial-gradient(circle at 90% 20%, rgba(118,221,190,.18), transparent 34%), rgba(10,16,35,.42); }
.july-customer-kpi--revisit { background: radial-gradient(circle at 90% 20%, rgba(120,176,255,.18), transparent 34%), rgba(10,16,35,.42); }
.july-customer-kpi--noshow { background: radial-gradient(circle at 90% 20%, rgba(255,124,124,.18), transparent 34%), rgba(10,16,35,.42); }
/* chart */
.july-customer-chart { padding: 18px; }
.july-customer-chart__bars { display: flex; align-items: end; justify-content: space-between; gap: 14px; height: 170px; padding-top: 10px; }
.july-customer-chart__item { flex: 1; text-align: center; }
.july-customer-chart__bar { width: 100%; max-width: 56px; margin: 0 auto 10px; border-radius: 18px 18px 10px 10px; background: linear-gradient(180deg, #7fe5c8 0%, #6fb0ff 100%); box-shadow: 0 12px 24px rgba(111,176,255,.14); animation: julyCustomerBarGrow 3.8s ease-in-out infinite; transform-origin: bottom; }
.july-customer-chart__bar--1 { height: 72px; animation-delay: .1s; }
.july-customer-chart__bar--2 { height: 102px; animation-delay: .25s; }
.july-customer-chart__bar--3 { height: 132px; animation-delay: .4s; }
.july-customer-chart__bar--4 { height: 152px; animation-delay: .55s; }
.july-customer-chart__item span { color: rgba(255,255,255,.68); font-size: 11px; font-weight: 800; }
/* list */
.july-customer-list { padding: 18px; }
.july-customer-list__items { display: grid; gap: 10px; }
.july-customer-list__item { display: grid; grid-template-columns: 40px 1fr auto; align-items: center; gap: 12px; min-height: 68px; padding: 0 14px; border-radius: 16px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.05); animation: julyCustomerRowFloat 6s ease-in-out infinite; }
.july-customer-list__item:nth-child(2) { animation-delay: .2s; }
.july-customer-list__item:nth-child(3) { animation-delay: .45s; }
.july-customer-list__item.is-alert { background: rgba(255,92,124,.08); border-color: rgba(255,92,124,.18); }
.july-customer-list__avatar { width: 40px; height: 40px; border-radius: 50%; background: radial-gradient(circle at 50% 34%, rgba(255,255,255,.82), transparent 18%), linear-gradient(135deg, rgba(246,216,228,.95), rgba(155,222,212,.92)); }
.july-customer-list__info strong { display: block; color: #fff; font-size: 13px; font-weight: 800; margin-bottom: 4px; }
.july-customer-list__info span { display: block; color: rgba(255,255,255,.66); font-size: 11px; line-height: 1.45; font-weight: 700; }
.july-customer-list__state { display: inline-flex; align-items: center; justify-content: center; min-width: 68px; height: 30px; padding: 0 10px; border-radius: 999px; font-style: normal; font-size: 10px; font-weight: 600; letter-spacing: .02em; }
.july-customer-list__state.is-done { background: rgba(118,221,190,.16); color: #d8fff2; }
.july-customer-list__state.is-wait { background: rgba(120,176,255,.16); color: #dcebff; }
.july-customer-list__state.is-alert { background: rgba(255,92,124,.18); color: #ffe1e8; }
/* timeline */
.july-customer-flow__timeline { position: relative; z-index: 4; display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 22px; }
.july-customer-flow__step { display: flex; align-items: center; justify-content: center; min-height: 40px; padding: 0 10px; border-radius: 14px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.62); font-size: 11px; font-weight: 600; text-align: center; }
.july-customer-flow__step.is-on { color: #fff; background: rgba(255,255,255,.10); }
.july-customer-flow__step.is-accent { color: #0f1630; background: linear-gradient(90deg, #7fe5c8, #6fb0ff); box-shadow: 0 10px 26px rgba(111,176,255,.18); animation: julyCustomerStepPulse 2.8s ease-in-out infinite; }
/* animation */
@keyframes julyCustomerScan {
  0% { top: -20%; opacity: 0; }
  20% { opacity: 1; }
  50% { top: 48%; opacity: .95; }
  100% { top: 110%; opacity: 0; }
}
@keyframes julyCustomerFieldPulse {
  0%, 100% { background: rgba(255,255,255,.05); }
  50% { background: rgba(255,255,255,.085); }
}
@keyframes julyCustomerAlertPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 12px 28px rgba(255,92,124,.22); }
  50% { transform: scale(1.05); box-shadow: 0 16px 34px rgba(255,92,124,.34); }
}
@keyframes julyCustomerBarGrow {
  0%, 100% { transform: scaleY(.88); opacity: .88; }
  50% { transform: scaleY(1); opacity: 1; }
}
@keyframes julyCustomerRowFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
@keyframes julyCustomerStepPulse {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
/* responsive */
@media (max-width:1024px) {
  .july-customer-flow { min-height: 980px; padding: 28px 20px 22px; }
  .july-customer-flow__body { grid-template-columns: 1fr; }
  .july-customer-kpis { grid-template-columns: 1fr; }
  .july-customer-flow__timeline { grid-template-columns: 1fr 1fr; }
}
@media (max-width:640px) {
  .july-customer-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-customer-flow__head { display: block; }
  .july-customer-flow__head > span { margin-top: 10px; }
  .july-customer-list__item { grid-template-columns: 40px 1fr; align-items: start; padding-top: 12px; padding-bottom: 12px; }
  .july-customer-list__state { grid-column: 2; justify-self: start; margin-top: 2px; }
  .july-customer-flow__timeline { grid-template-columns: 1fr; }
}
/* =========================
   EFFECT BLOCK 4 - STORE CARD SHARE FINAL
========================= */

.july-effect__screen--share-card { overflow: hidden; background: radial-gradient(circle at 12% 12%, rgba(255,232,18,.11), transparent 24%), radial-gradient(circle at 84% 18%, rgba(119,201,255,.12), transparent 24%), linear-gradient(135deg, #0d1427 0%, #121c35 48%, #0b1224 100%) !important; border: 1px solid rgba(255,255,255,.09); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--share-card .july-effect__viewport, .july-effect__screen--share-card .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-share-flow { position: relative; height: 100%; min-height: 660px; padding: 34px 28px 24px; color: #fff; overflow: hidden; }
.july-share-flow::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 24px 24px; opacity: .55; pointer-events: none; }
.july-share-flow__head { position: relative; z-index: 3; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.july-share-flow__head small { display: block; margin-bottom: 5px; color: #ffe812; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-share-flow__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.24; font-weight: 600; letter-spacing: -.04em; }
.july-share-flow__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(255,232,18,.12); border: 1px solid rgba(255,232,18,.18); color: #fff6a6; font-size: 11px; font-weight: 600; }
.july-share-flow__body { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1.12fr; gap: 22px; align-items: stretch; }
/* left builder */
.july-share-builder, .july-kakao-spread__phone, .july-share-result { background: rgba(10,16,35,.42); border: 1px solid rgba(255,255,255,.08); border-radius: 24px; box-shadow: 0 18px 46px rgba(0,0,0,.18); backdrop-filter: blur(10px); }
.july-share-builder { padding: 18px; }
.july-share-builder__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.july-share-builder__top small { display: block; margin-bottom: 4px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-share-builder__top strong { display: block; color: #fff; font-size: 15px; line-height: 1.35; font-weight: 800; }
.july-share-builder__top em { flex: 0 0 auto; display: inline-flex; align-items: center; height: 28px; padding: 0 10px; border-radius: 999px; background: rgba(119,201,255,.12); border: 1px solid rgba(119,201,255,.18); color: #cfefff; font-size: 10px; font-style: normal; font-weight: 600; }
.july-store-card { overflow: hidden; border-radius: 24px; background: rgba(255,255,255,.94); color: #0f1630; box-shadow: 0 18px 38px rgba(0,0,0,.18); animation: julyStoreCardFloat 4.8s ease-in-out infinite; }
.july-store-card__cover { height: 104px; background: radial-gradient(circle at 50% 34%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.68), transparent 28%), linear-gradient(135deg, #f6d8e4, #9bded4); }
.july-store-card__profile { display: grid; grid-template-columns: 58px minmax(0,1fr); gap: 12px; align-items: center; padding: 0 16px 14px; margin-top: -22px; }
.july-store-card__avatar { width: 58px; height: 58px; border-radius: 20px; background: radial-gradient(circle at 50% 32%, rgba(255,255,255,.82), transparent 16%), linear-gradient(135deg, #77c9ff, #d798ff); border: 3px solid #fff; }
.july-store-card__profile strong { display: block; color: #0f1630; font-size: 16px; font-weight: 600; }
.july-store-card__profile p { margin: 4px 0 0; color: #687089; font-size: 11px; font-weight: 700; }
.july-store-card__buttons { display: grid; gap: 8px; padding: 0 16px 14px; }
.july-store-card__btn { display: flex; align-items: center; min-height: 38px; padding: 0 12px; border-radius: 14px; background: #f7f9ff; color: #0f1630; font-size: 12px; font-weight: 600; animation: julyStoreButtonPulse 5s ease-in-out infinite; }
.july-store-card__btn:nth-child(2) { animation-delay: .3s; }
.july-store-card__btn:nth-child(3) { animation-delay: .6s; }
.july-store-card__btn b { width: 24px; height: 24px; margin-right: 8px; border-radius: 9px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 11px; font-weight: 600; }
.july-store-card__btn--naver b { background: #03c75a; }
.july-store-card__btn--insta b { background: radial-gradient(circle at 30% 110%, #ffdb7b 0%, #f77737 24%, #e1306c 48%, #833ab4 72%, #405de6 100%); }
.july-store-card__btn--phone b { background: #0f1630; }
.july-store-card__event { display: grid; grid-template-columns: 40px minmax(0,1fr) auto; gap: 10px; align-items: center; margin: 0 16px 16px; padding: 12px; border-radius: 18px; background: linear-gradient(90deg, rgba(119,201,255,.10), rgba(215,152,255,.12)); animation: julyStoreEventGlow 4s ease-in-out infinite; }
.july-store-card__event-icon { width: 40px; height: 40px; border-radius: 14px; display: flex; align-items: center; justify-content: center; background: #fff; }
.july-store-card__event strong { display: block; color: #0f1630; font-size: 12px; font-weight: 600; }
.july-store-card__event p { margin: 3px 0 0; color: #687089; font-size: 10px; font-weight: 700; }
.july-store-card__event > span { display: inline-flex; align-items: center; height: 26px; padding: 0 8px; border-radius: 999px; background: #fff; color: #5d54d6; font-size: 9px; font-weight: 600; }
.july-share-builder__steps { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 14px; }
.july-share-builder__steps div { min-height: 34px; padding: 0 12px; border-radius: 13px; display: flex; align-items: center; background: rgba(255,255,255,.06); color: rgba(255,255,255,.72); font-size: 11px; font-weight: 600; }
.july-share-builder__steps .is-on { color: #fff; background: rgba(255,255,255,.10); }
.july-share-builder__steps .is-accent { color: #0f1630; background: linear-gradient(90deg, #ffe812, #77c9ff); }
/* right kakao */
.july-kakao-spread { display: flex; flex-direction: column; gap: 14px; }
.july-kakao-spread__phone { overflow: hidden; }
.july-kakao-spread__header { height: 42px; padding: 0 14px; background: #ffe812; color: #3a3000; display: flex; align-items: center; justify-content: space-between; }
.july-kakao-spread__header span, .july-kakao-spread__header b { font-size: 12px; font-weight: 600; }
.july-kakao-spread__room { position: relative; min-height: 300px; padding: 18px; overflow: hidden; background: radial-gradient(circle at 12% 18%, rgba(255,255,255,.28), transparent 20%), linear-gradient(180deg, #bfe8ff 0%, #d9f2ff 100%); }
.july-kakao-spread__message { position: relative; z-index: 3; display: grid; grid-template-columns: 82px minmax(0,1fr); gap: 12px; padding: 12px; border-radius: 18px; background: #fff; box-shadow: 0 14px 30px rgba(15,22,48,.12); animation: julyKakaoMessagePop 4.8s ease-in-out infinite; }
.july-kakao-spread__thumb { width: 82px; height: 82px; border-radius: 18px; background: radial-gradient(circle at 50% 32%, rgba(255,255,255,.82), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,255,255,.68), transparent 26%), linear-gradient(135deg, #f6d8e4, #9bded4); }
.july-kakao-spread__msg-body strong { display: block; color: #0f1630; font-size: 14px; font-weight: 600; }
.july-kakao-spread__msg-body p { margin: 5px 0 8px; color: #687089; font-size: 11px; line-height: 1.45; font-weight: 700; }
.july-kakao-spread__msg-buttons { display: flex; gap: 6px; }
.july-kakao-spread__msg-buttons span { display: inline-flex; align-items: center; justify-content: center; min-width: 62px; height: 26px; padding: 0 8px; border-radius: 999px; background: #f4f6fb; color: #0f1630; font-size: 9px; font-weight: 600; }
.july-kakao-spread__send { position: absolute; left: 18px; right: 18px; bottom: 18px; z-index: 4; height: 42px; border: 0; border-radius: 999px; background: #ffe812; color: #3a3000; font-size: 13px; font-weight: 600; box-shadow: 0 12px 24px rgba(0,0,0,.12); animation: julyKakaoSendButtonPulse 3.4s ease-in-out infinite; }
.july-kakao-spread__particles { position: absolute; inset: 0; pointer-events: none; z-index: 2; }
.july-kakao-spread__particles i { position: absolute; left: 50%; bottom: 48px; width: 10px; height: 10px; border-radius: 50%; background: #ffe812; box-shadow: 0 0 0 8px rgba(255,232,18,.18); opacity: 0; animation: julyKakaoParticleFly 3.8s linear infinite; }
.july-kakao-spread__particles i:nth-child(1) { animation-delay: .1s; --x: -160px; --y: -210px; }
.july-kakao-spread__particles i:nth-child(2) { animation-delay: .7s; --x: 120px; --y: -190px; }
.july-kakao-spread__particles i:nth-child(3) { animation-delay: 1.3s; --x: -90px; --y: -130px; }
.july-kakao-spread__particles i:nth-child(4) { animation-delay: 1.9s; --x: 170px; --y: -250px; }
.july-kakao-spread__users { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.july-kakao-user { min-height: 76px; padding: 12px 8px; border-radius: 18px; background: rgba(10,16,35,.42); border: 1px solid rgba(255,255,255,.08); text-align: center; box-shadow: 0 14px 30px rgba(0,0,0,.16); opacity: .58; transform: translateY(8px) scale(.97); animation: julyKakaoUserReceiveFinal 4.8s ease-in-out infinite; }
.july-kakao-user--2 { animation-delay: .55s; }
.july-kakao-user--3 { animation-delay: 1.1s; }
.july-kakao-user span { display: block; margin-bottom: 6px; color: rgba(255,255,255,.60); font-size: 10px; font-weight: 600; }
.july-kakao-user strong { display: block; color: #fff; font-size: 12px; line-height: 1.35; font-weight: 600; }
.july-share-result { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; overflow: hidden; }
.july-share-result div { padding: 14px 10px; text-align: center; background: rgba(255,255,255,.035); }
.july-share-result small { display: block; margin-bottom: 5px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 600; }
.july-share-result strong { display: block; color: #fff; font-size: 18px; font-weight: 600; }
/* timeline */
.july-share-flow__timeline { position: relative; z-index: 4; display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 22px; }
.july-share-flow__step { display: flex; align-items: center; justify-content: center; min-height: 40px; padding: 0 10px; border-radius: 14px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.62); font-size: 11px; font-weight: 600; text-align: center; }
.july-share-flow__step.is-on { color: #fff; background: rgba(255,255,255,.10); }
.july-share-flow__step.is-accent { color: #0f1630; background: linear-gradient(90deg, #ffe812, #77c9ff); box-shadow: 0 10px 26px rgba(255,232,18,.16); animation: julyShareStepPulse 2.8s ease-in-out infinite; }
/* animations */
@keyframes julyStoreCardFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
@keyframes julyStoreButtonPulse {
  0%, 100% { background: #f7f9ff; }
  50% { background: #eef4ff; }
}
@keyframes julyStoreEventGlow {
  0%, 100% { box-shadow: 0 0 0 rgba(138,125,255,0); }
  50% { box-shadow: 0 0 0 6px rgba(138,125,255,.08); }
}
@keyframes julyKakaoMessagePop {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-3px) scale(1.01); }
}
@keyframes julyKakaoSendButtonPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 12px 24px rgba(0,0,0,.12); }
  50% { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(255,232,18,.20); }
}
@keyframes julyKakaoParticleFly {
  0% { opacity: 0; transform: translate(0, 0) scale(.5); }
  12% { opacity: 1; }
  80% { opacity: 1; transform: translate(var(--x), var(--y)) scale(1); }
  100% { opacity: 0; transform: translate(var(--x), var(--y)) scale(.45); }
}
@keyframes julyKakaoUserReceiveFinal {
  0%, 100% { opacity: .58; transform: translateY(8px) scale(.97); background: rgba(10,16,35,.42); }
  32%, 70% { opacity: 1; transform: translateY(0) scale(1); background: rgba(255,232,18,.12); border-color: rgba(255,232,18,.20); }
}
@keyframes julyShareStepPulse {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
/* responsive */
@media (max-width:1024px) {
  .july-share-flow { min-height: 980px; padding: 28px 20px 22px; }
  .july-share-flow__body { grid-template-columns: 1fr; }
  .july-share-flow__timeline { grid-template-columns: 1fr 1fr; }
}
@media (max-width:640px) {
  .july-share-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-share-flow__head { display: block; }
  .july-share-flow__head > span { margin-top: 10px; }
  .july-store-card__event { grid-template-columns: 40px minmax(0,1fr); }
  .july-store-card__event > span { grid-column: 1 / -1; justify-content: center; }
  .july-kakao-spread__users, .july-share-result { grid-template-columns: 1fr; }
  .july-share-flow__timeline { grid-template-columns: 1fr; }
}
/* =========================
   EFFECT BLOCK 5 - AI REPORT FINAL
========================= */

.july-effect__screen--ai-report { overflow: hidden; background: radial-gradient(circle at 14% 16%, rgba(117, 126, 255, 0.16), transparent 24%), radial-gradient(circle at 84% 18%, rgba(255, 122, 198, 0.13), transparent 24%), linear-gradient(135deg, #0c1326 0%, #101936 46%, #0b1224 100%) !important; border: 1px solid rgba(255,255,255,.08); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--ai-report .july-effect__viewport, .july-effect__screen--ai-report .july-effect__screen-inner { height: 100%; overflow: hidden; background: transparent !important; }
.july-ai-report { position: relative; min-height: 760px; padding: 30px 24px 24px; color: #fff; overflow: hidden; }
.july-ai-report::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px); background-size: 22px 22px; opacity: .55; pointer-events: none; }
.july-ai-report__head { position: relative; z-index: 2; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 20px; }
.july-ai-report__head small { display: block; margin-bottom: 5px; color: #8ebaff; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-ai-report__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.28; font-weight: 600; letter-spacing: -.04em; }
.july-ai-report__head > span { flex: 0 0 auto; display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: rgba(157,130,255,.12); border: 1px solid rgba(157,130,255,.2); color: #d4c6ff; font-size: 11px; font-weight: 600; }
.july-ai-report__grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.08fr .92fr; gap: 16px; }
.july-ai-card { position: relative; background: rgba(10,16,35,.48); border: 1px solid rgba(255,255,255,.08); border-radius: 24px; padding: 18px; box-shadow: 0 18px 46px rgba(0,0,0,.2); backdrop-filter: blur(10px); overflow: hidden; }
.july-ai-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.05) 48%, transparent 100%); transform: translateX(-120%); animation: julyAiCardShine 7s linear infinite; pointer-events: none; }
.july-ai-card__head { position: relative; z-index: 2; display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.july-ai-card__head small { display: block; margin-bottom: 4px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-ai-card__head strong { display: block; color: #fff; font-size: 16px; line-height: 1.35; font-weight: 600; }
.july-ai-score { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; min-width: 52px; height: 32px; padding: 0 12px; border-radius: 999px; background: linear-gradient(90deg, #67b1ff, #b592ff); color: #fff; font-size: 12px; font-weight: 600; box-shadow: 0 10px 22px rgba(120,146,255,.18); animation: julyAiBadgePulse 2.9s ease-in-out infinite; }
/* insta */
.july-ai-stat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 14px; }
.july-ai-stat { padding: 12px; border-radius: 16px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.06); }
.july-ai-stat span { display: block; margin-bottom: 6px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 800; }
.july-ai-stat strong { display: block; color: #fff; font-size: 18px; font-weight: 600; }
.july-ai-stat strong.is-accent { color: #ff95d1; }
.july-ai-feed-list { display: grid; gap: 10px; margin-bottom: 14px; }
.july-ai-feed-item { display: grid; grid-template-columns: 54px minmax(0,1fr) auto; gap: 10px; align-items: center; padding: 10px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.06); animation: julyAiFeedFloat 5.4s ease-in-out infinite; }
.july-ai-feed-item--2 { animation-delay: .45s; }
.july-ai-feed-item--3 { animation-delay: .9s; }
.july-ai-feed-item .thumb { width: 54px; height: 54px; border-radius: 16px; background: radial-gradient(circle at 50% 28%, rgba(255,255,255,.78), transparent 13%), radial-gradient(circle at 50% 82%, rgba(255,255,255,.58), transparent 24%), linear-gradient(135deg, #f9d9e6, #d1ebff); }
.july-ai-feed-item .meta strong { display: block; color: #fff; font-size: 12px; font-weight: 600; }
.july-ai-feed-item .meta span { display: block; margin-top: 4px; color: rgba(255,255,255,.6); font-size: 10px; font-weight: 700; }
.july-ai-feed-item em { display: inline-flex; align-items: center; justify-content: center; min-width: 54px; height: 26px; padding: 0 8px; border-radius: 999px; background: rgba(255,255,255,.08); color: #fff; font-size: 9px; font-style: normal; font-weight: 600; }
.july-ai-feed-item--1 em { background: rgba(255, 84, 147, .18); color: #ff9ec9; }
.july-ai-guide-box { padding: 14px; border-radius: 18px; background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(182,146,255,.09)); border: 1px solid rgba(255,255,255,.06); }
.july-ai-guide-box small { display: block; margin-bottom: 6px; color: #9eb8ff; font-size: 10px; font-weight: 600; }
.july-ai-guide-box strong { display: block; color: #fff; font-size: 18px; line-height: 1.34; font-weight: 600; }
.july-ai-guide-box p { margin: 8px 0 0; color: rgba(255,255,255,.68); font-size: 12px; line-height: 1.6; font-weight: 700; }
/* place */
.july-ai-place-summary { margin-bottom: 14px; padding: 14px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.06); }
.july-ai-place-summary__badge { display: inline-flex; align-items: center; min-height: 28px; padding: 0 11px; border-radius: 999px; background: rgba(103,177,255,.13); color: #bfe1ff; font-size: 11px; font-weight: 600; margin-bottom: 12px; }
.july-ai-place-summary__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.july-ai-place-summary__grid div { padding: 10px; border-radius: 14px; background: rgba(255,255,255,.04); }
.july-ai-place-summary__grid span { display: block; margin-bottom: 6px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 800; }
.july-ai-place-summary__grid strong { display: block; color: #fff; font-size: 18px; font-weight: 600; }
.july-ai-keyword-box__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.july-ai-keyword-box__tags span { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: rgba(255,255,255,.06); color: #d7dfff; font-size: 10px; font-weight: 600; }
.july-ai-keyword-rank { padding: 14px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.06); }
.july-ai-keyword-rank__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.july-ai-keyword-rank__head strong { color: #fff; font-size: 16px; font-weight: 600; }
.july-ai-keyword-rank__head em { display: inline-flex; align-items: center; justify-content: center; min-width: 46px; height: 28px; padding: 0 10px; border-radius: 999px; background: linear-gradient(90deg, #8ca8ff, #bd9cff); color: #fff; font-size: 11px; font-style: normal; font-weight: 600; }
.july-ai-keyword-rank ol { display: grid; gap: 8px; list-style: none; padding: 0; margin: 0; }
.july-ai-keyword-rank li { display: grid; grid-template-columns: 26px minmax(0,1fr); gap: 10px; align-items: center; min-height: 40px; padding: 0 10px; border-radius: 14px; background: rgba(255,255,255,.04); animation: julyAiRankPulse 5.2s ease-in-out infinite; }
.july-ai-keyword-rank li:nth-child(2) { animation-delay: .35s; }
.july-ai-keyword-rank li:nth-child(3) { animation-delay: .7s; }
.july-ai-keyword-rank li:nth-child(4) { animation-delay: 1.05s; }
.july-ai-keyword-rank li:nth-child(5) { animation-delay: 1.4s; }
.july-ai-keyword-rank li b { width: 26px; height: 26px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.08); color: #fff; font-size: 10px; font-weight: 600; }
.july-ai-keyword-rank li span { color: rgba(255,255,255,.82); font-size: 12px; line-height: 1.35; font-weight: 800; }
/* trend */
.july-ai-trend-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.july-ai-trend-tabs span { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.72); font-size: 10px; font-weight: 600; }
.july-ai-trend-tabs span.is-on { background: linear-gradient(90deg, rgba(103,177,255,.18), rgba(189,156,255,.18)); color: #fff; }
.july-ai-chart { position: relative; height: 190px; margin-bottom: 14px; padding: 10px 12px 34px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.06); overflow: hidden; }
.july-ai-chart__grid { position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px); background-size: 100% 38px, calc(100% / 6) 100%; opacity: .65; }
.july-ai-chart__line { position: absolute; left: 12px; right: 12px; top: 18px; bottom: 34px; }
.july-ai-chart__line i { position: absolute; width: 10px; height: 10px; margin-left: -5px; margin-top: -5px; border-radius: 50%; box-shadow: 0 0 0 5px rgba(255,255,255,.06); }
.july-ai-chart__line--primary i { background: #72b8ff; }
.july-ai-chart__line--secondary i { background: #c59cff; }
.july-ai-chart__line--primary::before, .july-ai-chart__line--secondary::before { content: ""; position: absolute; inset: 0; border-radius: 18px; opacity: .85; animation: julyAiPathDraw 4.8s ease-in-out infinite; }
.july-ai-chart__line--primary::before { background: linear-gradient(135deg, transparent 0%, transparent 22%, rgba(114,184,255,.22) 22%, rgba(114,184,255,.22) 24%, transparent 24%, transparent 40%, rgba(114,184,255,.22) 40%, rgba(114,184,255,.22) 42%, transparent 42%, transparent 56%, rgba(114,184,255,.22) 56%, rgba(114,184,255,.22) 58%, transparent 58%, transparent 72%, rgba(114,184,255,.22) 72%, rgba(114,184,255,.22) 74%, transparent 74%); }
.july-ai-chart__line--secondary::before { background: linear-gradient(135deg, transparent 0%, transparent 28%, rgba(197,156,255,.16) 28%, rgba(197,156,255,.16) 30%, transparent 30%, transparent 44%, rgba(197,156,255,.16) 44%, rgba(197,156,255,.16) 46%, transparent 46%, transparent 60%, rgba(197,156,255,.16) 60%, rgba(197,156,255,.16) 62%, transparent 62%, transparent 76%, rgba(197,156,255,.16) 76%, rgba(197,156,255,.16) 78%, transparent 78%); }
.july-ai-chart__line--primary i:nth-child(1) { left: 0%; top: 72%; }
.july-ai-chart__line--primary i:nth-child(2) { left: 20%; top: 62%; }
.july-ai-chart__line--primary i:nth-child(3) { left: 40%; top: 58%; }
.july-ai-chart__line--primary i:nth-child(4) { left: 60%; top: 42%; }
.july-ai-chart__line--primary i:nth-child(5) { left: 80%; top: 34%; }
.july-ai-chart__line--primary i:nth-child(6) { left: 100%; top: 24%; }
.july-ai-chart__line--secondary i:nth-child(1) { left: 0%; top: 68%; }
.july-ai-chart__line--secondary i:nth-child(2) { left: 20%; top: 66%; }
.july-ai-chart__line--secondary i:nth-child(3) { left: 40%; top: 62%; }
.july-ai-chart__line--secondary i:nth-child(4) { left: 60%; top: 55%; }
.july-ai-chart__line--secondary i:nth-child(5) { left: 80%; top: 48%; }
.july-ai-chart__line--secondary i:nth-child(6) { left: 100%; top: 40%; }
.july-ai-chart__labels { position: absolute; left: 12px; right: 12px; bottom: 10px; display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; }
.july-ai-chart__labels span { text-align: center; color: rgba(255,255,255,.5); font-size: 10px; font-weight: 800; }
.july-ai-trend-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.july-ai-trend-summary div { padding: 12px; border-radius: 16px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.06); }
.july-ai-trend-summary span { display: block; margin-bottom: 6px; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 800; }
.july-ai-trend-summary strong { display: block; color: #fff; font-size: 16px; font-weight: 600; }
/* weekly */
.july-ai-week-focus { margin-bottom: 14px; padding: 14px; border-radius: 18px; background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(197,156,255,.08)); border: 1px solid rgba(255,255,255,.06); }
.july-ai-week-focus__label { margin-bottom: 10px; color: #d8deff; font-size: 11px; font-weight: 600; }
.july-ai-week-focus__bar { position: relative; height: 12px; margin-bottom: 10px; border-radius: 999px; background: rgba(255,255,255,.07); overflow: hidden; }
.july-ai-week-focus__bar span { display: block; width: 0; height: 100%; border-radius: 999px; background: linear-gradient(90deg, #72b8ff, #c59cff, #ff88c8); animation: julyAiProgressFill 3.2s ease forwards infinite; }
.july-ai-week-focus strong { display: block; color: #fff; font-size: 18px; font-weight: 600; }
.july-ai-task-list { display: grid; gap: 10px; }
.july-ai-task { padding: 13px 14px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.06); animation: julyAiTaskFloat 5.2s ease-in-out infinite; }
.july-ai-task--2 { animation-delay: .45s; }
.july-ai-task--3 { animation-delay: .9s; }
.july-ai-task small { display: block; margin-bottom: 6px; color: #b7c8ff; font-size: 10px; font-weight: 600; }
.july-ai-task strong { display: block; color: #fff; font-size: 15px; line-height: 1.4; font-weight: 600; }
.july-ai-task p { margin: 7px 0 0; color: rgba(255,255,255,.68); font-size: 12px; line-height: 1.6; font-weight: 700; }
.july-ai-report__foot { position: relative; z-index: 2; display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.july-ai-report__pill { display: inline-flex; align-items: center; min-height: 32px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.06); color: rgba(255,255,255,.78); font-size: 11px; font-weight: 600; animation: julyAiPillPulse 4.2s ease-in-out infinite; }
.july-ai-report__pill:nth-child(2) { animation-delay: .25s; }
.july-ai-report__pill:nth-child(3) { animation-delay: .5s; }
.july-ai-report__pill.is-accent { color: #fff; background: linear-gradient(90deg, rgba(103,177,255,.16), rgba(197,156,255,.18)); border-color: rgba(197,156,255,.14); }
/* animations */
@keyframes julyAiCardShine {
  0% { transform: translateX(-120%); }
  100% { transform: translateX(140%); }
}
@keyframes julyAiBadgePulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 10px 22px rgba(120,146,255,.18); }
  50% { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(120,146,255,.28); }
}
@keyframes julyAiFeedFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
@keyframes julyAiRankPulse {
  0%, 100% { background: rgba(255,255,255,.04); }
  50% { background: rgba(255,255,255,.08); }
}
@keyframes julyAiPathDraw {
  0%, 100% { opacity: .4; transform: translateX(-3px); }
  50% { opacity: .9; transform: translateX(3px); }
}
@keyframes julyAiProgressFill {
  0% { width: 0; }
  50% { width: 65%; }
  100% { width: 65%; }
}
@keyframes julyAiTaskFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
@keyframes julyAiPillPulse {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1px); }
}
/* responsive */
@media (max-width:1200px) {
  .july-ai-report__grid { grid-template-columns: 1fr; }
  .july-ai-report { min-height: auto; }
}
@media (max-width:768px) {
  .july-ai-report { padding: 24px 16px 18px; }
  .july-ai-report__head { display: block; }
  .july-ai-report__head > span { margin-top: 10px; }
  .july-ai-stat-row, .july-ai-place-summary__grid, .july-ai-trend-summary { grid-template-columns: 1fr; }
  .july-ai-feed-item { grid-template-columns: 48px minmax(0,1fr); }
  .july-ai-feed-item em { grid-column: 1 / -1; justify-self: start; }
}
@media (max-width:640px) {
  .july-ai-keyword-rank li { grid-template-columns: 24px minmax(0,1fr); }
  .july-ai-report__foot { flex-direction: column; }
}
.review-avatar--image { overflow: hidden; background: rgba(255, 255, 255, .08); border: 1px solid rgba(255, 255, 255, .12); box-shadow: 0 10px 24px rgba(15, 22, 48, .12); }
.review-avatar--image img { display: block; width: 100%; height: 100%; object-fit: cover; }
.review-avatar--image::after { content: ""; position: absolute; inset: 0; border-radius: inherit; box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18); pointer-events: none; }
/* =========================
   EFFECT BLOCK - ALIMTALK AUTOMATION
========================= */

.july-effect__screen--alimtalk { overflow: hidden; background: radial-gradient(circle at 14% 16%, rgba(255, 232, 18, .16), transparent 24%), radial-gradient(circle at 82% 18%, rgba(119, 201, 255, .14), transparent 26%), linear-gradient(135deg, #0d1427 0%, #111b35 48%, #090f20 100%) !important; border: 1px solid rgba(255,255,255,.09); box-shadow: 0 24px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.july-effect__screen--alimtalk .july-effect__viewport, .july-effect__screen--alimtalk .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-alimtalk-flow { position: relative; min-height: 640px; padding: 34px 28px 24px; color: #fff; overflow: hidden; }
.july-alimtalk-flow::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 24px 24px; opacity: .55; pointer-events: none; }
.july-alimtalk-flow__head { position: relative; z-index: 3; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 24px; }
.july-alimtalk-flow__head small { display: block; margin-bottom: 5px; color: #ffe812; font-size: 11px; font-weight: 600; letter-spacing: .09em; }
.july-alimtalk-flow__head strong { display: block; color: #fff; font-size: 22px; line-height: 1.24; letter-spacing: -.04em; font-weight: 300; }
.july-alimtalk-flow__head > span { display: inline-flex; align-items: center; justify-content: center; min-width: 56px; height: 32px; border-radius: 999px; background: rgba(255, 232, 18, .14); border: 1px solid rgba(255, 232, 18, .28); color: #ffe812; font-size: 11px; font-weight: 600; }
.july-alimtalk-flow__body { position: relative; z-index: 3; display: grid; grid-template-columns: 1fr 64px 1.05fr; align-items: center; gap: 14px; }
.july-alimtalk-form { position: relative; border-radius: 24px; padding: 18px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); box-shadow: 0 18px 44px rgba(0,0,0,.18); animation: julyAlimtalkFormPulse 4.8s ease-in-out infinite; }
.july-alimtalk-form__top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.july-alimtalk-form__top span { color: rgba(255,255,255,.74); font-size: 12px; font-weight: 800; }
.july-alimtalk-form__top b { display: inline-flex; align-items: center; height: 26px; padding: 0 10px; border-radius: 999px; background: rgba(119,201,255,.14); color: #9bd7ff; font-size: 11px; font-weight: 600; }
.july-alimtalk-field { margin-top: 10px; padding: 12px 13px; border-radius: 16px; background: rgba(255,255,255,.92); color: #101827; transform: translateY(10px); opacity: .58; animation: julyAlimtalkFieldIn 4.8s ease-in-out infinite; }
.july-alimtalk-field:nth-child(3) { animation-delay: .25s; }
.july-alimtalk-field:nth-child(4) { animation-delay: .5s; }
.july-alimtalk-field small { display: block; margin-bottom: 4px; color: #7b8498; font-size: 10px; font-weight: 600; }
.july-alimtalk-field strong { display: block; color: #111827; font-size: 14px; font-weight: 600; }
.july-alimtalk-save { margin-top: 14px; height: 42px; border-radius: 999px; display: flex; align-items: center; justify-content: center; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); color: #0b1224; font-size: 13px; font-weight: 600; box-shadow: 0 12px 26px rgba(119,201,255,.18); animation: julyAlimtalkSaveClick 4.8s ease-in-out infinite; }
.july-alimtalk-arrow { position: relative; height: 160px; }
.july-alimtalk-arrow::before { content: ""; position: absolute; left: 50%; top: 12px; bottom: 12px; width: 2px; transform: translateX(-50%); background: linear-gradient(180deg, rgba(255,232,18,0), rgba(255,232,18,.9), rgba(119,201,255,0)); opacity: .7; }
.july-alimtalk-arrow i { position: absolute; left: 50%; top: 22px; width: 12px; height: 12px; border-radius: 50%; transform: translateX(-50%); background: #ffe812; box-shadow: 0 0 0 8px rgba(255,232,18,.12); animation: julyAlimtalkSendDot 2.6s linear infinite; }
.july-alimtalk-arrow i:nth-child(2) { animation-delay: .45s; }
.july-alimtalk-arrow i:nth-child(3) { animation-delay: .9s; }
.july-alimtalk-phone { position: relative; padding: 12px; border-radius: 28px; background: #1f1f1f; box-shadow: 0 22px 52px rgba(0,0,0,.28); }
.july-alimtalk-phone__bar { display: flex; align-items: center; height: 30px; padding: 0 12px; border-radius: 16px 16px 0 0; background: #ffe812; color: #3a3000; font-size: 11px; font-weight: 600; }
.july-alimtalk-chat { position: relative; min-height: 328px; padding: 14px; border-radius: 0 0 20px 20px; background: #b9d3e8; overflow: hidden; }
.july-alimtalk-bubble { position: absolute; left: 14px; right: 14px; padding: 13px 13px 12px; border-radius: 16px; background: #fff; color: #111827; box-shadow: 0 12px 26px rgba(15,22,48,.12); opacity: 0; transform: translateY(18px) scale(.98); animation: julyAlimtalkBubbleStack 7.2s ease-in-out infinite; }
.july-alimtalk-bubble--confirm { top: 14px; animation-delay: .3s; }
.july-alimtalk-bubble--day { top: 142px; animation-delay: 1.75s; }
.july-alimtalk-bubble--hour { top: 230px; animation-delay: 3.15s; }
.july-alimtalk-bubble em { display: block; margin-bottom: 5px; color: #9ca3af; font-size: 10px; font-style: normal; font-weight: 600; }
.july-alimtalk-bubble strong { display: block; color: #111827; font-size: 13px; line-height: 1.35; font-weight: 600; letter-spacing: -.03em; }
.july-alimtalk-bubble p { margin: 8px 0 0; color: #4b5563; font-size: 10px; line-height: 1.55; font-weight: 700; }
.july-alimtalk-bubble span { display: flex; align-items: center; justify-content: center; height: 28px; margin-top: 10px; border-radius: 10px; background: #f3f4f6; color: #111827; font-size: 10px; font-weight: 600; }
.july-alimtalk-timeline { position: relative; z-index: 3; display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 22px; }
.july-alimtalk-step { position: relative; min-height: 88px; padding: 14px 12px; border-radius: 18px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.10); text-align: center; opacity: .55; transform: translateY(8px); animation: julyAlimtalkStepActive 7.2s ease-in-out infinite; }
.july-alimtalk-step--1 { animation-delay: .4s; }
.july-alimtalk-step--2 { animation-delay: 1.8s; }
.july-alimtalk-step--3 { animation-delay: 3.2s; }
.july-alimtalk-step span { display: block; width: 12px; height: 12px; margin: 0 auto 9px; border-radius: 50%; background: #ffe812; box-shadow: 0 0 0 7px rgba(255,232,18,.10); }
.july-alimtalk-step b { display: block; color: #fff; font-size: 13px; font-weight: 600; }
.july-alimtalk-step small { display: block; margin-top: 4px; color: rgba(255,255,255,.62); font-size: 10px; font-weight: 800; }
@keyframes julyAlimtalkFormPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 18px 44px rgba(0,0,0,.18); }
  50% { transform: translateY(-4px); box-shadow: 0 24px 56px rgba(119,201,255,.12); }
}
@keyframes julyAlimtalkFieldIn {
  0%, 15% { opacity: .48; transform: translateY(10px); }
  30%, 78% { opacity: 1; transform: translateY(0); }
  100% { opacity: .58; transform: translateY(10px); }
}
@keyframes julyAlimtalkSaveClick {
  0%, 30%, 100% { transform: scale(1); }
  38% { transform: scale(.96); }
  46%, 76% { transform: scale(1); box-shadow: 0 0 0 8px rgba(119,201,255,.10); }
}
@keyframes julyAlimtalkSendDot {
  0% { top: 20px; opacity: 0; transform: translateX(-50%) scale(.6); }
  12% { opacity: 1; }
  70% { opacity: 1; }
  100% { top: 132px; opacity: 0; transform: translateX(-50%) scale(1.2); }
}
@keyframes julyAlimtalkBubbleStack {
  0%, 8% { opacity: 0; transform: translateY(18px) scale(.98); }
  16%, 72% { opacity: 1; transform: translateY(0) scale(1); }
  88%, 100% { opacity: .78; transform: translateY(0) scale(.995); }
}
@keyframes julyAlimtalkStepActive {
  0%, 12% { opacity: .46; transform: translateY(8px); }
  22%, 64% { opacity: 1; transform: translateY(0); border-color: rgba(255,232,18,.32); background: rgba(255,232,18,.09); }
  100% { opacity: .55; transform: translateY(8px); }
}
@media (max-width:1024px) {
  .july-alimtalk-flow { min-height: 680px; padding: 28px 20px 22px; }
  .july-alimtalk-flow__body { grid-template-columns: 1fr; gap: 14px; }
  .july-alimtalk-arrow { height: 42px; }
  .july-alimtalk-arrow::before { left: 12px; right: 12px; top: 50%; bottom: auto; width: auto; height: 2px; transform: translateY(-50%); background: linear-gradient(90deg, rgba(255,232,18,0), rgba(255,232,18,.9), rgba(119,201,255,0)); }
  .july-alimtalk-arrow i { left: 14px; top: 50%; animation-name: julyAlimtalkSendDotMobile; }
  .july-alimtalk-timeline { grid-template-columns: 1fr; }
}
@keyframes julyAlimtalkSendDotMobile {
  0% { left: 20px; opacity: 0; transform: translateY(-50%) scale(.6); }
  12% { opacity: 1; }
  70% { opacity: 1; }
  100% { left: calc(100% - 20px); opacity: 0; transform: translateY(-50%) scale(1.2); }
}
@media (max-width:640px) {
  .july-alimtalk-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-alimtalk-flow__head { display: block; }
  .july-alimtalk-flow__head > span { margin-top: 10px; }
  .july-alimtalk-chat { min-height: 348px; }
  .july-alimtalk-bubble--confirm { top: 14px; }
  .july-alimtalk-bubble--day { top: 156px; }
  .july-alimtalk-bubble--hour { top: 246px; }
}
/* HERO - AI assistant selling card */
.july-hero-ai-card { width: min(100%, 520px); margin-top: 28px; padding: 18px; border-radius: 26px; border: 1px solid rgba(255,255,255,0.12); background: radial-gradient(circle at 20% 0%, rgba(103,199,255,0.18), transparent 35%), linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.045) 100%); box-shadow: 0 22px 55px rgba(0,0,0,0.22); backdrop-filter: blur(16px); }
.july-hero-ai-card__head { display: flex; align-items: center; gap: 13px; margin-bottom: 15px; }
.july-hero-ai-card__avatar { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 46px; width: 46px; height: 46px; border-radius: 16px; background: linear-gradient(135deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 14px; font-weight: 600; box-shadow: 0 12px 28px rgba(103,199,255,0.22); }
.july-hero-ai-card__head strong { display: block; color: #fff; font-size: 17px; line-height: 1.25; font-weight: 800; letter-spacing: -0.03em; }
.july-hero-ai-card__head p { margin: 4px 0 0; color: rgba(255,255,255,0.68); font-size: 13px; line-height: 1.45; font-weight: 500; letter-spacing: -0.02em; word-break: keep-all; }
.july-hero-ai-card__body { display: grid; gap: 9px; }
.july-hero-ai-card__bubble { width: fit-content; max-width: 92%; padding: 12px 14px; border-radius: 17px; font-size: 14px; line-height: 1.55; font-weight: 600; letter-spacing: -0.02em; word-break: keep-all; }
.july-hero-ai-card__bubble--user { margin-left: auto; background: rgba(255,255,255,0.92); color: #101828; border-bottom-right-radius: 6px; }
.july-hero-ai-card__bubble--ai { background: rgba(10, 16, 35, 0.72); color: rgba(255,255,255,0.9); border: 1px solid rgba(255,255,255,0.08); border-bottom-left-radius: 6px; }
.july-hero-ai-card__tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 14px; }
.july-hero-ai-card__tags span { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.08); color: rgba(255,255,255,0.74); font-size: 12px; font-weight: 700; letter-spacing: -0.02em; }
@media (max-width:1024px) {
  .july-hero-ai-card { margin-left: auto; margin-right: auto; }
}
@media (max-width:768px) {
  .july-hero-ai-card { margin-top: 22px; padding: 15px; border-radius: 22px; }
  .july-hero-ai-card__head { align-items: flex-start; }
  .july-hero-ai-card__avatar { flex-basis: 42px; width: 42px; height: 42px; border-radius: 14px; }
  .july-hero-ai-card__head strong { font-size: 15px; }
  .july-hero-ai-card__head p { font-size: 12px; }
  .july-hero-ai-card__bubble { max-width: 100%; font-size: 13px; }
  .july-hero-ai-card__tags span { font-size: 11px; }
}
/* =========================
   AI SECRETARY SECTION
========================= */
.july-ai-secretary-section { position: relative; overflow: hidden; padding: 110px 0 120px; background: radial-gradient(circle at 16% 18%, rgba(103, 199, 255, 0.16), transparent 28%), radial-gradient(circle at 86% 20%, rgba(221, 143, 203, 0.13), transparent 28%), radial-gradient(circle at 50% 90%, rgba(138, 125, 255, 0.12), transparent 32%), linear-gradient(180deg, #080c1c 0%, #0b1022 52%, #090d1d 100%); color: #fff; border-top: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.july-ai-secretary-section::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,0.018) 1px, transparent 1px); background-size: 32px 32px; opacity: .8; pointer-events: none; }
.july-ai-secretary-section::after { content: ""; position: absolute; left: 50%; top: 50%; width: 860px; height: 860px; transform: translate(-50%, -50%); border-radius: 999px; background: rgba(119, 201, 255, 0.045); filter: blur(120px); pointer-events: none; }
.july-ai-secretary-bg { position: absolute; inset: 0; z-index: 1; overflow: hidden; pointer-events: none; }
.july-ai-secretary-bg span { position: absolute; color: rgba(141, 185, 255, 0.13); font-size: 14px; font-weight: 600; white-space: nowrap; animation: julySecretaryCodeFloat 17s linear infinite; }
.july-ai-secretary-bg span:nth-child(1) { top: 10%; left: 8%; animation-duration: 18s; }
.july-ai-secretary-bg span:nth-child(2) { top: 22%; right: 9%; animation-duration: 16s; }
.july-ai-secretary-bg span:nth-child(3) { top: 62%; left: 5%; animation-duration: 19s; }
.july-ai-secretary-bg span:nth-child(4) { bottom: 16%; right: 12%; animation-duration: 17s; }
.july-ai-secretary-bg span:nth-child(5) { bottom: 8%; left: 26%; animation-duration: 20s; }
.july-ai-secretary-bg span:nth-child(6) { top: 44%; right: 28%; animation-duration: 21s; }
@keyframes julySecretaryCodeFloat {
  0% { transform: translateY(28px); opacity: 0; }
  15% { opacity: 1; }
  55% { opacity: .78; }
  100% { transform: translateY(-34px); opacity: 0; }
}
.july-ai-secretary-inner { position: relative; z-index: 3; width: 100%; max-width: 1600px; margin: 0 auto; padding: 0 56px; }
.july-ai-secretary-head { max-width: 1180px; margin: 0 auto 54px; text-align: center; }
.july-ai-secretary-eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; margin-bottom: 20px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.06); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; backdrop-filter: blur(8px); }
.july-ai-secretary-title { margin: 0; color: #fff; font-size: clamp(52px, 5.2vw, 52px); line-height: 1.08; letter-spacing: -0.065em; font-weight: 300; word-break: keep-all; }
.july-ai-secretary-title span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-ai-secretary-desc { margin: 26px auto 0; max-width: 940px; color: rgba(255,255,255,0.76); font-size: 20px; line-height: 1.78; font-weight: 500; letter-spacing: -0.03em; word-break: keep-all; }
.july-ai-secretary-duo { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; align-items: stretch; }
.july-ai-secretary-chatbox { position: relative; overflow: hidden; min-height: 670px; padding: 20px; border-radius: 34px; border: 1px solid rgba(255,255,255,0.13); background: linear-gradient(180deg, rgba(255,255,255,0.11) 0%, rgba(255,255,255,0.045) 100%), rgba(5, 8, 22, 0.82); box-shadow: 0 32px 90px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.10); backdrop-filter: blur(18px); }
.july-ai-secretary-chatbox::before { content: ""; position: absolute; inset: -1px; pointer-events: none; opacity: .65; }
.july-ai-secretary-chatbox--operation::before { background: radial-gradient(circle at 12% 0%, rgba(103,199,255,0.20), transparent 34%); }
.july-ai-secretary-chatbox--marketing::before { background: radial-gradient(circle at 88% 0%, rgba(221,143,203,0.20), transparent 34%); }
.july-ai-secretary-chatbox__top { position: relative; z-index: 2; display: flex; align-items: center; gap: 12px; min-height: 56px; padding: 0 4px 14px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.july-ai-secretary-status { flex: 0 0 11px; width: 11px; height: 11px; border-radius: 50%; background: #67c7ff; box-shadow: 0 0 16px rgba(103,199,255,0.7); }
.july-ai-secretary-chatbox__top strong { display: block; color: #fff; font-size: 18px; font-weight: 600; letter-spacing: -0.03em; }
.july-ai-secretary-chatbox__top em { display: block; margin-top: 3px; color: rgba(255,255,255,0.58); font-size: 12px; line-height: 1.3; font-style: normal; font-weight: 700; letter-spacing: -0.02em; }
.july-ai-secretary-chatbox__top b { margin-left: auto; min-height: 28px; padding: 0 11px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: rgba(34,160,107,0.14); color: #60e6a6; font-size: 11px; font-weight: 600; }
.july-ai-secretary-chat { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 13px; min-height: 480px; padding: 24px 2px 18px; }
.july-ai-secretary-message { width: fit-content; max-width: 88%; padding: 13px 15px; border-radius: 18px; font-size: 14px; line-height: 1.62; font-weight: 650; letter-spacing: -0.02em; word-break: keep-all; overflow-wrap: break-word; opacity: 0; transform: translateY(16px); animation: julySecretaryMessageLoop 12s ease-in-out infinite; }
.july-ai-secretary-message--ai { align-self: flex-start; background: rgba(255,255,255,0.94); color: #101828; border-bottom-left-radius: 6px; }
.july-ai-secretary-message--user { align-self: flex-end; background: #0f1630; color: #fff; border: 1px solid rgba(255,255,255,0.10); border-bottom-right-radius: 6px; }
.july-ai-secretary-message--op1 { animation-delay: .2s; }
.july-ai-secretary-message--op2 { animation-delay: 1.6s; }
.july-ai-secretary-message--op3 { animation-delay: 3.2s; }
.july-ai-secretary-message--op4 { animation-delay: 4.6s; }
.july-ai-secretary-message--op5 { animation-delay: 6.2s; }
.july-ai-secretary-message--op6 { animation-delay: 7.6s; }
.july-ai-secretary-message--mk1 { animation-delay: .9s; }
.july-ai-secretary-message--mk2 { animation-delay: 2.3s; }
.july-ai-secretary-message--mk3 { animation-delay: 3.9s; }
.july-ai-secretary-message--mk4 { animation-delay: 5.3s; }
.july-ai-secretary-message--mk5 { animation-delay: 6.9s; }
.july-ai-secretary-message--mk6 { animation-delay: 8.3s; }
@keyframes julySecretaryMessageLoop {
  0% { opacity: 0; transform: translateY(16px); }
  8% { opacity: 1; transform: translateY(0); }
  72% { opacity: 1; transform: translateY(0); }
  90% { opacity: 0; transform: translateY(-10px); }
  100% { opacity: 0; transform: translateY(-10px); }
}
.july-ai-secretary-input { position: relative; z-index: 2; display: flex; align-items: center; gap: 10px; min-height: 58px; padding: 8px 8px 8px 16px; border-radius: 20px; background: rgba(255,255,255,0.95); }
.july-ai-secretary-input span { flex: 1; color: #8b94a9; font-size: 13px; font-weight: 600; }
.july-ai-secretary-input button { flex: 0 0 auto; min-width: 74px; height: 42px; border: 0; border-radius: 14px; background: #0f1630; color: #fff; font-size: 13px; font-weight: 600; }
.july-ai-secretary-bottom { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-top: 30px; padding: 22px 24px; border-radius: 26px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.055); backdrop-filter: blur(14px); }
.july-ai-secretary-bottom b { display: block; margin-bottom: 6px; color: #8db9ff; font-size: 12px; font-weight: 600; letter-spacing: .08em; }
.july-ai-secretary-bottom span { display: block; color: rgba(255,255,255,0.82); font-size: 16px; line-height: 1.65; font-weight: 600; letter-spacing: -0.02em; word-break: keep-all; }
.july-ai-secretary-bottom a { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; min-width: 220px; height: 56px; padding: 0 24px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f !important; text-decoration: none; font-size: 16px; font-weight: 600; box-shadow: 0 14px 32px rgba(115,126,255,0.22); transition: .25s ease; }
.july-ai-secretary-bottom a:hover { transform: translateY(-2px); color: #08111f !important; text-decoration: none; }
@media (max-width:1280px) {
  .july-ai-secretary-inner { padding: 0 28px; }
  .july-ai-secretary-duo { gap: 20px; }
  .july-ai-secretary-chatbox { min-height: 680px; }
  .july-ai-secretary-message { font-size: 13px; }
}
@media (max-width:1024px) {
  .july-ai-secretary-section { padding: 96px 0 104px; }
  .july-ai-secretary-head { margin-bottom: 40px; }
  .july-ai-secretary-duo { grid-template-columns: 1fr; max-width: 720px; margin: 0 auto; }
  .july-ai-secretary-chatbox { min-height: 620px; }
  .july-ai-secretary-bottom { max-width: 720px; margin-left: auto; margin-right: auto; }
}
@media (max-width:768px) {
  .july-ai-secretary-section { padding: 82px 0 90px; }
  .july-ai-secretary-inner { padding: 0 18px; }
  .july-ai-secretary-head { margin-bottom: 30px; }
  .july-ai-secretary-eyebrow { font-size: 11px; margin-bottom: 15px; }
  .july-ai-secretary-title { font-size: clamp(30px, 8vw, 42px); line-height: 1.1; }
  .july-ai-secretary-desc { margin-top: 18px; font-size: 15.5px; line-height: 1.72; }
  .july-ai-secretary-duo { gap: 16px; }
  .july-ai-secretary-chatbox { min-height: 640px; padding: 15px; border-radius: 28px; }
  .july-ai-secretary-chatbox__top { min-height: 52px; }
  .july-ai-secretary-chatbox__top strong { font-size: 16px; }
  .july-ai-secretary-chatbox__top em { font-size: 11px; }
  .july-ai-secretary-chat { min-height: 500px; gap: 10px; padding: 18px 0 14px; }
  .july-ai-secretary-message { max-width: 94%; padding: 11px 12px; font-size: 12.5px; line-height: 1.58; }
  .july-ai-secretary-input { min-height: 52px; padding: 7px 7px 7px 13px; border-radius: 17px; }
  .july-ai-secretary-input button { min-width: 62px; height: 38px; border-radius: 13px; font-size: 12px; }
  .july-ai-secretary-bottom { display: block; padding: 20px; text-align: center; }
  .july-ai-secretary-bottom span { font-size: 14px; }
  .july-ai-secretary-bottom a { width: 100%; min-width: 0; height: 52px; margin-top: 16px; font-size: 15px; }
}
@media (max-width:480px) {
  .july-ai-secretary-inner { padding-left: 15px; padding-right: 15px; }
  .july-ai-secretary-chatbox { min-height: 660px; }
  .july-ai-secretary-chat { min-height: 520px; }
}
/* AI Secretary bottom premium card */
.july-ai-secretary-bottom--premium { position: relative; overflow: hidden; align-items: center; padding: 30px 32px; border-radius: 30px; background: radial-gradient(circle at 14% 0%, rgba(103,199,255,0.18), transparent 34%), radial-gradient(circle at 88% 30%, rgba(221,143,203,0.15), transparent 32%), linear-gradient(180deg, rgba(255,255,255,0.075) 0%, rgba(255,255,255,0.045) 100%); box-shadow: 0 24px 70px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.08); }
.july-ai-secretary-bottom--premium::before { content: ""; position: absolute; inset: 1px; border-radius: 29px; border: 1px solid rgba(255,255,255,0.06); pointer-events: none; }
.july-ai-secretary-bottom__content { position: relative; z-index: 2; min-width: 0; }
.july-ai-secretary-bottom__label { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 13px; color: #8db9ff; font-size: 13px; font-weight: 600; letter-spacing: -0.02em; }
.july-ai-secretary-bottom__label span { display: inline-flex; align-items: center; justify-content: center; min-height: 24px; padding: 0 9px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 10px; font-weight: 600; letter-spacing: .06em; }
.july-ai-secretary-bottom--premium h3 { margin: 0; color: #fff; font-size: clamp(22px, 2.1vw, 34px); line-height: 1.32; font-weight: 300; letter-spacing: -0.045em; word-break: keep-all; }
.july-ai-secretary-bottom--premium h3 span { background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-ai-secretary-bottom--premium p { max-width: 920px; margin: 15px 0 0; color: rgba(255,255,255,0.72); font-size: 16px; line-height: 1.75; font-weight: 600; letter-spacing: -0.02em; word-break: keep-all; }
.july-ai-secretary-bottom__chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.july-ai-secretary-bottom__chips span { display: inline-flex; align-items: center; justify-content: center; min-height: 32px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.09); color: rgba(255,255,255,0.82); font-size: 12px; font-weight: 800; letter-spacing: -0.02em; }
.july-ai-secretary-bottom__action { position: relative; z-index: 2; flex: 0 0 280px; text-align: center; }
.july-ai-secretary-bottom__action a { width: 100%; min-width: 0; }
.july-ai-secretary-bottom__action small { display: block; margin-top: 10px; color: rgba(255,255,255,0.48); font-size: 12px; line-height: 1.45; font-weight: 600; word-break: keep-all; }
.july-ai-secretary-bottom--premium p strong { color: #fff; font-weight: 600; }
@media (max-width:1024px) {
  .july-ai-secretary-bottom--premium { display: block; max-width: 720px; padding: 26px 24px; }
  .july-ai-secretary-bottom__content { text-align: left; }
  .july-ai-secretary-bottom__action { flex: none; width: 100%; margin-top: 22px; }
}
@media (max-width:768px) {
  .july-ai-secretary-bottom--premium { padding: 24px 20px; border-radius: 26px; }
  .july-ai-secretary-bottom--premium h3 { font-size: 23px; line-height: 1.38; }
  .july-ai-secretary-bottom--premium p { font-size: 14px; line-height: 1.7; }
  .july-ai-secretary-bottom__chips { gap: 6px; }
  .july-ai-secretary-bottom__chips span { min-height: 30px; padding: 0 10px; font-size: 11px; }
}
/* =========================
   EFFECT BLOCK - LIVE CAPTURE FIX
========================= */
.july-effect__screen--live-capture { overflow: hidden; background: radial-gradient(circle at 18% 0%, rgba(103,199,255,0.16), transparent 34%), radial-gradient(circle at 92% 20%, rgba(221,143,203,0.14), transparent 36%), linear-gradient(180deg, #0b1022 0%, #10172c 100%) !important; }
.july-effect__screen--live-capture .july-effect__viewport, .july-effect__screen--live-capture .july-effect__screen-inner { height: 100%; background: transparent !important; overflow: hidden; }
.july-live-capture-flow { position: relative; min-height: 620px; height: 100%; padding: 28px; color: #fff; overflow: hidden; }
.july-live-capture-flow__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 22px; }
.july-live-capture-flow__head small { display: block; margin-bottom: 7px; color: #8db9ff; font-size: 11px; font-weight: 600; letter-spacing: .08em; }
.july-live-capture-flow__head strong { display: block; color: #fff; font-size: 20px; line-height: 1.28; font-weight: 600; letter-spacing: -0.04em; }
.july-live-capture-flow__head > span { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; min-height: 30px; padding: 0 11px; border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.82); font-size: 11px; font-weight: 600; }
.july-live-capture-flow__stage { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) 112px minmax(0, .95fr); gap: 14px; align-items: center; }
.july-live-capture-source { position: relative; min-height: 374px; }
.july-live-capture-source__tabs { display: flex; gap: 8px; margin-bottom: 10px; }
.july-live-capture-source__tabs span { display: inline-flex; align-items: center; justify-content: center; min-height: 30px; padding: 0 11px; border-radius: 999px; background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.72); font-size: 11px; font-weight: 600; }
.july-live-capture-source__tabs span.is-active { background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; }
.july-live-capture-browser { position: absolute; left: 0; right: 0; min-height: 168px; border-radius: 20px; background: rgba(255,255,255,0.96); border: 1px solid rgba(255,255,255,0.18); box-shadow: 0 16px 42px rgba(0,0,0,0.22); overflow: hidden; }
.july-live-capture-browser--naver { top: 42px; z-index: 2; animation: julyLiveBrowserTop 6s ease-in-out infinite; }
.july-live-capture-browser--dm { bottom: 0; z-index: 1; transform: scale(.92) translateY(10px); opacity: .72; animation: julyLiveBrowserBottom 6s ease-in-out infinite; }
.july-live-capture-browser__bar { display: flex; align-items: center; gap: 5px; height: 30px; padding: 0 10px; background: #eef3fb; border-bottom: 1px solid #dde5f1; }
.july-live-capture-browser__bar i { width: 7px; height: 7px; border-radius: 50%; background: #c9d3e3; }
.july-live-capture-browser__bar em { margin-left: 5px; color: #667085; font-size: 10px; font-weight: 800; font-style: normal; }
.july-live-capture-reserve { display: flex; gap: 10px; margin: 14px; padding: 13px; border-radius: 16px; background: #f8fafc; border: 1px solid #e8edf5; }
.july-live-capture-reserve__badge { display: flex; align-items: center; justify-content: center; flex: 0 0 34px; width: 34px; height: 34px; border-radius: 12px; background: #03c75a; color: #fff; font-size: 16px; font-weight: 600; }
.july-live-capture-reserve__body strong { display: block; color: #0f1630; font-size: 14px; font-weight: 600; }
.july-live-capture-reserve__body p { margin: 4px 0; color: #49536b; font-size: 11px; line-height: 1.35; font-weight: 800; }
.july-live-capture-reserve__body span { display: block; color: #8b94a9; font-size: 10px; line-height: 1.35; font-weight: 700; }
.july-live-capture-dm { display: grid; gap: 7px; padding: 12px 14px; }
.july-live-capture-dm__bubble { width: fit-content; max-width: 86%; padding: 8px 10px; border-radius: 13px; background: #f1f4fa; color: #0f1630; font-size: 10.5px; line-height: 1.4; font-weight: 800; }
.july-live-capture-dm__bubble.is-owner { justify-self: end; background: #0f1630; color: #fff; }
.july-live-capture-float-btn { position: absolute; right: 12px; bottom: 12px; height: 34px; padding: 0 13px; border: 0; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 11px; font-weight: 600; box-shadow: 0 10px 24px rgba(103,199,255,0.28); animation: julyLiveCaptureButtonPulse 1.8s ease-in-out infinite; }
.july-live-capture-bridge { position: relative; min-height: 300px; }
.july-live-capture-bridge__core { position: absolute; left: 50%; top: 50%; z-index: 4; width: 78px; height: 78px; transform: translate(-50%, -50%); border-radius: 28px; background: linear-gradient(135deg, #67c7ff 0%, #dd8fcb 100%); box-shadow: 0 18px 40px rgba(103,199,255,0.22); display: flex; align-items: center; justify-content: center; }
.july-live-capture-bridge__core span { color: #08111f; font-size: 21px; font-weight: 600; }
.july-live-capture-bridge__core i { position: absolute; inset: -9px; border-radius: 34px; border: 1px solid rgba(255,255,255,0.22); animation: julyLiveAiRing 1.8s ease-in-out infinite; }
.july-live-capture-bridge__line { position: absolute; left: 6px; right: 6px; top: 50%; height: 2px; transform: translateY(-50%); background: linear-gradient(90deg, rgba(103,199,255,0), rgba(103,199,255,.95), rgba(221,143,203,.95), rgba(221,143,203,0)); opacity: .85; }
.july-live-capture-bridge__line::after { content: ""; position: absolute; left: 0; top: -3px; width: 10px; height: 10px; border-radius: 50%; background: #fff; box-shadow: 0 0 18px rgba(255,255,255,.85); animation: julyLiveDataMove 2.2s linear infinite; }
.july-live-capture-bridge__line--2 { top: 58%; opacity: .45; }
.july-live-capture-bridge__line--2::after { animation-delay: .7s; }
.july-live-capture-chip { position: absolute; left: 50%; transform: translateX(-50%); min-height: 25px; padding: 0 9px; border-radius: 999px; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.86); font-size: 10px; font-weight: 600; white-space: nowrap; opacity: 0; animation: julyLiveChipPop 6s ease-in-out infinite; }
.july-live-capture-chip--1 { top: 58px; animation-delay: .4s; }
.july-live-capture-chip--2 { top: 92px; animation-delay: 1.2s; }
.july-live-capture-chip--3 { bottom: 92px; animation-delay: 2s; }
.july-live-capture-chip--4 { bottom: 58px; animation-delay: 2.8s; }
.july-live-capture-crm { min-height: 374px; padding: 16px; border-radius: 22px; background: rgba(255,255,255,0.96); border: 1px solid rgba(255,255,255,0.18); box-shadow: 0 16px 42px rgba(0,0,0,0.20); }
.july-live-capture-crm__head { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 16px; }
.july-live-capture-crm__head small { display: block; margin-bottom: 5px; color: #8a7dff; font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-live-capture-crm__head strong { display: block; color: #0f1630; font-size: 15px; font-weight: 600; }
.july-live-capture-crm__head span { display: inline-flex; align-items: center; align-self: flex-start; min-height: 26px; padding: 0 9px; border-radius: 999px; background: #ecfdf5; color: #168f63; font-size: 10px; font-weight: 600; }
.july-live-capture-form { display: grid; gap: 10px; }
.july-live-capture-form label { display: block; padding: 10px 12px; border-radius: 14px; background: #f8fafc; border: 1px solid #e8edf5; }
.july-live-capture-form label span { display: block; margin-bottom: 5px; color: #7c8399; font-size: 10px; font-weight: 600; }
.july-live-capture-form label b { display: block; color: #0f1630; font-size: 13px; font-weight: 600; }
.july-live-capture-save { display: flex; align-items: center; justify-content: center; height: 42px; margin-top: 14px; border-radius: 14px; background: #0f1630; color: #fff; font-size: 13px; font-weight: 600; animation: julyLiveSaveReady 3s ease-in-out infinite; }
.july-live-capture-flow__note { margin-top: 16px; padding: 14px 16px; border-radius: 18px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.09); color: rgba(255,255,255,0.82); font-size: 13px; line-height: 1.6; font-weight: 700; word-break: keep-all; }
@keyframes julyLiveBrowserTop {
  0%, 46%, 100% { transform: scale(1) translateY(0); opacity: 1; z-index: 2; }
  50%, 88% { transform: scale(.92) translateY(-4px); opacity: .66; z-index: 1; }
}
@keyframes julyLiveBrowserBottom {
  0%, 46%, 100% { transform: scale(.92) translateY(10px); opacity: .72; z-index: 1; }
  50%, 88% { transform: scale(1) translateY(0); opacity: 1; z-index: 2; }
}
@keyframes julyLiveCaptureButtonPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 10px 24px rgba(103,199,255,0.28); }
  50% { transform: scale(1.05); box-shadow: 0 14px 30px rgba(221,143,203,0.34); }
}
@keyframes julyLiveAiRing {
  0%, 100% { transform: scale(.98); opacity: .5; }
  50% { transform: scale(1.08); opacity: 1; }
}
@keyframes julyLiveDataMove {
  0% { left: 0; opacity: 0; }
  12% { opacity: 1; }
  82% { opacity: 1; }
  100% { left: calc(100% - 10px); opacity: 0; }
}
@keyframes julyLiveChipPop {
  0%, 8% { opacity: 0; transform: translateX(-50%) translateY(8px); }
  14%, 56% { opacity: 1; transform: translateX(-50%) translateY(0); }
  70%, 100% { opacity: 0; transform: translateX(-50%) translateY(-8px); }
}
@keyframes julyLiveSaveReady {
  0%, 100% { background: #0f1630; }
  50% { background: #168f63; }
}
@media (max-width:1280px) {
  .july-live-capture-flow { min-height: 900px; padding: 24px 20px 22px; }
  .july-live-capture-flow__stage { grid-template-columns: 1fr; gap: 18px; }
  .july-live-capture-source, .july-live-capture-crm { min-height: 320px; }
  .july-live-capture-bridge { min-height: 120px; }
  .july-live-capture-bridge__line { left: 15%; right: 15%; }
  .july-live-capture-chip { display: none; }
}
@media (max-width:640px) {
  .july-live-capture-flow { min-height: auto; padding: 24px 16px 18px; }
  .july-live-capture-flow__head { display: block; }
  .july-live-capture-flow__head > span { margin-top: 10px; }
  .july-live-capture-flow__head strong { font-size: 17px; }
  .july-live-capture-source, .july-live-capture-crm { min-height: 300px; }
  .july-live-capture-browser { min-height: 148px; }
  .july-live-capture-reserve { margin: 11px; padding: 11px; }
  .july-live-capture-dm__bubble { font-size: 10px; }
  .july-live-capture-bridge { min-height: 96px; }
  .july-live-capture-bridge__core { width: 66px; height: 66px; border-radius: 22px; }
  .july-live-capture-flow__note { font-size: 12px; }
}
/* =========================
   FINAL CTA - SIMPLE MATCH TYPE
========================= */
.july-fit-cta { position: relative; overflow: hidden; padding: 140px 0 150px; background: radial-gradient(circle at 12% 10%, rgba(103,199,255,0.11), transparent 26%), radial-gradient(circle at 88% 16%, rgba(221,143,203,0.10), transparent 30%), radial-gradient(circle at 50% 100%, rgba(120,130,255,0.08), transparent 30%), linear-gradient(180deg, #060913 0%, #08101f 56%, #050813 100%); color: #fff; }
.july-fit-cta::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,0.018) 1px, transparent 1px); background-size: 32px 32px; pointer-events: none; }
.july-fit-cta .container { position: relative; z-index: 2; max-width: 1600px; padding: 0 56px; }
.july-fit-cta__inner { display: grid; gap: 64px; }
.july-fit-cta__intro { max-width: 1280px; margin: 0 auto; }
.july-fit-cta__eyebrow { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 16px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.05); color: #8db9ff; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; backdrop-filter: blur(8px); }
.july-fit-cta__title { margin: 24px 0 0; color: #fff; font-size: clamp(34px, 4vw, 64px); line-height: 1.08; letter-spacing: -0.065em; font-weight: 300; word-break: keep-all; }
.july-fit-cta__title span { display: block; margin-top: 10px; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-fit-cta__questions { margin: 34px 0 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.july-fit-cta__questions li { position: relative; margin: 0; padding: 0; color: rgba(255,255,255,0.92); font-size: clamp(24px, 3vw, 40px); line-height: 1.52; letter-spacing: -0.055em; font-weight: 300; word-break: keep-all; min-height: 1.52em; }
.july-fit-cta__questions li::before { content: attr(data-text); display: block; visibility: hidden; white-space: normal; word-break: keep-all; pointer-events: none; }
.july-fit-cta__question-text { position: absolute; left: 0; top: 0; right: 0; display: block; white-space: normal; word-break: keep-all; }
.july-fit-cta__summary { margin-top: 36px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.08); }
.july-fit-cta__lead { margin: 0; color: #fff; font-size: clamp(28px, 2.8vw, 42px); line-height: 1.24; letter-spacing: -0.05em; font-weight: 300; word-break: keep-all; }
.july-fit-cta__lead strong { font-weight: 700; }
.july-fit-cta__sub { margin: 14px 0 0; color: rgba(255,255,255,0.76); font-size: 20px; line-height: 1.8; letter-spacing: -0.03em; font-weight: 500; word-break: keep-all; }
.july-fit-cta__industry { margin-top: 28px; padding: 24px 26px; border-radius: 28px; border: 1px solid rgba(255,255,255,0.10); background: radial-gradient(circle at 16% 0%, rgba(103,199,255,0.10), transparent 32%), rgba(255,255,255,0.05); backdrop-filter: blur(12px); }
.july-fit-cta__badge { display: inline-flex; align-items: center; justify-content: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #09111d; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; }
.july-fit-cta__badge--accent { min-height: 32px; padding: 0 14px; font-size: 12px; }
.july-fit-cta__industry p { margin: 14px 0 0; color: rgba(255,255,255,0.84); font-size: 15px; line-height: 1.78; letter-spacing: -0.02em; font-weight: 600; word-break: keep-all; }
.july-fit-cta__gallery { display: grid; gap: 18px; }
.july-fit-cta__gallery-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; max-width: 100%; }
.july-fit-cta__gallery-head p { margin: 0; color: rgba(255,255,255,0.62); font-size: 14px; line-height: 1.5; font-weight: 600; letter-spacing: -0.02em; }
.july-fit-cta__ticker { position: relative; overflow: hidden; mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%); -webkit-mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%); }
.july-fit-cta__ticker-track { display: flex; align-items: stretch; gap: 16px; width: max-content; animation: julyFitTicker 36s linear infinite; }
.july-fit-cta__ticker:hover .july-fit-cta__ticker-track { animation-play-state: paused; }
.july-fit-cta__ticker-item { position: relative; flex: 0 0 auto; width: clamp(150px, 12vw, 184px); aspect-ratio: 560 / 820; border-radius: 24px; overflow: hidden; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); box-shadow: 0 20px 40px rgba(0,0,0,0.18); }
.july-fit-cta__ticker-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,13,28,0.02) 0%, rgba(8,13,28,0.22) 100%); pointer-events: none; }
.july-fit-cta__ticker-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.july-fit-cta__ticker-item:hover img { transform: scale(1.04); }
@keyframes julyFitTicker {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-50% - 8px)); }
}
.july-fit-cta__promise { max-width: 1100px; margin: 0 auto; padding: 38px 40px; border-radius: 34px; border: 1px solid rgba(221,143,203,0.16); background: radial-gradient(circle at 86% 0%, rgba(221,143,203,0.15), transparent 32%), radial-gradient(circle at 12% 100%, rgba(103,199,255,0.12), transparent 34%), rgba(255,255,255,0.06); box-shadow: 0 24px 56px rgba(0,0,0,0.18); text-align: center; }
.july-fit-cta__promise h3 { margin: 18px 0 0; color: #fff; font-size: clamp(30px, 3vw, 52px); line-height: 1.2; letter-spacing: -0.055em; font-weight: 300; word-break: keep-all; }
.july-fit-cta__promise p { margin: 18px 0 0; color: rgba(255,255,255,0.82); font-size: 20px; line-height: 1.8; letter-spacing: -0.03em; font-weight: 600; word-break: keep-all; }
.july-fit-cta__action { display: flex; justify-content: center; }
.july-fit-cta__btn { display: inline-flex; align-items: center; justify-content: center; min-width: 320px; height: 68px; padding: 0 36px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f !important; text-decoration: none !important; font-size: 18px; font-weight: 600; letter-spacing: -0.02em; box-shadow: 0 18px 34px rgba(115,126,255,0.22); transition: transform .25s ease, box-shadow .25s ease; }
.july-fit-cta__btn:hover { transform: translateY(-2px); box-shadow: 0 24px 40px rgba(115,126,255,0.28); }
/* responsive */
@media (max-width:1280px) {
    .july-fit-cta { padding: 120px 0 130px; }
    .july-fit-cta .container { padding: 0 28px; }
    .july-fit-cta__inner { gap: 56px; }
    .july-fit-cta__questions li { font-size: clamp(22px, 3.2vw, 42px); }
    .july-fit-cta__lead { font-size: clamp(25px, 2.6vw, 36px); }
    .july-fit-cta__sub { font-size: 18px; }
    .july-fit-cta__promise p { font-size: 18px; }
}
@media (max-width:768px) {
    .july-fit-cta { padding: 90px 0 100px; }
    .july-fit-cta .container { padding: 0 18px; }
    .july-fit-cta__inner { gap: 40px; }
    .july-fit-cta__eyebrow { min-height: 34px; font-size: 11px; }
    .july-fit-cta__title { margin-top: 18px; font-size: clamp(30px, 8vw, 42px); line-height: 1.12; }
    .july-fit-cta__questions { margin-top: 24px; gap: 8px; }
    .july-fit-cta__questions li { font-size: clamp(18px, 5.4vw, 20px); line-height: 1.54; }
    .july-fit-cta__question-text { line-height: inherit; }
    .july-fit-cta__summary { margin-top: 28px; padding-top: 22px; }
    .july-fit-cta__lead { font-size: clamp(24px, 6.6vw, 32px); line-height: 1.28; }
    .july-fit-cta__sub { font-size: 15px; line-height: 1.72; }
    .july-fit-cta__industry { margin-top: 22px; padding: 18px; border-radius: 22px; }
    .july-fit-cta__industry p { margin-top: 12px; font-size: 13.5px; line-height: 1.72; }
    .july-fit-cta__gallery-head { flex-direction: column; align-items: flex-start; gap: 10px; }
    .july-fit-cta__ticker-track { gap: 12px; animation-duration: 28s; }
    .july-fit-cta__ticker-item { width: clamp(150px, 42vw, 210px); border-radius: 18px; }
    .july-fit-cta__promise { padding: 24px 18px; border-radius: 22px; }
    .july-fit-cta__promise h3 { margin-top: 14px; font-size: clamp(26px, 8vw, 34px); line-height: 1.24; }
    .july-fit-cta__promise p { margin-top: 14px; font-size: 14px; line-height: 1.75; }
    .july-fit-cta__btn { width: 100%; max-width: 60%; height: 58px; font-size: 16px; }
}
@media (max-width:480px) {
    .july-fit-cta .container { padding-left: 15px; padding-right: 15px; }
    .july-fit-cta__ticker-item { width: clamp(148px, 68vw, 220px); }
}

/* 모바일에서는 스크롤 등장 효과 제거 */
@media (max-width: 768px) {
    [data-aos],
    .aos-init,
    .aos-animate,
    .effect-reveal,
    .pricing-reveal,
    .review-reveal,
    .final-cta-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        animation-delay: 0s !important;
    }
}


/* =========================
   JULY LAUNCH EVENT MODAL
========================= */
.july-launch-modal { position: fixed; inset: 0; z-index: 99999; display: none; align-items: center; justify-content: center; padding: 24px 18px; }
.july-launch-modal__backdrop { position: absolute; inset: 0; background: rgba(3, 6, 16, 0.72); backdrop-filter: blur(10px); }
.july-launch-modal__dialog { position: relative; z-index: 2; width: min(680px, calc(100% - 36px)); max-height: calc(100vh - 48px); margin: 0; overflow: hidden; border-radius: 34px; border: 1px solid rgba(255,255,255,0.13); background: radial-gradient(circle at 12% 0%, rgba(103,199,255,0.18), transparent 34%), radial-gradient(circle at 88% 10%, rgba(221,143,203,0.16), transparent 36%), linear-gradient(180deg, rgba(17,23,45,0.98) 0%, rgba(8,12,27,0.98) 100%); box-shadow: 0 34px 90px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.08); color: #fff; animation: julyLaunchModalIn .34s ease both; }
@keyframes julyLaunchModalIn {
    from { opacity: 0; transform: translateY(18px) scale(.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
.july-launch-modal__close { position: absolute; right: 18px; top: 18px; z-index: 4; width: 38px; height: 38px; border: 0; border-radius: 999px; background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.86); font-size: 24px; line-height: 1; cursor: pointer; transition: .2s ease; }
.july-launch-modal__close:hover { background: rgba(255,255,255,0.14); color: #fff; }
.july-launch-modal__head { padding: 42px 42px 28px; text-align: center; }
.july-launch-modal__eyebrow { display: inline-flex; align-items: center; justify-content: center; min-height: 32px; padding: 0 13px; margin-bottom: 18px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.06); color: #8db9ff; font-size: 11px; font-weight: 600; letter-spacing: .08em; }
.july-launch-modal__head h2 { margin: 0; color: #fff; font-size: clamp(34px, 4.4vw, 54px); line-height: 1.1; letter-spacing: -0.06em; font-weight: 300; word-break: keep-all; }
.july-launch-modal__head h2 span { display: inline-block; margin-top: 6px; background: linear-gradient(90deg, #77c9ff 0%, #d798ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.july-launch-modal__head p { margin: 18px 0 0; color: rgba(255,255,255,0.78); font-size: 17px; line-height: 1.7; font-weight: 600; letter-spacing: -0.03em; word-break: keep-all; }
.july-launch-modal__body { padding: 0 34px 28px; }
.july-launch-modal__highlight { padding: 22px 24px; border-radius: 24px; border: 1px solid rgba(103,199,255,0.20); background: radial-gradient(circle at 12% 0%, rgba(103,199,255,0.16), transparent 34%), rgba(255,255,255,0.06); }
.july-launch-modal__highlight strong { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; margin-bottom: 12px; border-radius: 999px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #08111f; font-size: 11px; font-weight: 600; letter-spacing: .04em; }
.july-launch-modal__highlight p { margin: 0; color: #fff; font-size: 18px; line-height: 1.65; font-weight: 700; letter-spacing: -0.035em; word-break: keep-all; }
.july-launch-modal__content { display: grid; gap: 10px; margin-top: 18px; }
.july-launch-modal__content p { margin: 0; color: rgba(255,255,255,0.76); font-size: 15px; line-height: 1.75; font-weight: 550; letter-spacing: -0.025em; word-break: keep-all; }
.july-launch-roadmap { margin-top: 20px; padding: 22px; border-radius: 24px; background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.09); }
.july-launch-roadmap__title { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.july-launch-roadmap__title span { color: #8db9ff; font-size: 10px; font-weight: 600; letter-spacing: .08em; }
.july-launch-roadmap__title strong { color: #fff; font-size: 18px; line-height: 1.35; font-weight: 800; letter-spacing: -0.03em; }
.july-launch-roadmap ul { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
.july-launch-roadmap li { display: flex; align-items: center; gap: 12px; min-height: 46px; padding: 10px 12px; border-radius: 16px; background: rgba(255,255,255,0.055); }
.july-launch-roadmap li b { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 28px; border-radius: 999px; background: rgba(103,199,255,0.14); color: #9ad7ff; font-size: 13px; font-weight: 600; }
.july-launch-roadmap li span { color: rgba(255,255,255,0.84); font-size: 14px; line-height: 1.45; font-weight: 650; letter-spacing: -0.02em; }
.july-launch-roadmap p { margin: 14px 0 0; color: rgba(255,255,255,0.48); font-size: 12px; line-height: 1.55; font-weight: 600; letter-spacing: -0.02em; }
.july-launch-modal__actions { display: grid; grid-template-columns: 1fr auto; gap: 12px; padding: 0 34px 34px; }
.july-launch-modal__primary, .july-launch-modal__today { display: inline-flex; align-items: center; justify-content: center; height: 56px; border-radius: 999px; text-decoration: none !important; border: 0; cursor: pointer; transition: .22s ease; }
.july-launch-modal__primary { padding: 0 26px; background: linear-gradient(90deg, #67c7ff 0%, #dd8fcb 100%); color: #07111f !important; font-size: 16px; font-weight: 600; letter-spacing: -0.025em; box-shadow: 0 14px 30px rgba(115,126,255,0.22); }
.july-launch-modal__today { padding: 0 20px; background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.76); font-size: 14px; font-weight: 800; letter-spacing: -0.02em; }
.july-launch-modal__primary:hover, .july-launch-modal__today:hover { transform: translateY(-2px); }
body.is-july-launch-modal-open { overflow: hidden; }
@media (max-width:768px) {
    .july-launch-modal__dialog { width: 100%; max-height: calc(100vh - 28px); margin: 0; border-radius: 26px; overflow-y: auto; }
    .july-launch-modal__head { padding: 34px 20px 22px; }
    .july-launch-modal__head p { font-size: 15px; }
    .july-launch-modal__body { padding: 0 16px 20px; }
    .july-launch-modal__highlight { padding: 18px; border-radius: 20px; }
    .july-launch-modal__highlight p { font-size: 15.5px; line-height: 1.65; }
    .july-launch-modal__content p { font-size: 13.5px; line-height: 1.7; }
    .july-launch-roadmap { padding: 18px; border-radius: 20px; }
    .july-launch-roadmap__title { display: block; }
    .july-launch-roadmap__title strong { display: block; margin-top: 6px; font-size: 16px; }
    .july-launch-roadmap li { align-items: flex-start; }
    .july-launch-modal__actions { grid-template-columns: 1fr; padding: 0 16px 24px; }
    .july-launch-modal__primary, .july-launch-modal__today { width: 100%; height: 54px; }
    .july-launch-modal__today { order: 2; background: transparent; height: 44px; }
}


/* hero visual real images */
.july-video-build__phone--photo{overflow:hidden;background:#090f1f;}
.july-video-build__photo{position:absolute;inset:0;border-radius:inherit;overflow:hidden;opacity:0;transform:scale(1.04);animation:julyShortsPhotoSwap 15s ease-in-out infinite;}
.july-video-build__photo img{width:100%;height:100%;display:block;object-fit:cover;}
.july-video-build__photo--1{animation-delay:0s;}
.july-video-build__photo--2{animation-delay:2.5s;}
.july-video-build__photo--3{animation-delay:5s;}
.july-video-build__photo--4{animation-delay:7.5s;}
.july-video-build__photo--5{animation-delay:10s;}
.july-video-build__photo--6{animation-delay:12.5s;}
.july-video-build__phone--photo::after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.18));pointer-events:none;z-index:2;}
.july-video-build__phone--photo .july-video-build__play{position:absolute;right:10px;bottom:10px;z-index:4;}

@keyframes julyShortsPhotoSwap{
  0%{opacity:0;transform:scale(1.06);}
  4%{opacity:1;transform:scale(1.025);}
  14%{opacity:1;transform:scale(1);}
  18%{opacity:0;transform:scale(1.04);}
  100%{opacity:0;transform:scale(1.06);}
}

.july-insta-real__tile{position:relative;overflow:hidden;background:#dfe7ec;}
.july-insta-real__tile img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .35s ease,filter .35s ease;}
.july-insta-real__tile:hover img{transform:scale(1.06);}
.july-insta-real__tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(15,22,48,.12));pointer-events:none;}
.july-insta-real__tile i{display:none;}
.july-insta-real__tile em{position:absolute;left:8px;bottom:8px;z-index:3;}

.july-kakao-share__card-thumb{overflow:hidden;background:none!important;}
.july-kakao-share__card-thumb::before{content:"";display:block;width:100%;height:100%;background:url('/img/hero/09.jpg') center/cover no-repeat;}

.july-store-card__avatar.is-image { overflow:hidden; background:#fff; }
.july-store-card__avatar.is-image img { display:block; width:100%; height:100%; object-fit:cover; }

.july-kakao-spread__thumb.is-image { overflow:hidden; background:#f4f6fb; }
.july-kakao-spread__thumb.is-image img { display:block; width:100%; height:100%; object-fit:cover; }

.july-ai-feed-item .thumb.is-image { overflow:hidden; background:#111827; }
.july-ai-feed-item .thumb.is-image img { display:block; width:100%; height:100%; object-fit:cover; }