/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans KR',sans-serif;color:#333;line-height:1.6;overflow-x:hidden;background:#fff}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}
button,input,textarea,select{font-family:inherit;outline:none;border:none}
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
@keyframes slideRight{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
.anim-up{animation:fadeUp .7s ease both}
.anim-in{animation:fadeIn .7s ease both}
.anim-right{animation:slideRight .7s ease both}
.d1{animation-delay:.12s}.d2{animation-delay:.24s}.d3{animation-delay:.36s}

/* Scroll-triggered */
.anim-up,.anim-in,.anim-right{animation-play-state:paused}
.anim-up.visible,.anim-in.visible,.anim-right.visible{animation-play-state:running}
/* Hero always plays */
.hero .anim-up,.hero .anim-in{animation-play-state:running}

/* ===== HEADER ===== */
#hd{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.04);transition:.3s}
#hd.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.08)}
.hd-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:56px}
.logo{display:flex;align-items:center;gap:8px;font-size:1.05rem}
.logo b{font-weight:800;color:#222}
.logo em{font-style:normal;color:#6c5ce7}
.logo-i{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#6c5ce7,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;flex-shrink:0;box-shadow:0 3px 8px rgba(108,92,231,.3)}
.nav-pc{display:flex;align-items:center;gap:24px}
.nav-pc a{font-size:.84rem;font-weight:500;color:#555;transition:.2s;position:relative}
.nav-pc a:not(.nav-cta):hover{color:#6c5ce7}
.nav-pc a:not(.nav-cta)::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;background:#6c5ce7;border-radius:1px;transition:.3s}
.nav-pc a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff!important;padding:8px 20px;border-radius:50px;font-weight:700;font-size:.82rem!important;box-shadow:0 4px 14px rgba(108,92,231,.3);transition:all .3s!important}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(108,92,231,.4)}
.hamburger{display:none;background:none;cursor:pointer;width:26px;height:20px;position:relative}
.hamburger span{display:block;width:100%;height:2px;background:#333;border-radius:1px;position:absolute;left:0;transition:.3s}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:9px}
.hamburger span:nth-child(3){top:18px}
.hamburger.on span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.on span:nth-child(2){opacity:0}
.hamburger.on span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
.nav-mo{display:none;position:fixed;top:56px;left:0;right:0;z-index:999;background:#fff;padding:12px 16px;flex-direction:column;gap:2px;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.nav-mo.on{display:flex}
.nav-mo a{display:block;padding:12px 14px;border-radius:10px;font-size:.92rem;font-weight:500;color:#333;transition:.15s}
.nav-mo a:active{background:#f0edff;color:#6c5ce7}
.mo-cta{background:linear-gradient(135deg,#6c5ce7,#a855f7)!important;color:#fff!important;text-align:center;font-weight:700;border-radius:12px;margin-top:6px;display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 4px 12px rgba(108,92,231,.25)}

/* ===== HERO ===== */
.hero{background:linear-gradient(135deg,#1a0a4a 0%,#2d1b69 30%,#4c3db5 60%,#6c5ce7 85%,#a855f7 100%);padding:56px 0 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 20%,rgba(168,85,247,.25) 0%,transparent 50%),radial-gradient(ellipse at 20% 80%,rgba(108,92,231,.2) 0%,transparent 50%);pointer-events:none;z-index:0}
.hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;z-index:0}

.hero-deco{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.hd-orb{position:absolute;border-radius:50%;opacity:.6}
.hd-orb.o1{width:350px;height:350px;top:-80px;right:-80px;background:radial-gradient(circle,rgba(168,85,247,.2),transparent 70%);animation:orbMove 18s ease-in-out infinite}
.hd-orb.o2{width:200px;height:200px;bottom:20%;left:-40px;background:radial-gradient(circle,rgba(108,92,231,.15),transparent 70%);animation:orbMove 14s ease-in-out infinite reverse}
.hd-orb.o3{width:120px;height:120px;top:50%;right:25%;background:radial-gradient(circle,rgba(255,212,59,.08),transparent 70%);animation:orbMove 10s ease-in-out infinite 2s}
@keyframes orbMove{0%,100%{transform:translate(0,0)}25%{transform:translate(15px,-10px)}50%{transform:translate(-10px,15px)}75%{transform:translate(10px,5px)}}

.hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:52px 20px 76px;position:relative;z-index:2}
.hero-txt{color:#fff}
.h-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);padding:6px 15px;border-radius:50px;font-size:.73rem;font-weight:600;margin-bottom:16px;backdrop-filter:blur(4px);animation:badgePulse 3s ease-in-out infinite}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 rgba(255,212,59,.2)}50%{box-shadow:0 0 0 10px rgba(255,212,59,0)}}
.h-badge i{color:#ffd43b;filter:drop-shadow(0 0 4px rgba(255,212,59,.4))}
.hero-txt h1{font-size:2.6rem;font-weight:900;line-height:1.2;margin-bottom:14px;letter-spacing:-.03em;word-break:keep-all;text-shadow:0 2px 30px rgba(0,0,0,.15)}
.hero-txt h1 span{background:linear-gradient(90deg,#ffd43b,#ff922b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.h-sub{font-size:.9rem;color:rgba(255,255,255,.65);line-height:1.75;margin-bottom:24px;word-break:keep-all}
.h-sub b{color:#fff;font-weight:700}
.h-btns{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap}
.btn-a{display:inline-flex;align-items:center;gap:7px;padding:12px 28px;border-radius:50px;background:#fff;color:#6c5ce7;font-size:.88rem;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.12);transition:all .3s}
.btn-a:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.18)}
.btn-b{display:inline-flex;align-items:center;gap:7px;padding:12px 28px;border-radius:50px;border:2px solid rgba(255,255,255,.25);color:#fff;font-size:.88rem;font-weight:600;transition:all .3s;backdrop-filter:blur(4px)}
.btn-b:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4)}
.h-nums{display:flex;gap:24px}
.h-nums>div{text-align:center;position:relative}
.h-nums>div:not(:last-child)::after{content:'';position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:1px;height:28px;background:rgba(255,255,255,.1)}
.h-nums b{display:inline;font-size:1.5rem;font-weight:900;color:#fff;font-family:'Nunito',sans-serif}
.h-nums small{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.4)}
.h-nums span{display:block;font-size:.65rem;color:rgba(255,255,255,.35);margin-top:2px}

/* Hero Visual */
.hero-vis{position:relative;z-index:2}
.vis-wrap{position:relative;filter:drop-shadow(0 25px 50px rgba(0,0,0,.3))}
.vis-browser{background:#fff;border-radius:12px;overflow:hidden}
.vis-bar{display:flex;gap:6px;padding:9px 14px;background:linear-gradient(180deg,#f5f5f7,#ececee);border-bottom:1px solid #ddd}
.vis-bar i{display:block;width:9px;height:9px;border-radius:50%;box-shadow:inset 0 -1px 2px rgba(0,0,0,.1)}
.vis-bar i:nth-child(1){background:#ff5f57}
.vis-bar i:nth-child(2){background:#ffbd2e}
.vis-bar i:nth-child(3){background:#28ca41}
.vis-screen{height:280px;overflow:hidden;background:#e8e4f8;position:relative}
.vis-screen .hs-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;opacity:0;transition:opacity 1s ease}
.vis-screen .hs-img.active{opacity:1}
.vis-phone{position:absolute;bottom:-20px;right:-16px;width:110px;background:#1a1a1a;border-radius:18px;padding:4px;box-shadow:0 12px 36px rgba(0,0,0,.35);z-index:3}
.vis-phone img{width:100%;height:170px;object-fit:cover;object-position:top;border-radius:14px}
.vis-tag{position:absolute;background:#fff;border-radius:50px;padding:6px 14px;font-size:.7rem;font-weight:700;box-shadow:0 4px 16px rgba(0,0,0,.1);display:flex;align-items:center;gap:5px;white-space:nowrap;animation:tagFloat 3s ease-in-out infinite;z-index:4}
.vis-tag i{color:#6c5ce7;font-size:.68rem}
.t1{top:12%;left:-16px}
.t2{bottom:28%;left:-26px;animation-delay:-1s}
.t3{top:32%;right:-20px;animation-delay:-2s}
@keyframes tagFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.hero-wave{position:absolute;bottom:-1px;left:0;width:100%;height:60px;display:block}

/* ===== COMPARE ===== */
.compare{padding:28px 0;background:#fff}
.cmp-box{display:flex;align-items:center;justify-content:center;gap:20px;background:linear-gradient(135deg,#faf8ff,#f0edff);border:2px solid #e8e0ff;border-radius:18px;padding:24px 28px;box-shadow:0 4px 20px rgba(108,92,231,.06);position:relative;overflow:hidden}
.cmp-box::before{content:'';position:absolute;top:-30px;right:-30px;width:100px;height:100px;background:radial-gradient(circle,rgba(108,92,231,.06),transparent 70%);border-radius:50%}
.cmp-l,.cmp-r{text-align:center;flex:1}
.cmp-label{font-size:.72rem;font-weight:700;color:#888;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.cmp-price{font-size:1.4rem;font-weight:900;font-family:'Nunito',sans-serif;color:#bbb}
.cmp-price.old s{text-decoration:line-through;text-decoration-color:#e74c3c;text-decoration-thickness:2px}
.cmp-price.hl{color:#6c5ce7}
.cmp-sub{font-size:.7rem;color:#aaa;margin-top:3px}
.cmp-sub.hl{color:#6c5ce7;font-weight:600}
.cmp-vs{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#6c5ce7,#a855f7);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(108,92,231,.3);animation:vsPulse 2s infinite}
.cmp-vs span{color:#fff;font-size:.72rem;font-weight:900;font-family:'Nunito',sans-serif}
@keyframes vsPulse{0%,100%{box-shadow:0 4px 14px rgba(108,92,231,.3)}50%{box-shadow:0 4px 22px rgba(108,92,231,.5)}}

/* ===== INCL ===== */
.incl{padding:36px 0;background:#fff;overflow:hidden}
.incl .s-head{margin-bottom:20px}
.incl-scroll{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:1100px;margin:0 auto;padding:0 20px}
.incl-card{text-align:center;padding:20px 10px;border-radius:14px;background:linear-gradient(180deg,#faf8ff,#f3f0ff);border:1px solid #e8e0ff;transition:all .3s}
.incl-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(108,92,231,.08);border-color:#d0c4ff}
.ic-icon{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#6c5ce7,#a855f7);display:flex;align-items:center;justify-content:center;margin:0 auto 8px;color:#fff;font-size:.9rem;box-shadow:0 4px 10px rgba(108,92,231,.25);transition:.3s}
.incl-card:hover .ic-icon{transform:scale(1.1);box-shadow:0 6px 14px rgba(108,92,231,.35)}
.incl-card b{display:block;font-size:.76rem;font-weight:700;color:#333;margin-bottom:2px}
.incl-card span{font-size:.64rem;color:#999}

/* ===== SECTION HEAD ===== */
.s-head{text-align:center;margin-bottom:28px}
.s-badge{display:inline-block;padding:4px 14px;border-radius:50px;background:linear-gradient(135deg,rgba(108,92,231,.08),rgba(168,85,247,.08));color:#6c5ce7;font-size:.68rem;font-weight:700;font-family:'Nunito',sans-serif;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;border:1px solid rgba(108,92,231,.1)}
.s-badge.light{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.12)}
.s-head h2{font-size:1.5rem;font-weight:800;color:#1a1a2e;margin-bottom:6px;letter-spacing:-.02em}
.s-head h2 b{color:#6c5ce7}
.s-head.light h2{color:#fff}
.s-head p{font-size:.84rem;color:#888}
.s-head.light p{color:rgba(255,255,255,.5)}

/* ===== PORTFOLIO ===== */
.portfolio{background:linear-gradient(160deg,#1a0a4a 0%,#2d1b69 30%,#4c3db5 70%,#6c5ce7 100%);padding:56px 0 50px;position:relative;overflow:hidden}
.pf-bg-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.pf-orb{position:absolute;border-radius:50%;opacity:.5}
.pf-orb.po1{width:300px;height:300px;top:5%;right:-60px;background:radial-gradient(circle,rgba(168,85,247,.2),transparent 70%);animation:orbMove 16s ease-in-out infinite}
.pf-orb.po2{width:200px;height:200px;bottom:10%;left:-40px;background:radial-gradient(circle,rgba(108,92,231,.15),transparent 70%);animation:orbMove 12s ease-in-out infinite reverse}
.portfolio::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}

.pf-filter{display:flex;gap:6px;margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:none;position:relative;z-index:2}
.pf-filter::-webkit-scrollbar{display:none}
.pf-fb{padding:6px 14px;border-radius:50px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:rgba(255,255,255,.55);font-size:.72rem;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .25s;backdrop-filter:blur(4px)}
.pf-fb:hover,.pf-fb.active{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.3)}

.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;position:relative;z-index:2}
.pf-card{display:block;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,.15);transition:all .35s;position:relative}
.pf-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,0,0,.25)}
.pf-img{height:200px;overflow:hidden;position:relative}
.pf-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s}
.pf-card:hover .pf-img img{transform:scale(1.05)}
.pf-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(108,92,231,.8),rgba(168,85,247,.8));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.pf-card:hover .pf-ov{opacity:1}
.pf-ov i{color:#fff;font-size:1.4rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.2))}
.pf-info{padding:12px 14px;display:flex;align-items:center;justify-content:space-between}
.pf-info h4{font-size:.84rem;font-weight:700;color:#1a1a2e}
.pf-cat{font-size:.62rem;font-weight:600;color:#6c5ce7;background:rgba(108,92,231,.06);padding:3px 10px;border-radius:50px;flex-shrink:0}

/* ===== TRUST BAR ===== */
.trust-bar{padding:36px 0;background:linear-gradient(135deg,#1a0a4a,#2d1b69,#4c3db5);position:relative;overflow:hidden}
.trust-bar::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Ccircle cx='20' cy='20' r='1'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.tb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative;z-index:1}
.tb-item{text-align:center;padding:12px 8px}
.tb-ic{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 8px;color:#c4b5fd;font-size:.9rem;transition:.3s}
.tb-item:hover .tb-ic{background:rgba(255,255,255,.15);transform:scale(1.1)}
.tb-item b{font-family:'Nunito',sans-serif;font-size:1.8rem;font-weight:900;color:#fff;display:inline}
.tb-item small{font-size:.8rem;color:rgba(255,255,255,.4);font-weight:700}
.tb-item span{display:block;font-size:.68rem;color:rgba(255,255,255,.35);margin-top:2px}

/* ===== PRICING ===== */
.pricing{padding:56px 0;background:linear-gradient(180deg,#f8f7ff,#fff);position:relative;overflow:hidden}
.pricing::before{content:'';position:absolute;top:10%;left:50%;transform:translateX(-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(108,92,231,.03),transparent 70%);pointer-events:none}
.pr-scroll{display:flex;gap:16px;justify-content:center}
.pr-card{background:#fff;border-radius:18px;padding:28px 22px;border:1px solid #ece8f8;text-align:center;position:relative;transition:all .4s;display:flex;flex-direction:column;box-shadow:0 2px 12px rgba(0,0,0,.04);flex:0 0 280px;max-width:320px}
.pr-card:hover{box-shadow:0 10px 36px rgba(108,92,231,.12);transform:translateY(-4px)}
.pr-card.best{border:2px solid #6c5ce7;box-shadow:0 6px 28px rgba(108,92,231,.15);transform:scale(1.03);background:linear-gradient(180deg,#fff,#faf8ff)}
.pr-card.best:hover{transform:scale(1.03) translateY(-4px)}
.pr-best-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);padding:5px 20px;border-radius:50px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;font-size:.7rem;font-weight:700;white-space:nowrap;box-shadow:0 4px 12px rgba(108,92,231,.3);animation:badgePulse 3s ease-in-out infinite}
.pr-top{margin-bottom:14px}
.pr-label{font-family:'Nunito',sans-serif;font-size:.7rem;font-weight:700;color:#6c5ce7;text-transform:uppercase;letter-spacing:.5px}
.pr-top strong{display:block;font-size:1.2rem;font-weight:800;color:#1a1a2e;margin:5px 0 2px}
.pr-top p{font-size:.78rem;color:#999}
.pr-price{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid #f0eef8}
.pr-price small{font-size:.76rem;color:#999}
.pr-price b{font-size:2.2rem;font-weight:900;color:#1a1a2e;font-family:'Nunito',sans-serif;margin:0 2px}
.pr-card.best .pr-price b{color:#6c5ce7}
.pr-card ul{text-align:left;margin-bottom:18px;flex:1}
.pr-card li{padding:7px 0;font-size:.8rem;color:#555;display:flex;align-items:center;gap:7px;border-bottom:1px solid #f8f6ff}
.pr-card li:last-child{border:none}
.pr-card li i{font-size:.65rem;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pr-card li .fa-check{color:#6c5ce7;background:rgba(108,92,231,.08)}
.pr-card li.off{color:#ccc}
.pr-card li.off i{color:#ddd;background:none}
.pr-btn{display:block;padding:11px;border-radius:12px;font-size:.86rem;font-weight:700;border:2px solid #6c5ce7;color:#6c5ce7;background:#fff;transition:all .3s;text-align:center;cursor:pointer}
.pr-btn:hover{background:#6c5ce7;color:#fff}
.pr-btn.pri{background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;border:none;box-shadow:0 4px 16px rgba(108,92,231,.3)}
.pr-btn.pri:hover{box-shadow:0 8px 24px rgba(108,92,231,.4);transform:translateY(-1px)}
.pr-note{text-align:center;margin-top:18px;color:#6c5ce7;font-size:.82rem;font-weight:600;background:linear-gradient(135deg,rgba(108,92,231,.05),rgba(168,85,247,.03));padding:11px 14px;border-radius:12px;border:1px solid rgba(108,92,231,.08);display:flex;align-items:center;justify-content:center;gap:6px}

/* ===== MID CTA ===== */
.mid-cta{padding:20px 0;background:#fff}
.mcta-inner{max-width:1100px;margin:0 auto;background:linear-gradient(135deg,#6c5ce7,#a855f7,#6c5ce7);background-size:200% 200%;animation:gradientShift 6s ease infinite;border-radius:20px;padding:40px 32px;text-align:center;position:relative;overflow:hidden;box-shadow:0 8px 32px rgba(108,92,231,.25)}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.mcta-deco{position:absolute;inset:0;pointer-events:none}
.mc-orb{position:absolute;border-radius:50%}
.mc-orb.m1{width:150px;height:150px;top:-30px;right:-20px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent)}
.mc-orb.m2{width:100px;height:100px;bottom:-20px;left:10%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent)}
.mcta-inner h3{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:6px;position:relative;z-index:1}
.mcta-inner p{font-size:.86rem;color:rgba(255,255,255,.7);margin-bottom:20px;position:relative;z-index:1;word-break:keep-all}
.mcta-btn{display:inline-flex;align-items:center;gap:7px;padding:13px 32px;border-radius:50px;background:#fff;color:#6c5ce7;font-size:.9rem;font-weight:700;box-shadow:0 4px 16px rgba(0,0,0,.1);transition:all .3s;position:relative;z-index:1}
.mcta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}

/* ===== PROCESS - 타임라인 ===== */
.process{background:linear-gradient(160deg,#1a0a4a,#2d1b69 40%,#4c3db5);padding:56px 0 50px;position:relative;overflow:hidden}
.proc-bg-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.proc-orb{position:absolute;border-radius:50%}
.proc-orb.pr1{width:250px;height:250px;top:10%;right:-50px;background:radial-gradient(circle,rgba(168,85,247,.12),transparent 70%);animation:orbMove 14s ease-in-out infinite}
.proc-orb.pr2{width:180px;height:180px;bottom:5%;left:-30px;background:radial-gradient(circle,rgba(108,92,231,.1),transparent 70%);animation:orbMove 10s ease-in-out infinite reverse}
.process::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}

.proc-timeline{position:relative;z-index:2;max-width:600px;margin:0 auto;padding-left:32px}
.proc-timeline::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,rgba(255,255,255,.15),rgba(255,255,255,.05))}
.tl-step{position:relative;padding-bottom:28px;padding-left:32px}
.tl-step:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-22px;top:4px;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#6c5ce7,#a855f7);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(108,92,231,.3);z-index:1}
.tl-dot span{font-family:'Nunito',sans-serif;font-size:.7rem;font-weight:900;color:#fff}
.tl-content{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px 16px;backdrop-filter:blur(4px);transition:all .3s}
.tl-content:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15);transform:translateX(4px)}
.tl-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#c4b5fd;font-size:.9rem;margin-bottom:8px}
.tl-content h4{font-size:.88rem;font-weight:700;color:#fff;margin-bottom:4px}
.tl-content p{font-size:.76rem;color:rgba(255,255,255,.45);line-height:1.6;word-break:keep-all}

/* ===== MERIT ===== */
.merit{padding:56px 0;background:linear-gradient(180deg,#fff,#faf8ff);position:relative;overflow:hidden}
.merit::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(108,92,231,.08),transparent)}
.merit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.m-card{display:flex;gap:14px;align-items:flex-start;padding:22px 18px;border-radius:16px;background:#fff;border:1px solid #eee;transition:all .35s;box-shadow:0 2px 8px rgba(0,0,0,.03)}
.m-card:hover{box-shadow:0 8px 28px rgba(108,92,231,.1);border-color:#d0c4ff;transform:translateY(-3px)}
.m-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.m-txt h4{font-size:.88rem;font-weight:700;margin-bottom:3px;color:#1a1a2e}
.m-txt p{font-size:.76rem;color:#888;line-height:1.6}

/* ===== FAQ ===== */
.faq-sec{padding:48px 0;background:#f8f7ff;position:relative;overflow:hidden}
.faq-sec::before{content:'';position:absolute;top:20%;left:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(108,92,231,.03),transparent);border-radius:50%;pointer-events:none}
.faq-list{max-width:640px;margin:0 auto}
.fq{background:#fff;border-radius:12px;margin-bottom:8px;border:1px solid #ece8f8;overflow:hidden;transition:all .25s;box-shadow:0 1px 4px rgba(0,0,0,.02)}
.fq.active{border-color:#d0c4ff;box-shadow:0 4px 14px rgba(108,92,231,.08)}
.fq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:none;cursor:pointer;font-size:.86rem;font-weight:600;color:#1a1a2e;text-align:left;gap:10px;transition:.2s}
.fq-q:hover{color:#6c5ce7}
.fq-q i{font-size:.6rem;color:#6c5ce7;transition:transform .3s;flex-shrink:0;width:20px;height:20px;border-radius:50%;background:rgba(108,92,231,.06);display:flex;align-items:center;justify-content:center}
.fq.active .fq-q i{transform:rotate(45deg);background:rgba(108,92,231,.12)}
.fq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.fq-a p{padding:0 16px 14px;font-size:.8rem;color:#666;line-height:1.75}

/* ===== CONTACT ===== */
.contact{padding:48px 0;background:#fff;position:relative;overflow:hidden}
.contact::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(108,92,231,.08),transparent)}
.ct-box{display:grid;grid-template-columns:1fr 1.2fr;gap:32px;align-items:start;background:linear-gradient(135deg,#faf8ff,#f0edff);border-radius:18px;padding:36px 28px;border:1px solid #e8e0ff;box-shadow:0 4px 20px rgba(108,92,231,.06);position:relative;overflow:hidden}
.ct-box::before{content:'';position:absolute;top:-50px;left:-50px;width:180px;height:180px;background:radial-gradient(circle,rgba(108,92,231,.05),transparent 70%);border-radius:50%}
.ct-left{position:relative;z-index:1}
.ct-left h2{font-size:1.5rem;font-weight:800;line-height:1.3;color:#1a1a2e;margin-bottom:10px}
.ct-left h2 span{color:#6c5ce7}
.ct-left p{font-size:.86rem;color:#666;line-height:1.75;margin-bottom:16px;word-break:keep-all}
.ct-btns{display:flex;gap:8px;flex-wrap:wrap}
.ct-btns a{display:flex;align-items:center;gap:6px;padding:9px 18px;border-radius:12px;background:#fff;font-size:.8rem;font-weight:600;color:#333;box-shadow:0 2px 10px rgba(0,0,0,.05);transition:all .3s;border:1px solid #f0f0f0}
.ct-btns a:hover{box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-2px)}
.ct-btns a i{color:#6c5ce7;font-size:.9rem}
.ct-btns .kk i{color:#f7e600}
.ct-form{background:#fff;border-radius:14px;padding:22px;box-shadow:0 6px 22px rgba(0,0,0,.04);border:1px solid #f0f0f0;position:relative;z-index:1}
.ct-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ct-f{margin-bottom:10px}
.ct-f label{display:block;font-size:.72rem;font-weight:600;color:#555;margin-bottom:4px}
.ct-f input,.ct-f select,.ct-f textarea{width:100%;padding:10px 12px;border:1px solid #e0dce8;border-radius:10px;font-size:.84rem;background:#fafafa;transition:all .25s}
.ct-f input:focus,.ct-f select:focus,.ct-f textarea:focus{border-color:#6c5ce7;background:#fff;box-shadow:0 0 0 3px rgba(108,92,231,.06)}
.ct-f textarea{resize:vertical}
.ct-form button{width:100%;padding:12px;border-radius:12px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 4px 16px rgba(108,92,231,.25);transition:all .3s}
.ct-form button:hover{box-shadow:0 8px 24px rgba(108,92,231,.35);transform:translateY(-1px)}

/* ===== FOOTER ===== */
footer{background:#0d0720;color:rgba(255,255,255,.5);padding:28px 0 0;position:relative}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(108,92,231,.15),transparent)}
.ft-inner{display:flex;align-items:center;justify-content:space-between;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.05);flex-wrap:wrap;gap:12px}
.ft-left .logo b{color:#fff}
.ft-left>p{font-size:.72rem;margin-top:4px}
.ft-right{display:flex;gap:16px;flex-wrap:wrap}
.ft-right a{font-size:.76rem;transition:.2s}
.ft-right a:hover{color:#c4b5fd}
.ft-copy{padding:14px 0;text-align:center;font-size:.68rem;color:rgba(255,255,255,.2)}
.ft-copy a{color:#c4b5fd}

/* ===== FIXED CTA ===== */
.fix-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:900;padding:10px 16px;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.05);box-shadow:0 -4px 16px rgba(0,0,0,.06)}
.fix-cta.show{display:block}
.fix-cta a{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px;border-radius:12px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;font-size:.88rem;font-weight:700;box-shadow:0 4px 16px rgba(108,92,231,.3)}

/* ===== RESPONSIVE 768 ===== */
@media(max-width:768px){
  .nav-pc{display:none}
  .hamburger{display:block}
  .hd-inner{height:50px}
  .nav-mo{top:50px}
  .wrap{padding:0 16px}
  .hero{padding-top:50px}
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:24px 16px 44px;gap:20px}
  .hero-txt h1{font-size:1.9rem}
  .h-sub{font-size:.84rem}
  .h-btns{justify-content:center}
  .h-nums{justify-content:center;gap:20px}
  .vis-wrap{max-width:360px;margin:0 auto}
  .vis-phone{right:-6px;width:80px}
  .vis-phone img{height:120px}
  .vis-screen{height:190px}
  .vis-tag{font-size:.62rem;padding:5px 10px}
  .t1{left:2px;top:8%}
  .t2{left:-4px}
  .t3{right:-4px}

  .cmp-box{padding:18px 14px;gap:10px;border-radius:14px}
  .cmp-price{font-size:1.2rem}

  .incl-scroll{display:flex;grid-template-columns:none;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-snap-type:x mandatory}
  .incl-scroll::-webkit-scrollbar{display:none}
  .incl-card{flex:0 0 130px;scroll-snap-align:start}

  .pf-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .pf-img{height:140px}

  .pr-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:flex-start;padding:0 16px;scroll-snap-type:x mandatory}
  .pr-scroll::-webkit-scrollbar{display:none}
  .pr-card{flex:0 0 260px;scroll-snap-align:center}
  .pr-card.best{transform:none}
  .pr-card.best:hover{transform:translateY(-4px)}

  .mcta-inner{margin:0 16px;padding:32px 20px;border-radius:16px}

  .proc-timeline{padding-left:24px}
  .tl-dot{left:-16px;width:24px;height:24px}
  .tl-dot span{font-size:.64rem}
  .tl-step{padding-left:24px}

  .merit-grid{grid-template-columns:1fr}
  .m-card{padding:18px 14px}

  .ct-box{grid-template-columns:1fr;gap:16px;padding:20px 16px;text-align:center}
  .ct-btns{justify-content:center}
  .ct-row{grid-template-columns:1fr}

  .ft-inner{flex-direction:column;align-items:flex-start}
  .contact{padding-bottom:70px}
  .s-head h2{font-size:1.3rem}

  .tb-grid{grid-template-columns:repeat(2,1fr);gap:0}
  .tb-item:nth-child(2)::after{display:none}
}

/* ===== 320px ===== */
@media(max-width:374px){
  .wrap{padding:0 14px}
  .hd-inner{height:46px;padding:0 14px}
  .logo{font-size:.9rem;gap:6px}
  .logo-i{width:26px;height:26px;font-size:.65rem;border-radius:7px}
  .nav-mo{top:46px}
  .hero{padding-top:46px}
  .hero-inner{padding:18px 14px 36px;gap:16px}
  .hero-txt h1{font-size:1.55rem;line-height:1.25}
  .h-sub{font-size:.78rem;line-height:1.7;margin-bottom:18px}
  .h-badge{font-size:.62rem;padding:4px 10px;margin-bottom:12px}
  .btn-a,.btn-b{padding:10px 20px;font-size:.82rem;gap:5px}
  .h-btns{gap:8px;margin-bottom:20px}
  .h-nums{gap:14px}
  .h-nums b{font-size:1.2rem}
  .h-nums small{font-size:.65rem}
  .h-nums span{font-size:.58rem}
  .vis-screen{height:145px}
  .vis-phone{width:65px;border-radius:12px;padding:3px}
  .vis-phone img{height:90px;border-radius:9px}
  .vis-tag{display:none}
  .hero-wave{height:40px}

  .compare{padding:20px 0}
  .cmp-box{padding:14px 10px;gap:8px;border-radius:12px}
  .cmp-price{font-size:1.05rem}
  .cmp-label{font-size:.64rem}
  .cmp-sub{font-size:.62rem}
  .cmp-vs{width:32px;height:32px}
  .cmp-vs span{font-size:.65rem}

  .incl{padding:28px 0}
  .incl .s-head{margin-bottom:14px}
  .incl-scroll{gap:8px}
  .incl-card{flex:0 0 105px;padding:14px 8px;border-radius:10px}
  .ic-icon{width:34px;height:34px;font-size:.78rem;border-radius:9px}
  .incl-card b{font-size:.7rem}
  .incl-card span{font-size:.58rem}

  .s-head h2{font-size:1.15rem}
  .s-head p{font-size:.74rem}
  .s-badge{font-size:.62rem;padding:3px 10px}
  .s-head{margin-bottom:20px}

  .portfolio{padding:40px 0 36px}
  .pf-filter{gap:4px}
  .pf-fb{padding:5px 10px;font-size:.66rem}
  .pf-grid{gap:7px}
  .pf-img{height:110px}
  .pf-info{padding:8px 10px}
  .pf-info h4{font-size:.74rem}
  .pf-cat{font-size:.56rem;padding:2px 7px}

  .trust-bar{padding:24px 0}
  .tb-item{padding:8px 4px}
  .tb-ic{width:32px;height:32px;font-size:.75rem;margin-bottom:6px}
  .tb-item b{font-size:1.4rem}
  .tb-item small{font-size:.65rem}
  .tb-item span{font-size:.6rem}

  .pricing{padding:40px 0}
  .pr-scroll{padding:0 14px;gap:10px}
  .pr-card{flex:0 0 240px;padding:20px 14px;border-radius:14px}
  .pr-price b{font-size:1.8rem}
  .pr-card li{font-size:.76rem;padding:6px 0;gap:6px}
  .pr-note{font-size:.76rem;padding:10px 12px;margin-top:14px}

  .mid-cta{padding:16px 0}
  .mcta-inner{margin:0 14px;padding:26px 16px;border-radius:14px}
  .mcta-inner h3{font-size:1.1rem}
  .mcta-inner p{font-size:.78rem;margin-bottom:16px}
  .mcta-btn{padding:11px 24px;font-size:.84rem}

  .process{padding:40px 0 36px}
  .proc-timeline{padding-left:20px}
  .tl-dot{left:-14px;width:22px;height:22px}
  .tl-dot span{font-size:.6rem}
  .tl-step{padding-left:20px;padding-bottom:20px}
  .tl-content{padding:14px 12px;border-radius:12px}
  .tl-icon{width:30px;height:30px;font-size:.8rem;border-radius:8px;margin-bottom:6px}
  .tl-content h4{font-size:.82rem}
  .tl-content p{font-size:.7rem}

  .merit{padding:36px 0}
  .m-card{padding:16px 12px;border-radius:12px;gap:10px}
  .m-ic{width:38px;height:38px;font-size:.9rem;border-radius:10px}
  .m-txt h4{font-size:.82rem}
  .m-txt p{font-size:.7rem}

  .faq-sec{padding:36px 0}
  .fq-q{padding:12px 12px;font-size:.8rem;gap:8px}
  .fq-q i{width:18px;height:18px;font-size:.55rem}
  .fq-a p{padding:0 12px 12px;font-size:.74rem}

  .contact{padding:36px 0 70px}
  .ct-box{padding:16px 12px;border-radius:12px;gap:12px}
  .ct-left h2{font-size:1.1rem}
  .ct-left p{font-size:.78rem;margin-bottom:12px}
  .ct-btns a{padding:8px 14px;font-size:.76rem}
  .ct-form{padding:16px 12px;border-radius:10px}
  .ct-f label{font-size:.68rem;margin-bottom:3px}
  .ct-f input,.ct-f select,.ct-f textarea{padding:9px 10px;font-size:.8rem;border-radius:8px}
  .ct-f{margin-bottom:8px}
  .ct-form button{padding:11px;font-size:.84rem}

  .fix-cta{padding:8px 14px}
  .fix-cta a{padding:11px;font-size:.82rem;border-radius:10px}

  footer{padding:20px 0 0}
  .ft-left>p{font-size:.68rem}
  .ft-right a{font-size:.72rem}
  .ft-copy{font-size:.64rem;padding:12px 0}
}
