@charset "utf-8";
/* CSS Document */


@import url('https://fonts.googleapis.com/css2?family=Metrophobic&family=Roboto:wght@300;400&display=swap');

* { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; } 
html,
body { width: 100%; height: 100%; font-size:14px; font-family: 'Roboto','Noto Sans KR', 'helvetica', sans-serif;  } 
body { background: #fff; box-sizing: border-box}
body,
ul,
li,
dl,
dt,
dd,
h1,
div,
button { margin: 0px; padding: 0px;  box-sizing: border-box; } 
body,
textarea,
select,
button,
p { color: #555; } 
li { list-style: none ;font-family: 'Roboto','Noto Sans KR', 'helvetica', sans-serif!important }
img { border: 0px; vertical-align: top; } 
body,
ul,
li,
dl,
dt,
dd,
h1,
p,
input { margin: 0px; padding: 0px; font-family: 'Roboto','Noto Sans KR', 'helvetica', sans-serif !important; } 
input { font-size: 12px; } 
fieldset button { border: 0}
table { border-collapse: collapse; border-spacing: 0; } 
input,
textarea { font-size: 14px; } 
button { cursor: pointer; border: none; margin: 0px; outline: 0}
a { text-decoration: none}
a:active,
a:hover { text-decoration: none}
h1,h2,h3 { margin: 0; padding: 0; font-weight: 600; } 

input[type=checkbox] { width: 20px; height: 20px; vertical-align: sub;}
input[type=text],
input[type=password],
input[type=number],
select { width: 100%; padding:3px; border-radius: 2px; box-sizing: border-box; resize: vertical; border: 1px solid #C9C9C9; font-size: 14px!important; font-family: initial; outline: none ;height:30px!important; outline: none ;text-align: left;font-family: 'Roboto','Noto Sans KR', 'helvetica', sans-serif !important;} 
textarea {width: 100%; padding:3px; border-radius: 2px; box-sizing: border-box; resize: vertical; border: 1px solid #C9C9C9; font-size: 14px!important; font-family: initial; outline: none }
textarea:focus, input:focus{ outline: none;}
::placeholder { color: #aaaaaa; } 
.shadow { -webkit-box-shadow: 0px -5px 10px -3px rgba(0,0,0,0.25); box-shadow: 0px -5px 10px -3px rgba(0,0,0,0.25)!important; } 
input[type=number] { padding:5px; border-radius: 4px; box-sizing: border-box; resize: vertical;  font-size: 1em; width: auto;}

.d-none { display: none; }

.login_c { background: url(../images/bg_login.png) no-repeat left bottom; height: 50%; background-size: cover; position: relative;}
.login-wrap { width: 970px; position: absolute; left: 50%; margin-left: -485px;; top: 50%; box-shadow:3px 3px 50px -2px rgba(0,0,0,0.2)}
.left-box { height: 450px; width: 470px; float: left; background: url(../images/img_symbol.png)no-repeat bottom right rgb(43 127 201 / 90%)}
.left-box p { font-size: 30px; color: #fff; margin: 25px; white-space: pre-line; letter-spacing: 1px; margin-top: 50px;}
.left-box p > strong { color:#f8ff00; font-weight: normal;}
.login_c form { width: 500px; background:#fff ; padding:20px 60px 60px ;margin: 0 auto;float: left;}
.login_c form label { margin: 20px 0 10px;}
.login_c h1 {background: url(../images/logo_w2.png) no-repeat left center; font-size: 0px; width:200px; height: 30px; margin: 20px;}
.login_c h1 strong { color: #fff; margin-top: 2px; margin-left: 15px; display: inline-block;}
.login_c h2 { font-size: 30px; color:#075F80 ; font-weight: normal; margin-bottom:30px;}
.login_c input[type=text],input[type=password] { border-radius: 3px; padding: 10px 8PX; height: unset!important;;}
.login_c input[type=checkbox] + label { margin-left: 10px;}
.login_c .login-area { position: relative;}
.login_logo { position: absolute; bottom: 10px; left: 20px; width: 218px; height: 30px; font-size: 0px; background: url(../images/login_logo.png) no-repeat;}
.btn-login { width: 100%; background: #000 ; color: #fff; padding: 10px;}
label.error { margin-left: 5px !important; left: 0px; top: 95px; color: red;}
label.error::before { content: "*";}

h1.logo { background: url("../images/logo_c.png") no-repeat 3px; font-size: 0px ;  height: 30px ; cursor: pointer;}
h1 strong { font-size: 20px ; font-weight: bold ; padding-left: 125px ; line-height: 33px }
.wrap { height: 100% ; width: 100% ; background: #f7f7f7}
.wrap  h2 { font-size: 30px ; color: #2959C9 ; padding: 10px 15px ; background: #fff;}
.wrap  h2 strong { font-size: 14px; font-weight: normal; color: #999; margin-left: 10px;}

.main { width: 100%; height: 100%; position: absolute ; transition: margin-left .5s; overflow: hidden;}
/* .navi + .main { margin-left:300px; width: calc(100% - 300px); background-color: #FFFFFF} */
.toggle{ display: none !important; cursor: pointer; left: 240px; top: -2px; display: inline-block; cursor: pointer; padding: 15px 17px; float: right; margin-right: -15px; margin-top: -42px;}
.bar1, .bar2, .bar3 { width: 25px; height: 2px; background-color: #1880a7; margin: 6px 0;transition: 0.4s;}
.active .bar1 { -webkit-transform: rotate(-45deg) translate(-4px, 3px);transform: rotate(-45deg) translate(-6px, 5px);}
.active .bar2 {opacity: 0;}
.active .bar3 { -webkit-transform: rotate(45deg) translate(-6px, -5px); transform: rotate(45deg) translate(-6px, -5px);}
.toggle.active { left: 0px; opacity: 0; line-height: 28px  }

.navi { position: fixed; top:0px; left:0px;  background: #fff; transition: width 0.5s; overflow-x: hidden;z-index: 99;height: 100% ; width: 300px; border-radius: 15px ; padding: 10px ; box-shadow: 3px 3px 10px -2px rgba(0,0,0,0.31);
-webkit-box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41);
-moz-box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41);}

nav::-webkit-scrollbar { display:none; }
nav li { position: relative;float: left; width: 100%; list-style: none; transition: 0.5s; font-size: 15px;}
nav li li { border-top: none;}
nav li:first-child { border-top: none;}
nav ul > .sub > a:after { pointer-events: none; position: relative; float: right; content: '';  margin-top: 7px; vertical-align: middle; transition: 0.5s; width: 0.5rem; height: 0.5rem; border-bottom: 1px solid currentColor; border-left: 1px solid currentColor; transform: rotate(-45deg) translate(50%, 0%); -webkit-transform: rotate(-135deg); transform-origin: center center; transition: transform ease-in-out 100ms;}
nav li.lock { background: url(../images/img_lock.png) no-repeat 260px 13px}
nav.active li.lock::after { content:""; background: url(../images/img_lock.png) no-repeat 0px -34px ; width: 18px;  height: 18px;  position:absolute; right: 10px; top: 30px }
nav li.lock a::after {display: none;}
nav input[type=checkbox] { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0;display: block; cursor: pointer;}

nav ul { margin: 0; padding: 0;overflow: hidden;}
nav a {display: block; padding: 10px 10px 8px; color: #333; text-decoration: none; white-space: nowrap;}
nav a span { display: inline-block ;width: 30px ;margin-right: 10px; height: 30px ;  vertical-align: middle;}
nav a span.m_vssl { background: url("../images/icon_menu.svg")no-repeat -50px -48px}
nav a span.m_cargo { background: url("../images/icon_menu.svg")no-repeat -50px -95px; }
nav a span.m_truck { background: url("../images/icon_menu.svg")no-repeat -50px -140px;}
nav a span.m_terminal { background: url("../images/icon_menu.svg")no-repeat -50px -185px;}
nav a span.m_port { background: url("../images/icon_menu.svg")no-repeat -195px -138px}
nav a span.m_layer { background: url("../images/icon_menu.svg")no-repeat -50px -278px}
nav a span.m_weather { background: url("../images/icon_menu.svg")no-repeat -50px -325px}
nav a span.m_alarm {  background: url("../images/icon_menu.svg") no-repeat -195px -56px}
nav a span.m_setting { background: url("../images/icon_menu.svg")no-repeat -195px -95px;}
nav a span.m_container { background: url("../images/icon_menu.svg")no-repeat -195px -138px}
nav a span.m_portvue { background: url("../images/menu-beta-on.gif")no-repeat 0 0; background-size: 35px; width: 40px; }


nav.active a {display: block; padding: 15px 10px 3px; color: #3bb1dd; text-decoration: none; white-space: nowrap;}
nav.active a span { display: inline-block ;width: 30px ;margin-right: 10px; height: 30px ; vertical-align: middle;}
nav.active a span.m_vssl { background: url("../images/icon_menu.svg")no-repeat 0px -48px}
nav.active a span.m_cargo { background: url("../images/icon_menu.svg")no-repeat 0px -95px; }
nav.active a span.m_truck { background: url("../images/icon_menu.svg")no-repeat 0px -140px;}
nav.active a span.m_terminal { background: url("../images/icon_menu.svg")no-repeat 0px -185px;}
nav.active a span.m_port { background: url("../images/icon_menu.svg")no-repeat -150px -138px}
nav.active a span.m_layer { background: url("../images/icon_menu.svg")no-repeat 0px -278px}
nav.active a span.m_weather { background: url("../images/icon_menu.svg")no-repeat 0px -325px}
nav.active a span.m_alarm { background: url("../images/icon_menu.svg")no-repeat -148px -56px}
nav.active a span.m_setting { background: url("../images/icon_menu.svg")no-repeat -150px -95px}
nav.active a span.m_container {background: url("../images/icon_menu.svg")no-repeat -150px -138px }
nav.active a span.m_portvue { background: url("../images/menu-beta.gif")no-repeat 0 0; background-size: 35px; width: 40px;  }


.navi.active .util{ color: #3bb1dd; display: block;  background: none;}
.navi.active .util a.login { padding: 3px; margin-right: -8px!important;letter-spacing: -0.5px;}
nav.navi.active .util strong { font-size: 0px; padding: 125px; padding-top: 10px;}

/*뎁스추가용*/
nav .sub .sub { padding: 5px; position: relative ; }
nav .sub .sub + .sub {border-top: 1px solid #b4dcea  }
nav .sub .sub a {font-weight: bold; color: #3893b4; font-size: 14px;padding:5px ;display: flex; justify-content: space-between; padding:2px 0px}
nav .sub .sub a::after {pointer-events: none; position: relative; float: right; content: '';  vertical-align: middle; transition: 0.5s; width: 0.4rem; height: 0.4rem; border-bottom: 1.5px solid currentColor; border-left: 1.5px solid currentColor; transform: rotate(-45deg) translate(50%, 0%); -webkit-transform: rotate(-135deg); transform-origin: center center; transition: transform ease-in-out 100ms; margin-top: 5px;}
nav .sub .sub a.ui-jump::after { display: none;}
nav .sub .sub .submenu {border-top: none!important  ; padding: 0px }

nav ul > li:hover {}
nav li li:hover { background: #fff !important;}
nav .submenu { max-height: 0; overflow: hidden; border-top: none; transition: max-height 0.5s ease-in-out; display: grid;  position: relative; background: #e8f5fa; padding: 0px 10px;}
nav ul li >.submenu { box-shadow: 0 0 0 1px #94d2e9 inset;}

nav input[type=checkbox]:checked ~ .submenu { max-height: 999px; border-radius: 8px ;padding: 5px;}
nav input[type=checkbox]:checked ~ a:after { transform: rotate(-45deg)!important; }
nav .submenu a { }
nav .submenu li { }
nav .submenu li.sub { list-style: none;padding-left: 45px;}
nav .submenu li.sub:hover { background: #fcf5d4!important ;}
nav .submenu li li {background: #3a3a3a;}
nav .submenu li li li { background: #2a2a2a;}
nav.active .submenu { overflow: hidden; display: none;}
nav .submenu.exc { background:#fff!important; padding: 0px }
nav .submenu.exc div[class^=col] { padding:3px!important }
nav .submenu .input-group.date input,
nav .submenu .input-group .form-select { height: 35px!important;}

nav li.setting { }
nav .submenu .input-group.date input { background: url(../images/icon_calendar.png) no-repeat #fff 125px;  border-radius: 5px 0 0 5px; }
nav .submenu .input-group .form-select  { border-radius: 0px 5px 5px 0px;}
nav p.s-tit { font-size: 13px;}
.navi.active { width:70px; background:#268ad0;border-radius: 0;}
.navi.active + .main { left:0px; /* width: calc(100% - 70px); */}
.navi.active h1 {background: url(../images/logo_w.png) no-repeat center #0f67a5; height: 50px; border-radius: 8px;}
.navi.active h1 strong { display: none;}
.navi.active .sub .sub div:after ,.navi.active ul > .sub > a:after { display: none;}
.navi.active .util { border-bottom: 1px solid rgb(255 255 255 / 30%); border-radius: 0; margin: 0;  margin-top: 20px;}
.navi.active .portvue-section { border-top: 1px solid rgb(255 255 255 / 30%); border-radius: 0; margin: 0;  margin-top: 440px;}
.toggle.active .navi-open { background:url("../images/icon_left.png") no-repeat }
.main iframe#main-mapIframe, .main iframe#vslIframe, .main iframe#tmlIframe { left: 70px !important; width: calc(100% - 70px); position: absolute; }
.main iframe#vslPrtIframe, .main iframe#wthIframe { left: 620px !important; }

.wrap.l-dist {left: 70px; position: absolute; width: calc(100% - 70px);}

.util { background:#3b6ddd ; border-radius: 5px ; overflow: hidden; display: flex ;justify-content: space-between; align-items: center; color:#fff ; padding: 10px; margin: 20px 0 10px ; width: 100%;position: relative;}
.util a.login { color:#fff ;float: right ; border-radius: 2px ; border:1px solid #bbe9fb; font-size: 13px ;padding: 5px 10px;} 
.util strong { font-weight: normal ; background: url("../images/icon_member.png") no-repeat 5px -42px; padding-left:40px ; height: 25px ;line-height: 25px } 
.src { margin-top:10px}
.src input { background: #fff ; border-radius: 20px ; padding:8px 15px ; border: 0 ; width: 100% ; color:#126f92 ;letter-spacing: -0.2px;}
.src::placeholder { color:#938c8c }	
.src .btn_src { position: relative ; background: url("../images/icon_menu.png") no-repeat  0 5px;  width: 25px; height: 25px ; font-size: 0px ; float:right ; margin-top:-30px ; margin-right:10px }

.slider.slider-horizontal { height: 14px; width: 240px;margin-left: 10px;}
  
.slider-handle { background-color:#527fea; background-image: unset; top: -3px; width: 12px; height: 12px;}
.slider-strips .slider-selection { background-color:#527fea !important; background-image: none !important; }
.slider .tooltip.top { margin-top: -40px; margin-left: -15px;}
.slider .tooltip { opacity: 1 ; font-size: 13px ; position: absolute}
.slider .tooltip-main { opacity: 0!important}
.slider .slider-track { background-color: #d3e1e6!important;  background-image: unset; height: 3px!important}
.slider .tooltip-inner { padding:0px 3px;color: #3b95dd; border: 1px solid #3b95dd; background: #fff; border-radius: 2px}
.slider .tooltip.top .tooltip-arrow { border-top-color: #3b95dd;}
.tooltip.tooltip-max.top {margin-left: -55px;}
.slider .tooltip.bottom {  margin-top: -40px; margin-left: -15px;}

.s-sort a { font-weight: normal !important;  background: #fff;  display: inline-block!important; border: 1px solid #c6c8c8; padding: 2px 8px 3px!important; text-align: center; border-radius: 20px; font-size: 13px!important ; margin-bottom:3px ; text-decoration: none }
.s-sort a span { width: 15px; height: 15px; border-radius: 30px; margin-right: 5px!important;}
.s-sort a span.crimson { background: #E67E22}
.s-sort a span.green { background: #3CB371}
.s-sort a span.orange { background: #deb887}
.s-sort a span.cyan { background: #008B8B} 
.s-sort a span.opauqe { background: #92c7c7} 
.s-sort a span.blue { background:#00BFFF} 
.s-sort a span.rosybrown { background:#BC8F8F}
.s-sort a span.maroon { background:#800000 }
.s-sort a span.gray { background:#ddd }
.s-sort a span.dodgerblue { background:#5572e0 }
.s-sort a span.purple { background:#9370db}
.s-sort a span.darkgray { background:#a1a1a1}
.s-sort a span.peach { background:#ffcba4} 
.s-sort a span.goldorange { background:#d4a017} 
.s-sort a span.darkgold { background:#af7817}
.s-sort a span.oil { background:#3b3131}
.s-sort a span.sage { background:#848b79}
.s-sort a span.slime { background:#bce954}
.s-sort a span.rose { background:#d19a98}
.s-sort a span.yellow { background:#ffe87c}
.s-sort a.none { cursor: not-allowed !important; }

.s-sort a::after { border: none!important; display: none}
.src a.gray { background:#0f698b ; border-radius: 20px ;font-size: 13px!important ;  display: inline-block!important; padding: 2px 10px ; color:#fff}

.s-sort a { background: #538ce3; color: #fff!important ; border: none!important ; padding: 3px 12px!important;}
.s-sort a span { float: right ; background:url("../images/icon_x.png") no-repeat center ; margin-right: 0px!important ;margin-right: -3px!important; margin-top: 3px; margin-left: 5px;}

.s-sort.type > a { font-weight: normal !important; background: #fff !important; display: inline-block!important; border: 1px solid #c6c8c8 !important;  padding: 2px 7px 3px!important; text-align: center; border-radius: 20px; font-size: 13px!important; margin-bottom: 3px;color: #3893b4!important;letter-spacing: -0.5px;}
.s-sort.type a span {float: left!important; margin-left: 0px; margin-right: 5px!important;}

.s-sort.fleet > a { font-weight: normal !important; background: #fff !important; display: inline-block!important; border: 1px solid #c6c8c8 !important;  padding: 2px 7px 3px!important; text-align: center; border-radius: 20px; font-size: 13px!important; margin-bottom: 3px;color: #3893b4!important;letter-spacing: -0.5px;}
.s-sort.fleet a span {float: left!important; margin-left: 0px; margin-right: 5px!important;}

.s-sort a.disabled  { opacity: 0.4;}
.src a.disabled.gray { opacity: 0.2;}
.s-sort a.disabled span { opacity: 0.5;}

#drg-info { position: absolute; z-index: 9999; width: 550px; background-color: #fff; position: absolute; left:300px; position: absolute; top:50px; box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41); 
    -webkit-box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41); -moz-box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41); overflow: hidden; } 

#drg-header { padding: 10px; cursor: move; z-index: 10; background: #1d46a1;color: #fff;position: relative;font-size: 20px; border-radius: 5px 5px 0 0;}
#drg-header p { color:#bce8f9 ; font-size: 13px; line-height: 10px;}

.scroll-container {}

.vssl_info { width:100%; }
.vssl_info h1 img { margin-right: 10px; vertical-align: top;}
.vssl_info button.close { color: #fff ; font-size: 30px; font-weight: normal;}
.vssl_info .ship_photo img { width: 100%; height:240px!important;}
.vssl_info .ovh dl { margin-top: -3px;}
.vssl_info .s-sum { background: #E5F8FF; padding: 5px; overflow:hidden;}
.vssl_info .s-sum dl { margin-top: 0px;  margin-bottom: 0px; margin-left: 10px;}
.vssl_info .s-sum dl dt { font-weight: normal; font-size: 13px;}
.vssl_info .s-sum dl dd { font-weight: bold;}
.vssl_info .s-cur { padding: 15px;}
.vssl_info .s-cur dl { margin-bottom: 10px;}
.vssl_info .s-cur dl dt { font-weight: normal; font-size: 13px;}
.vssl_info .s-cur dl dd { font-weight: bold; font-size: 15px;}
.vssl_info .nav-tabs { width: 100% !important;}

.ship-progress { background:#F3F3F3; padding:10px; overflow: hidden; font-weight: bold; width: 100%; padding-bottom: 5px; }
.ship-progress .line { font-size: 22px; margin: 0; color: s;}
.ship-progress .line span { margin-top: -3px; font-size: 14px;display: block; font-weight: normal; color: #1E218B;}
.ship-progress .path:before { content: ""; border-radius: 30px; width: 9px; height: 9px; background: #1E218B; display: block; margin-bottom: -5px; margin-left: 0;}
.ship-progress .path:after  { content: ""; border-radius: 30px; width: 9px; height: 9px; background:#1E218B; display: block; position: absolute; top:25px ; right: 0px;}
.ship-progress .path { width: 100%;  overflow: hidden;position: relative; padding-top: 25px;}
.ship-progress .path span {font-weight: normal; color: #8E8E8E; font-size: 13px;}
.ship-progress .path strong { display: block; letter-spacing: -0.5px; margin-top: -3px; color: #000; font-weight: normal;}
.ship-progress .path .bar { border: 1px solid #1E218B; position: absolute ; width: 100%; z-index: 999;}
.ship-progress .path .b-dot { width: 100%; position: absolute ; right: 0; background-image: linear-gradient(to right, #333 10%, rgba(255, 255, 255, 0) 0%); background-position: top; background-size: 6px 2px; background-repeat: repeat-x; height: 2px; border: none; }
.ship-progress .path .per20{ width:20%}
.ship-progress .path .per40{ width:40%}
.ship-progress .path .per60{ width:60%}
.ship-progress .path .per80{ width:80%}
.triangle-right { width: 0;height: 0;border-top: 5px solid transparent;border-left: 7px solid #1E218B;border-bottom: 5px solid transparent;margin-left: 33.333%; position: absolute; top: 25px; font-size: 0;z-index: 99; }
.triangle-up { width: 0;height: 0;border-left: 5px solid transparent;border-right: 5px solid transparent;border-bottom: 7px solid #1E218B; font-size: 0;position: absolute; left: 18.5px;  top: 55%;}
.triangle-down { width: 0;height: 0;border-left: 5px solid transparent;border-right: 5px solid transparent;border-top: 7px solid #1E218B; font-size: 0;position: absolute; left: 18.5px;  top: 55%;}

.info-rcv { background: #F3F3F3 ; border-top: 1px solid #DBDBDB; overflow: hidden; position: absolute;; bottom:0; width:100%; font-size: 13px; left: 0 ; text-align: left; padding: 7px; color: #9e9e9e; padding-left: 15px;}
.info-rcv strong { margin-left: 20px; color: #000; font-size: 12px; font-weight: normal; }

.ship-trk { background: url(../images/ship-trk.png) no-repeat ; width: 52px; height: 35px; font-size: 0; position: absolute ;top: 3px;}
.ship-trk.per0 { left: 0%!important}
.ship-trk.per20 { left: 20%!important}
.ship-trk.per40 { left: 40%!important}
.ship-trk.per60 { left: 60%!important}
.ship-trk.per80 { left: 80%!important}
.ship-trk.per100 { left: 100% !important; margin-left: -50px;}

.ship-pod { margin-top: 5px; overflow-y: auto; margin-top: -3px;}
.ship-pod ul { margin: 0px ; padding: 0px; position: relative;}
.ship-pod li { color: #000; overflow: hidden; font-size: 22px; font-weight: bold; list-style: none; position: relative; padding-left: 70px; padding-left: 90px;}
.ship-pod ul:after { position: absolute; content: ""; width: 6px; background: #cce9e8; left: 21px; top: -1px;z-index: -1; height: 100%;}

.ship-pod li + li { margin-top: 15px;}
.ship-pod li:last-child { overflow: inherit; }
.ship-pod li strong {width: 55px; text-align: center;}
.ship-pod li strong.pod { color:#fff ; position: absolute; left: -50px; background: #a7ced6 ; font-size: 15px ; border-radius: 3px; padding: 5px 10px 3px 10px;left: 0px;}
.ship-pod li strong.pol { color:#fff ; position: absolute; left: -50px; background: #3a68d1; font-size: 15px ; border-radius: 3px; padding: 5px 10px 3px 10px;left: 0px;}
.ship-pod li strong.ts  { color:#2C9F9D; position: absolute; left: -50px; background: #fff; border: 1px solid #a8a9de;font-size: 15px ; border-radius: 3px; padding: 3px 10px;left: 0px;}
.ship-pod li span { font-size: 14px; font-weight: normal; margin-left: 10px; color: #1E218B;}
.ship-pod li dl dt { font-size: 12px ; line-height: 22px ; color: #8E8E8E ; font-weight: normal; float: left; width: 30%; text-align: right; }
.ship-pod li dl dd { font-size: 12px ; line-height: 22px ; color: #8E8E8E ; font-weight: normal; float: left;  width: 65%; margin-left: 15px; }

.sol { background: #3a68d1; color: #fff; padding: 10px;display: flex; justify-content: space-around;align-items: center;}
.sol a { color: #fff; text-decoration: none;}
.sol a:first-child { }
.sol a + a { border-left: 1px solid rgb(255 255 255 / 30%); padding-left: 20px;}
.sol a:first-child::before { content: ""; width: 25px; height:25px ;background: url("/images/icon_util.png") no-repeat  0 -75px; display: inline-block;vertical-align: middle;  margin-right: 5px;}
.sol a:nth-child(2)::before { content: ""; width: 27px; height:29px ;background: url("/images/icon_util.png") no-repeat  -50px -70px; display: inline-block;vertical-align: middle;  margin-right: 5px;}
.sol a:nth-child(3)::before { content: ""; width: 25px; height:25px ;background: url("/images/icon_util.png") no-repeat  -105px -75px; display: inline-block;vertical-align: middle;  margin-right: 5px;}

.time-progress {display: flex;flex-wrap: nowrap;justify-content: space-between;}
.time-progress .speed { color: #002d91; font-size: 15px; }
.contents { height: calc(100% - 66px); padding:25px 0 25px 25px ;overflow: auto;}
.contents section { width: 100%; overflow: hidden;}
.contents h3 { font-size: 18px;}
.contents section + section { margin-top: 20px;}

.card-port { transition: 0.2s }
.card-port li { width:360px;float:left; font-weight: bold; border-radius: 10px ; border: 1px solid #CBCBCB ; padding: 10px 15px; background: url("../images/img_card.png") no-repeat #fff 10px 15px; white-space: nowrap ; transition: 0.5s; margin:10px; position:relative ;height: 80px;}
.card-port li span.schedule { width: 20px; height: 25px; background: url(../images/icon_card.png) no-repeat 0px 5px; display: inline-block;}
.card-port li span.lock { width: 25px; height: 26px; font-size: 0px; background: url(../images/icon_card.png) no-repeat 3px -21px; display: inline-block; margin-left: 5px;}
.card-port li p { font-size: 13px ; font-weight: normal;white-space: initial; line-height: 15px;}

.card-port li div { float: right; font-size: 0px  ; }
.card-port li div a {width: 23px; height: 25px; display: inline-block; background: url(../images/icon_card.png) no-repeat 0 -50px; margin-left: 5px; }

.card-port li h2 { color: #2959C9;  margin-bottom: 5px; cursor: pointer; }
.card-port li > a { color: #1863b7; display: block; font-size: 22px; margin-left: 60px;}

/* Schedule */
.modal-dialog-scrollable .modal-content {  height:90%;}
.pop_wrap { height: 100%; }
.pop_content { background: #fff ; padding: 25px; overflow: auto; height: calc(100% - 120px); }
.row.date .col { padding: 3px; text-align: right;width: 25%; min-width:36px}
.row.date .col +.col { border-left: 1px solid #ccc;}
.row.date .col .col { border-right: 1px solid #cccccc; }
.row.line { justify-content: space-between; flex-wrap: nowrap;}
.pop_content  .row.line >.col {background: #aecfee; text-align: center ;  border: 1px solid #85a3bf; margin-left: -1px;display: flex; flex-wrap: unset; white-space: nowrap;justify-content: space-around;width: 146px; min-width: 146px;}
.pop_content .row.line >.col.sat, .pop_content .row.line >.col.sun { background: #ffeee5; color: #f15600; border: 1px solid #fbb522;}
.pop_content  .row.line >.col span{ display: block ; padding:5px ;  white-space: nowrap;}
.pop_content  .row.line >.col:first-child span { display: block ; width:162px;}
.pop_content  .row.time {margin-top: -1px; flex-wrap: nowrap;}
.pop_content  .row.time > .col { border: 1px solid #CCCCCC ; margin-left: -1px;background: #ECF4FB ;}
.pop_content  .row.time > .col > span { width:190px;}
.pop_content  .row.time > .col:first-child ,.pop_content .row.line > .col:first-child { max-width: 190px; flex: unset; text-align: center; width: 190px;min-width:190px;}
.pop_content  .row.time .col.date span {  text-align: right;}

.row { }

.fm-area {background:#f2ffe7 ; position: relative}
.fm-area span.port{writing-mode: vertical-lr; text-orientation: mixed; font-size: 18px; color: #2585A8 ; font-weight: bold ; position: absolute; height: 100%; display: block; top: 0px; text-align: center; background: #f2ffe7;;margin-left: -10px; border-bottom: 1px solid #ccc; border-top: 1px solid #ccc; border-right: 1px solid #ccc;} 
.row.fm .col .row {height: 100% ;  position: relative; display: flex; flex-wrap: inherit;}
.fm-area .row.fm .col { background: #eef6d7}
.fm-area .row.fm { margin-top: -1px ;  display: flex;flex-wrap: inherit;}
.row.fm > .col {  border: 1px solid #CCCCCC ;  margin-left: -1px;}
.row.fm > .col:first-child { max-width: 190px;}
.row.fm > .col .col + .col { border-left: 1px solid #CCCCCC;}
.row.fm .col .col { padding:5px 0px 0px ; width: 36px; min-width:36px ;}
.row.date { flex-wrap: unset;}
.row.date .col.current { position: relative;}
.row.date .current::before { content: "\25BC"; position: absolute; right: -7px; bottom: -8px; z-index: 999; color: #f78b0a;}
.row.fm .col .col.current {border-right: 2px dashed #f7b20a;}
.row.fm .col .col.current:first-child:before { content: ""; }

.row.fm .col p.s-txt { font-size:12px; }
.row.fm .col p.s-txt:nth-child(3) { background: #d1ffe3; display: inline;  padding: 0px 3px;}
.row.fm .col .s-info { padding: 5px 0px ; position: relative; text-align: center ; width:190px;  min-height: 80px;}
.row.fm .col .s-info strong{ margin-top: 5px ; display: block}

.to-area { background:#FFF6EE ; position: relative}
.to-area span.port{writing-mode: vertical-lr; text-orientation: mixed; font-size: 18px; color: #2585A8 ; font-weight: bold ; position: absolute; height: 100%; display: block; top: 0px; text-align: center; background: #FFF6EE;margin-left: -10px; border-bottom: 1px solid #ccc; border-top: 1px solid #ccc; border-right: 1px solid #ccc;} 
.to-area .row.fm { margin-top: -1px ;  display: flex; flex-wrap: inherit;}
.to-area .row.fm .col { background: #fdf1dd}


.ref { background: #5cba14; height: 90%; color: #fff; text-align: center ; font-size: 13px ; border-radius: 5px ;position: absolute; width: 8.333%; padding:0px ; min-width: 20px;}
.rf-box { position: absolute;height: 90%; margin-top: 5px; /* background: repeating-linear-gradient(45deg, #fdfdfd, #d3d3d3 10px, #e4e4e4 0, #ededed 20px); */ }
.rf-box span { height: 100%}
.rf_00,.rf_01,.rf_02,.rf_03 { left: 0px;height: 100% }
.rf_04,.rf_05,.rf_06 { left:8.8888%}
.rf_07,.rf_08,.rf_09 { left:17.7777%}
.rf_10,.rf_11,.rf_12 { left:25%}
.rf_13,.rf_14,.rf_15 { left:33.3333%}
.rf_16,.rf_17,.rf_18 { left:41.6%}
.rf_19,.rf_20,.rf_21 { left:49.5%}
.rf_22,.rf_23,.rf_24 {left:50%}

.ref.ata { background:#aaaa0f ;}

.cell-pop { width: max-content; background: #ffffff !important; border: 1px solid #a6a6a6; z-index: 999 !important; position: absolute; padding: 8px 15px; color: #656565 !important; margin-top: 15px; margin-left: 15px; height: initial !important; border-radius: 5px;}
.cell-pop b {}
.cell-pop label {color: #0c355f; margin-left: 10px;  display: block;}
.cell-pop label + b { margin-left: 20px;}
/*.rep-box { position: absolute;height: 90% ;margin-top: 5px ; background: repeating-linear-gradient(45deg, #fdfdfd, #ebebeb 5px, #e4e4e4 0, #ededed 5px)}*/
.row.rep-box .col { position: relative!important ; }
.row.rep-box .col span { position: absolute ; color: #fff ;height:90%; display: block ; font-size: 13px; text-align: center; background: #a9d055 ;display: flex; justify-content: space-around;  align-items: center;}
.row.rep-box .col span.under { left:0% ;background: #a9d055; width: 22px ; border-radius: 5px ; padding: 5px 3px}
.row.rep-box .col span.over { right:0% ;background: #a9d055;  width: 22px ; border-radius: 5px}
.row.rep-box .col span.color1 {background: #78cbff}
.to-area .row.rep-box .col span {  background: #ee9555; display: flex; justify-content: space-around; align-items: center;}

.per01,.per02,.per03,.per04,.per05,.per06,.per07,.per08,
.eta,.etb,.etd,.arrival
{ background: #a9d055; height: 90%; color: #fff; text-align: center ; font-size: 13px ; border-radius: 5px ;width: 20px; padding:0px ;position: absolute ; height: 88% ;}

.arrival { background: #37b23c !important; border:2px solid #118716 ;}
.arrival2 {background:#2999df!important }
.rep-box:has(.arrival) {}

.datepicker td, .dow { border: 1px solid #b5baca!important;}
.input-daterange .form-control { width: 140px; background: url(/images/icon_calendar.png) no-repeat; background-position: right 5px bottom 5px; flex-grow: 1; padding: 0 10px;}
.datepicker .datepicker-switch { width: 145px; color: #195fa8;}
.datepicker td, .datepicker th { width: 35px!important;}
.form-control.to + .fm { margin-left: -1px; flex-grow: 1;}

.pop_wrap header { background: #F6F6F6; overflow: hidden ; border-bottom: 1px solid #CCCCCC ; position: relative;}
.pop_wrap header >.row {color:#2585A8 ; padding: 5px; padding: 0 50px; }
.pop_wrap header >.row >.col {   font-size: 16px}
.pop_wrap header >.row > .col:nth-child(2) { margin-left: -80px;}
.pop_wrap header >.row:last-child { margin-bottom: 10px;}
.pop_wrap header >.row >.col span { font-weight: normal ;font-size: 14px ;color: #999 ; margin-right: 10px}

.skd-sum { font-size: 30px ; color:#2585A8 ; float: left ; font-weight: bold;}

.condition { width: 100%; padding-bottom: 10px; }
.condition > a {background:#fff; margin-top:10px; display: inline-block; padding: 5px 15px 3px 10px;  border: 1px solid #c6c8c8 !important; border-radius: 20px; font-size:14px;}
.condition > a + a { margin-top: 5px; border-top: 1px solid #b4dcea;}
.condition > a.disabled { opacity: 0.4;}
.condition > a::before { vertical-align: middle;}
.condition > a.radar::before {  content: ""; background: url(../images/icon_weather.png) no-repeat 0px -48px; width:30px; display: inline-block; height: 20px;}
.condition > a.temperature::before  { content: ""; background: url(../images/icon_weather.png) no-repeat 3px 0px; width: 30px; display: inline-block; height: 20px;}
.condition > a.airPressure::before  { content: ""; background: url(../images/icon_weather.png) no-repeat  0px -92px ;width:30px; display: inline-block; height: 20px;}
.condition > a.typhoon::before {content: ""; background: url(../images/icon_weather.png) no-repeat 0px -135px ; width:30px; display: inline-block; height: 20px;}

.condition > a.currents::before { content: ""; background: url(../images/icon_wind.png) no-repeat 5px 0px  ; width:30px; display: inline-block; height: 20px;}
.condition > a.wind::before { content: ""; background: url(../images/icon_wind.png) no-repeat 5px -40px ; width:30px; display: inline-block; height: 20px;}

.x_btn { width: 30px; height: 30px; z-index: 99; right: 10px; top: 15px; background: url(../images/icon_menu.png) no-repeat -0px -373px;font-size: 0; cursor: pointer; position: absolute;}
.input-daterange {display: flex;  align-items: flex-end;}

/*ship info*/
.ship_photo.tml_info li { float: left;border: none; padding-top: 10px; padding: 0px 0px 8px 10px;}
.ship_photo.tml_info p { border-bottom: 1px solid #c6d5e2; padding: 0;padding-bottom: 10px;}
.ship_photo.tml_info p > span { font-size: 20px!important; padding: 5px; font-weight: bold;}
.ship_photo.tml_info.tml_bg span { display: inline-block; }
.ship_photo { max-width: 600px; height: max-content; }
.ship_photo.tml_info { padding: 10px 15px 0 5px!important;}
.ship_photo img { width: 100%;  height: 350px!important;}
.ship_photo .slick-slide img { width: 480px; height: 250px; margin: 0px;}
.ship_photo .btn-set { display: flex; padding: 10px; background: #3bb1dd;}
.ship_photo button.com_btn { width: 50%; color: #fff; background: #3BB1DD !important; padding:4px; }
.ship_photo button.com_btn:first-child::before { content: ""; width: 25px; height: 25px; background: url(../images/icon_util.png) no-repeat -105px -75px; display: inline-block; vertical-align: middle;  margin-right: 8px;}
.ship_photo button.com_btn:nth-child(2)::before { content: ""; width: 25px; height: 25px; background: url(../images/icon_util.png) no-repeat -164px -75px; display: inline-block; vertical-align: middle;  margin-right: 8px;}
.ship_photo.tml_info > ul { display: flex; flex-direction: column;border: none;padding: 5px;}
.ship_photo.tml_info > ul li { width: unset;}
.ship_photo .btn-set button + button {border-left: 1px solid rgb(255 255 255 / 30%);}
.zoomin { position: absolute; width: 97%; height: 95%; left: 20px; z-index: 999; overflow: hidden; background-color: #ffffff; text-align: center; margin-top: 10px; border: 1px solid #b4dcea;}
.zoomin img { height: 100%;}

.noimg { background: url(../images/no_img.png) center; background-size: cover;  width: 100%;  }
.vssl_info .noimg { height: 240px;}
.tab-pane .carousel-inner > .noimg {height: 350px;}
.tml_bg { background: #ecf4fb; overflow: hidden;}
.tml_info {  padding: 20px 15px 0px 0px; }
.tml_info ul {border-radius: 5px;border: 1px solid #95cce0;padding: 5px 20px;}
.tml_info ul + ul { margin-top: 10px;}
.tml_info ul li { list-style: none; font-size: 13px; color: #3e637d ; line-height: 20px;}
.tml_info ul li span { display: inline-block; font-size: 15px;color: #000; position: relative; margin-left: 10px;}

.tml_info p span { font-size: 0px; display: block; color: #2494be;}
.tml_info ul li span::before { content: ":"; margin-right: 10px;}

.amp { display: flex; white-space: nowrap; padding: 15px;align-items: center;}
.amp input {margin: 0 10px;}
li.nth_bg + li.nth_bg { border-left: 1px solid #c6d5e2;}
.sort_line { border-bottom: 1px solid #c1c9d9;  padding: 0px 0 10px 0px!important;}

/*r-slide*/

.r-slide { width: 550px; background-color: #fff; z-index: 1500; position: absolute; left: 0; right: 0; box-shadow: -2px 0px 5px 3px rgb(0 0 0 / 27%); height: 100%; position: absolute; top: 0;}
.r-slide .close_btn { width: 30px; height: 30px;position: absolute;z-index: 99; right: 15px!important;top:20px; background: url(/images/icon_menu.png) no-repeat -0px -373px; font-size: 0; left: unset;  border-left: none;  cursor: pointer;}
.r-slide .badge { margin-right: 10px; color: #999; font-size: 14px;}
.r-slide .cg_info.detail { position: relative ;}
.r-slide .port_info .port_grp {  position: absolute;   right: 10px; top: 30px;}

.port_info h4 { padding: 12px 25px; margin-bottom: 0px; background: #1d46a1; color: #fff; font-size: 1.75rem; border-radius: 5px;}
.info_iner { padding: 10px 3px !important; } /* Port Status */
.info_iner.vol dl dt { margin-left: 10px!important; margin-right: 0px;}
.info_iner { padding: 10px 3px !important; margin: 0px; background:#eff9f9!important; overflow: hidden; padding: 10px 3px !important; display: flex; justify-content: space-around;} 
.cg_info.bi.sel .info_iner { background: #fff !important}

.alrm_info { display: flex; }

.info_iner dl + dl { border-left: 1px solid #a6bfbf; padding-right: 5px;}
.cg_info dl dt { font-weight: normal; font-size: 12px; margin-right: 10px; padding-left: 0; color: #757575; white-space: nowrap;}
.cg_info.detail { background: #fff; margin-bottom: 15px;padding: 10px; margin-bottom: 15px; border-radius: 8px; border: 1px solid #dacccc;}
.cg_info.bi.sel { border:1px solid #3a68d1 !important; border-radius: 8px; box-shadow: 0 0 0 1px #3a68d1 inset;  background: #eff2f9;}   
.cg_info.bi.sel .location {background: #3a68d1;}
.cg_info dl dt.location { color: #fff!important; background: #bbbcbc;; margin-right: 15px; border-radius: 20px;}
.cg_info.bi > dl > dt, .cg_info.bi > dl > dd { display: inline-block;padding: 2px 10px;}
.cg_info.sel dl dd.city { color: #1b3f8e; font-size: 18px;}
.cg_info dl dd.city { font-size: 18px; color: #848889; line-height: 24px;}
.cg_info dl dd { font-weight: bold;}

.tab-group { margin-top: 15px; display: block; margin: 10px 15px; }
.nav.nav-tabs { border-bottom: 1px solid #3a68d1;}
.nav-tabs .nav-link { color: #999;  padding: 5px 15px; border-radius: 8px 8px 0 0;}
.nav-item a.nav-link.active { border: 1px solid #3a68d1!important; border-bottom: 1px solid #fff!important; color:#3a68d1;}

/*photo thumnail*/
.ship_thum { position: relative;}
.ship_thum > button { position: absolute ; right: 10px; top: 10px;}

/* Grid */

.tui-grid-container {font-family: 'Roboto','Noto Sans KR', 'helvetica', sans-serif!important;font-size: 14px;}
.tui-contextmenu { z-index: 999 !important; display: none;}
.tui-grid-table  { width: 100%; margin-bottom: 15px;  }
.tui-grid-header-area { border-color: #89baca;}
.tui-grid-body-area .tui-grid-table tr:nth-child(even) td { background-color: #e6f3f7!important}
.tui-grid-cell { background-color: #fefefe!important ; }
th.tui-grid-cell.tui-grid-cell-headerh[data-column-name=CRR_ETD] {}
.tui-grid-cell-content:has(button) { display: flex;align-items: center; justify-content: space-between;}
.tui-grid-cell.tui-grid-cell-header { background: #c4d6ff!important; border-color: #b4bfdb !important; }
.tui-grid-body-area .tui-grid-table tr:nth-child(even) td.selected, .tui-grid-cell.selected { background-color: rgb(176 242 255 / 60%) !important; }

#mainGrid td[data-column-name=VSL_NAME] div::after { width:25px; height:25px ;border:1px solid #2585A8 ; font-size: 0px; background: url(../images/icon_ship.png) no-repeat center #fff; border-radius: 3px; content: ""; position: absolute ; right: 5px;}
#mainGrid td[data-column-name=SLAN_CD] div::after { width:25px; height:25px ;border:1px solid #68A21B; font-size: 0px; background:url(../images/icon_route.png) no-repeat center #fff;border-radius: 3px; content: ""; position: absolute; right: 0px; }
#mainGrid td[data-column-name=PRE_PORT] div span::after { margin-left: 7px; width:25px; height: 25px ;border:1px solid#D68B2B; font-size: 0px; background:url(../images/icon_port.png) no-repeat center #fff;border-radius: 3px; content: "";}
#mainGrid td[data-column-name=CRR_CD] div::after { width:25px; height: 25px ;border:1px solid#5C3DC7; font-size: 0px; background:url(../images/icon_schedule.png) no-repeat center #fff;border-radius: 3px; content: "";}
#mainGrid td[data-column-name=CRR_CD] div.disabled::after { width:25px; height: 25px ;border:1px solid#c8c8c8; font-size: 0px; background:url(../images/icon_schedule2.png) no-repeat center #fff;border-radius: 3px; content: "";}

#mainGrid td[data-column-name=VSL_NAME] .tui-grid-cell-content,
#mainGrid td[data-column-name=SLAN_CD] .tui-grid-cell-content,
#mainGrid td[data-column-name=PRE_PORT] .tui-grid-cell-content span,
#mainGrid td[data-column-name=CRR_CD] .tui-grid-cell-content{ display: flex;align-items: center; justify-content: space-between;}

/* Modal */
.modal-header { background:#038cbf; color: #fff;}

.nav-pills .nav-link { padding: 8px 40px;color: #999;  overflow: auto;}
#cargoeye-maps { height: calc(100% - 60px);}
#management-maps { height: calc(100% - 60px);}

.tab-group > .tab-content { height: 100%;}
.tab-content .tab-content {padding: 15px 0; height: 100%; }
.tab-content >.active { display: block; height: calc(100% - 50px)!important; }
.tab-content .col-4.p-fx { }
.tab-content >.active { display: block; overflow-x: hidden; }
.tab-content .col-4.p-fx { }
.tab-content .container-fluid , .tab-content>.active, .tab-content .row { height: 100%;}
.tab-content>.tab-pane + .tab-pane {  overflow-x: hidden;}
.nav.nav-pills { margin-bottom: 0px!important; border-bottom: 2px solid #038cbf; padding-left: 20px;}
.nav-pills .nav-link.active, .nav-pills .show>.nav-link { border-radius: 8px 8px 0 0 ; box-shadow: 0px -3px 10px -3px rgba(0,0,0,0.25)!important; clear: both;}
button.nav-link.active { background: #fff!important; color: #038cbf!important; border: 1px solid #038cbf; border-bottom: 1px solid #fff; margin-bottom: -2px; font-weight: bold;}
.tab-content .scrollbar { overflow-y: auto;}
.tab-content .scrollbar { overflow-y: auto;}
.swal2-popup { border-radius: 10px;}
/*Scroll custom*/
.scrollbar { overflow: auto; padding: 0px 10px 15px 15px; clear: both;}
.scrollbar::-webkit-scrollbar { width: 6px;}
.scrollbar::-webkit-scrollbar-track { background-color: transparent;}
.scrollbar::-webkit-scrollbar-thumb { border-radius: 3px; background-color:#5572e0;;}
.scrollbar::-webkit-scrollbar-button { width: 0; height: 0;}
.scroll-container.scrollbar { padding: 0; max-height: 750px; }

/* Common */
.hide { display: none;}
.show { display: block;}
.a-c { text-align: center;}
.a-r { text-align:right;}
.form-control, .form-select { box-shadow: none!important ; border-radius: 3px!important}
.input-group.date input { }
.input-group-addon { font-size: 0px; background: none; background: url("../images/icon_calendar.png") no-repeat center}
.form-check-input[type=checkbox] { border-radius: 0.25em; width: 16px; height:16px; border-radius: 3px;}
.form-check { display: inline-block;}
.form-check + .form-check { margin-left: 15px; }
.form-check label { vertical-align: middle;; cursor: pointer;font-size: 13px; letter-spacing: -0.5px;}
#cargoeye-tooltip { position: absolute; z-index: 999; background: rgb(21 46 102 / 70%); color: #fff; font-family: sans-serif; font-size: 11px; padding: 0px 15px 10px; pointer-events: none; border-radius: 10px; box-shadow: 3px 3px 5px -2px rgba(0,0,0,0.41); }
#cargoeye-tooltip h5 { font-weight: bold;padding: 10px 0; margin-bottom: 10px; border-bottom:1px solid #6e8dba}
#cargoeye-tooltip::after {content: ""; position: absolute; top: 100%; left: 50%; margin-left: -5px; border-width: 7px; border-style: solid; border-color:#2d6494 transparent transparent transparent;}

button + button { margin-left: 5px;}
button.ship { width:25px; height:25px ;border:1px solid #2585A8 ; font-size: 0px; background: url(../images/icon_ship.png) no-repeat center; border-radius: 3px;}
button.route { width:25px; height:25px ;border:1px solid #68A21B; font-size: 0px; background:url(../images/icon_route.png) no-repeat center;border-radius: 3px;}
button.port { width:25px; height: 25px ;border:1px solid#D68B2B; font-size: 0px; background:url(../images/icon_port.png) no-repeat center;border-radius: 3px;}

button.btn { height: 30px; background: #008abd; padding: 5px 15px; color: #fff; border-radius: 3px;}
button.com_full { height: 30px;font-size: 0px; position: absolute; width: 30px; z-index: 998; right: 5px; border-radius: 3px; top: 20px; background: url(../images/icon_zoomin.png) no-repeat center #015878;}
button.com_out { height: 30px;font-size: 0px; position: absolute; width: 30px; z-index: 999; right: 5px; border-radius: 3px; top: 10px; background: url(../images/icon_zoomout.png) no-repeat center #015878;}
button.btn:hover { border: 1px solid #008abd; color:  #008abd; background:#3a68d1;} 

button.exc { background: url(../images/icon_excel.png) no-repeat center #3a68d1;  padding: 5px 15px; font-size: 0px; height: 30px; border-radius: 3px; }
button.exc:hover,button.exc:active  { background: url(../images/icon_excel.png) no-repeat center #5cb8da; font-size: 0px;}

button.src { background: url("../images/icon_menu.png") no-repeat #3a68d1  -50px 5px;  width: 30px; height: 30px ; font-size: 0px ; float:right ; margin-top:-3px; border-radius: 3px;
    margin-left: 5px;}
button.src:hover {background: url("../images/icon_menu.png") no-repeat #5cb8da -50px 5px}
button.sm-ic {font-size:0px ; border:1px solid #3a68d1}
button.sm-ic.ship {background: url(../images/icon_menu.svg) no-repeat -35px -37px #fff;background-size: 600%;}
button.sm-ic.weather2 {background: url(../images/icon_menu.svg) no-repeat -37px -262px #fff ;background-size: 600%;}

div.footer-area { position: absolute;bottom: 30px; right: 10px; z-index: 999; }
div.footer-area .btn-set {display: flex; justify-content: center; flex-direction: column; align-items: center; letter-spacing: -0.5px; font-weight: bold; text-shadow: -1px -1px 0 #ffffff, 1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px 1px 0 #ffffff;;}
div.footer-area button { font-size: 14px; border-radius: 3px;box-shadow: 0px 0px 20px 5px rgba(0,0,0,0.16); width: 45px; height: 45px; border-radius:100%;}
div.footer-area button.vsl-list { background: url(../images/icon_vsl-list.svg) no-repeat center #fff ; border: 1px solid #0b1865;}
div.footer-area button.chat { background: url(../images/icon_chat.svg) no-repeat center #D81D69 ; }
div.footer-area .btn-set:has(.vsl-list) { color: #0b1865; ;}
div.footer-area .btn-set:has(.chat) { color: #D81D69; }


/*tab - tracking MAP FULL SCREEN*/
.col-sm-12.map .col-4 { position: absolute; width: calc(100% - 30px); margin-top: -40px;left: 15px; height: calc(100% - 50px); background-color: #fff;}
.col-sm-12.map .col-4 .input-daterange,.col-sm-12.map .col-8 .tui-grid-container { display: none; }

.col-4.p-fx button.com_full { right: 20px; top: 120px;}
.col-4.p-fx button.com_out {  display: none;}
.col-sm-12.map .col-4.p-fx button.com_full { display: none;}
.col-sm-12.map .col-4.p-fx button.com_out { display: block;  right: 20px; top: 80px;}

#cargoeye-maps-l-info { font-size: 12px; width: 125px; height: 50px; text-align: center; position: absolute; top: 10px; left: 15px; padding: 5px; background-color: rgb(255 255 255 / 40%); border-radius: 5px; box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2); z-index: 777; color: #000; text-shadow: unset; }
#cargoeye-maps-r-info span { display: block; }
#cargoeye-maps-r-info { font-size: 12px; width: 200px; height: 60px; text-align: center; position: absolute; top: 10px; right: 50px; padding: 3px 5px;  background-color: rgb(255 255 255 / 40%);box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2); z-index: 9999; padding-top: 5px; color: #000; border-radius: 5px;text-shadow: unset; }

#management-maps-l-info { font-size: 12px; width: 125px; height: 40px; text-align: center; position: absolute; top: 10px; left: 15px; padding: 3px 5px; background-color: rgb(255 255 255 / 40%); border-radius: 5px; box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2); z-index: 777; color: #000; text-shadow: unset; }
#management-maps-r-info span { display: block; }
#management-maps-r-info { font-size: 12px; width: 200px; height: 60px; text-align: center; position: absolute; top: 10px; right: 50px; padding: 3px 5px;  background-color: rgb(255 255 255 / 40%);box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2); z-index: 9999; padding-top: 5px; color: #000; border-radius: 5px;text-shadow: unset; }

.tml-legend { float: left; margin: 15px 10px 10px 20px}
.tml-legend + .src_box + .form-group { margin: 15px 10px 10px 15px;}
.item01,.item02  { display: inline-block; }
.item01 span,.item02 span  {display: inline-block; width: 20px ;height: 20px; vertical-align: bottom; font-size: 0; margin-right: 5px; border:1px solid #aaaaaa; }
/*[class*='item'] span { display: inline-block; width: 20px ;height: 20px; vertical-align: bottom; font-size: 0; margin-right: 5px; border:1px solid #aaaaaa;} */
.item01 span { background: #e7fcc9; border-radius: 3px;} 
.item02 span { background: #eaeaea; border-radius: 3px;} 
.swal2-title { font-size: 1.5em;}
.carousel-control-next, .carousel-control-prev { opacity: 1!important;}

.b-btm { border-bottom: 1px solid #b4dcea }
.p-fx { position: relative}
.fl_l { float: left;}
.fl_r { float: right;}
.t-red { color: red;}
.pd_t0 { padding-top: 0!important;}
.mg-t5 { margin-top: 5px!important}
.mg-t10 { margin-top: 10px!important}
.mg-t15 { margin-top: 15px!important}
.mg-t20 { margin-top: 20px!important}

.mg-b10 { margin-bottom: 10px!important}


/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
    .login_c {height: 30%!important}
	.left-box { height:200px!important ; width: 100%!important; margin-top: 0!important;}
	.card-port li { width:100%!important}
    .ship_photo.p-fx { width: 100%; }
    .col.respon { position: unset;  width: 100%;  }
}



/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (max-width: 768px) {
    .login_c { background: url(../images/bg_login.png) no-repeat left -50px; background-size: cover;height: 35%!important;}

    .login_c form { width: 100%!important ; }

	.card-port li { width:100%}
	.card-port li p { font-size: 13px;    white-space: pre-line;}	
}

/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (max-width: 992px) {
    .login_c h1 strong  { color: #075F80;;}
	.card-port li { width:42%}
	.navi + .main {margin-left:0px ; width: 100%;}
    .login_c {background: url(../images/bg_login.png) no-repeat left -300px; height: 38%; position: absolute; width: 100%;}
	.login-wrap { position: unset; margin: 0 auto; width: unset; box-shadow: none; width: 100% !important ; } 
    .left-box { float: unset; margin: 0 auto; width:90%; background: none;  height:200px;;}
    .login_c form { float: unset;width: 100%!important ; }
    
    .login_c h1 { color: #ffffff; font-weight: bold; text-align: center; text-shadow: 2px 2px 3px rgba(0,0,0,0.47);}
    .left-box p { }

}

@media only screen and (max-width: 1200px) {
	header { display: grid;}
	.skd-sum { text-align: left ; padding: 10px; border-right: none ; max-width: 100%!important;}
	.row.mg-t20 {margin-top: 0px!important}
    .col:has(.skd-sum) { border-bottom: 1px solid #ccc; }
 
 .tab-content .col-4.p-fx  { width: 100%; height:300px;} /*overflow: hidden; 날짜 검색이 위로 가려짐*/
 .tab-content>.tab-pane + .tab-pane .col-sm-5 { width: 100%; float: left; } /*tab 02 width 100%*/
 .tab-content .col-8  { width: 100%; height: 60%;}
 .tab-content>.tab-pane > .row , .tab-content>.tab-pane > .row > .row {  --bs-gutter-x:0!important;}
 .tab-content>.tab-pane:nth-child(2) .col-sm-5 { width: unset}
 .tab-content>.tab-pane > .row > .row {  --bs-gutter-x:0!important;}
 .tab-content>.tab-pane:nth-child(2) .col-sm-5 { width: unset}
 .tab-content>.tab-pane > .row > .row {  --bs-gutter-x:0!important;}
 .tab-content>.tab-pane:nth-child(2) .col-sm-5 { width: unset}
 .tab-pane .ship_photo  { width: 100%;padding: 0px;margin-top: 15px;}
 .ship_photo.tml_info { max-width: unset;margin-top: 15px; }

 .tab-content .container-fluid, .tab-content>.active, .tab-content .row { --bs-gutter-x: 0;}
 .col-sm-12.map .col-4 { height: 100%!important; overflow: hidden; width: calc(100% - 25px); margin-top: -50px; }
 .col.respon .tml_info { padding: 0; float: right; margin-left: 10px;width: 100%;}

 .col.respon { width: 50%; float: right;  margin-top: 15px;}
 .amp { width: 100%; padding: 15px 0px; }
 div#cargoeye-maps { width: 100%; }
 .col-4.p-fx button.com_full,.col-sm-12.map .col-4.p-fx button.com_out { right: 10px; }
 .modal-dialog-scrollable .modal-body { overflow: hidden;}
 .tab-pane.scrollbar { overflow-x: hidden;}
}

@media (min-width: 992px) {
.modal-lg, .modal-xl {
    --bs-modal-width: 90%;}
}

@media (min-width: 1200px) {
.modal-xl {
    --bs-modal-width:95%!important ;  --bs-modal-margin: 0rem !important;}
    .col-sm-12.map .col-4 { height: 100%!important; margin-top: -40px;}
}

/* 2024.01.19 kobc */
.port_grp {margin-left:20px;display: inline;}
.port_grp .btn{display: inline;}
.kobc iframe#tmlIframe,
.kobc iframe#wthIframe{ position: absolute;z-index: 99999;left: 550px; width: calc(100% - 550px); }
#mainPage span.close_btn,
#portWeatherPage span.close_btn,
#portVslListPage span.close_btn {
    display: block;
    width: 30px;
    height: 30px;
    background: url(../images/icon_menu.png) no-repeat -55px -408px;
    margin-top: -42px;
    float: right;
    cursor: pointer;
    margin-right: 12px;
  }
  
#portWeatherPage td[data-column-name=WIND_DIR] span { display: inline-flex; }
#portWeatherPage td[data-column-name=WIND_DIR] label { padding: 3px 0px 0px 8px; font-size: 11px; color: #9a9a9a; }

#mainGrid .tui-grid-header-area tr:nth-child(3) th{font-weight: normal;font-size: 10px;background: #cce1e8 !important;color: #6c8d98;}

#mainGrid td[data-column-name=DATE_DATE] { background-color: #fefefe!important; }

.geofence input[type=text],
.geofence input[type=password],
.geofence select { display: inline-block; width: unset; }
.geofence textarea { resize: none; min-height: 80px; width: 95%; }
td[data-column-name=portGeoEdit] i,
td[data-column-name=locGeoEdit] i { padding: 10px; cursor: pointer; }

.leaflet-draw, .leaflet-draw-tooltip{ display: none !important;}
 
.dropdown-btn{ width: 30px; height: 30px; border-radius: 5px; background-color: #ffffff; color: #000; padding: 3px; }
.dropdown-btn:focus { background-color: #e6f3f7; color: #4a88d0; }
.dropdown-toggle::after{ display: none;}
.dropend .dropdown-toggle::after{ display: none;}

.leaflet-editing-icon { margin-left: -5px !important; margin-top: -5px !important; width: 10px !important; height: 10px !important; border-radius: 5px; }
.cargoeye-map-layer { position: absolute; top: 60px; left: 15px; z-index: 777;}
.cargoeye-map-layer button.dropdown-toggle {font-size: 17px; width: 38px; height: 40px; text-align: center; padding: 3px 5px; background-color: rgb(255 255 255 / 40%); border-radius: 5px; box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2); z-index: 777;}
.cargoeye-map-layer .form-check-input[type=checkbox] { width: 20px; height: 10px; border-radius: 20px; margin: 5px 0px 0px -25px}

ul.layer { background-color: rgb(255 255 255 / 40%) !important; border-radius: 5px; box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2) !important; border: none; margin-left: 5px !important; }

.port-side {position: absolute; width: calc(100% - 620px); left: 620px;z-index: 9999;}
.tui-grid-cell-header {color: #040e27;  font-weight: 500 !important; }

#portCallGrid .tui-grid-cell-has-input .tui-grid-cell-content {font-size: 11px;}
#mainGrid .tui-grid-cell-has-input .tui-grid-cell-content {font-size: 12px;}

span.highlight{ background: #fff8bb;padding: 1px; font-weight: bold; }


.src_box { padding-left:15px; overflow: hidden; white-space: nowrap;}
.src_box label { color: #fff; margin-right: 7px;  margin-top: 5px;}



/*DATEPICKER-- calendar*/
.datepicker table {font-family: 'Monda',"Nanum Gothic",sans-serif ,Helvetica Neue;}
.datepicker.dropdown-menu th, .datepicker.dropdown-menu td {  padding: 7px 10px;}
.datepicker th.datepicker-switch { width: 145px;color: #195fa8;  font-size: 16px; }
.datepicker table tbody td,.datepicker table thead th.dow {  border: 1px solid #b5baca;}
.datepicker-dropdown { z-index: 9999 !important; }

.total { color: #385dcc; font-weight: 600; }

div#tmlMap { width: 100%; height: 100%; }

.msg-box { z-index: 999; position: absolute; left: 50%!important; top: 50%; margin-left: -150px; margin-top: -25px;height: 40px; width: 300px; text-align: center; background-color: #fff; border-radius: 5px; box-shadow: 0 2px 7px 1px rgb(0 0 0 / 30%); }
.msg-box label { padding: 10px; }
.msg-box span { color: #506ab9; margin-right: 10px; }

button.route, button.port, button.ship { float: right; }

.ship_photo .slick-slide  img { width: 480px; height: 200px; margin: 0px; justify-content: center; display: flex; }
.ship_photo img { width: 100%; height: 300px;}
.ship_photo .ship_thum div#vslThmb img { width: 100%; height: 60px;}

/** Slick */
.bs-position-cover { position: absolute; top: 0; bottom: 0; left: 0; right: 0; }
.bs-overlay { display: inline-block; position: relative; max-width: 100%; vertical-align: middle; overflow: hidden; -webkit-transform: translateZ(0); margin: 0; }
.bs-overlay:hover .bs-overlay-panel.bs-overlay-top { bottom: 0; opacity: 1; -webkit-transform: translateX(0) translateY(0); transform: translateX(0) translateY(0); }
.bs-overlay-panel.bs-overlay-top { top: auto; }
.bs-overlay-background { background: rgba(0,0,0,.8); -webkit-transform: translateY(100%); transform: translateY(100%); opacity: 0; transition-duration: .3s; transition-timing-function: ease-out; transition-property: opacity,transform,filter; }
.bs-overlay-panel { position: absolute; top: 0; bottom: auto; left: 0; right: 0; padding: 20px; color: #fff; }
.bs-overlay>:first-child,
.bs-overlay-panel>:last-child { margin-bottom: 0; }
.bs-overlay:hover{ cursor: pointer; }
.slider-nav-thumbnails { margin-top: 10px; }
.slider-nav-thumbnails .slick-slide { cursor: pointer; outline: none; }
.slider-nav-thumbnails .slick-slide.slick-current.slick-active { opacity: 1; }
.slider-nav-thumbnails .slick-slide img { padding: 2px; background: transparent;; }
.slider-nav-thumbnails .slick-slide.slick-current.slick-active img { border: solid 2px #b4d7ff; border-radius: 1px; }
.slider-nav-thumbnails img { width: 40px; margin: 0 5px; }
.slider-nav-thumbnails .slick-slide:first-child img { margin-left: 0; }
.slider-nav-thumbnails .slick-slide:last-child img { margin-right: 0; }

#dtlFlag label { width: 26px; height: 20px; position: relative; border: 1px solid #777;margin-top: 5px; }



#vslInfo .zoomin img { width: 100%; height: 100%;}

.tui-grid-layer-selection { background-color: #00d5ff !important; border: none !important;}



#mainGrid th[data-column-name=CRR_UPD] { background: url(../images/icon_time.png) no-repeat 15px 5px #a9c4d2!important;font-size: 0px;}
#mainGrid th[data-column-name=TML_UPD] { background: url(../images/icon_time.png) no-repeat 15px 5px #89dbf9!important; font-size: 0px; }
#mainGrid th[data-column-name=PTA_UPD] { background: url(../images/icon_time.png) no-repeat 15px 20px #c4a3e7!important; font-size: 0px; }
#mainGrid th[data-column-name=PILOT_UPD] { background: url(../images/icon_time.png) no-repeat 15px 20px #8989f9!important; font-size: 0px; }
#mainGrid th[data-column-name=AIS_ETA_UPD] { background: url(../images/icon_time.png) no-repeat 15px 20px #7baaef!important; font-size: 0px; }
#mainGrid th[data-column-name=NEXT_TML_UPD] { background: url(../images/icon_time.png) no-repeat 15px 20px #b0dbe9!important; font-size: 0px; }

#mainGrid th[data-column-name=ETB_DT], #mainGrid th[data-column-name=ETD_DT] { text-wrap: wrap; }

#mainGrid th[data-column-name=operator], #mainGrid th[data-column-name=CRR_ETA], #mainGrid th[data-column-name=CRR_ETB], #mainGrid th[data-column-name=CRR_ETD], #mainGrid th[data-column-name=CRR_UPD] {
    background-color: #a9c4d2!important;
}

#mainGrid th[data-column-name=terminal], #mainGrid th[data-column-name=TML_ETB], #mainGrid th[data-column-name=TML_ETD], #mainGrid th[data-column-name=TML_UPD] {
 background-color: #89dbf9!important;
 }

 #mainGrid th[data-column-name=ais], #mainGrid th[data-column-name=AIS_ATA], #mainGrid th[data-column-name=AIS_ATB], #mainGrid th[data-column-name=AIS_ATD] {
 background-color: #9ae5d5!important;
 }

 #mainGrid th[data-column-name=ETA_BUSAN], #mainGrid th[data-column-name=AIS_ETA_UPD] {
  background-color: #7baaef!important;
  }

  #mainGrid th[data-column-name=PTA_BUSAN], #mainGrid th[data-column-name=PTA_UPD] {
 background-color: #c4a3e7!important;
 }

  #mainGrid th[data-column-name=PILOT_DT], #mainGrid th[data-column-name=PILOT_UPD] {
 background-color: #b5b5f3!important;
 }

 .tui-grid-container ul.tui-grid-context-menu { display: none; }

 .modal{ background: rgba(0, 0, 0, 0.5); }
 .tab-content >.active { display: contents !important; }
 #mapPage { position: absolute; }
 #vslListPage { position: fixed; }
 #portVslListPage,#portWeatherPage { position: absolute; width: calc(100% - 550px); left: 550px; z-index: 9999;}
 #mapPage.half{ height: calc(100% - 300px) }
 #vslListPage.min{ height: 300px; bottom: 0; z-index: 999; }
 #vslListPage.max{ height: 100%; }
 #portVslListPage td[data-column-name=VSL_NAME] div::after { width:25px; height:25px ;border:1px solid #2585A8 ; font-size: 0px; background: url(../images/icon_ship.png) no-repeat center #fff; border-radius: 3px; content: ""; position: absolute ; right: 5px;}
 #portVslListPage td[data-column-name=VSL_NAME] .tui-grid-cell-content{ display: flex;align-items: center; justify-content: space-between;}
.track-bar { position: absolute; z-index: 99999; top: 10px; background-color: #ffffff; border-radius: 5px; border: solid 1px #f2eee7; margin-bottom: -10px; left: 50%; margin-left: -250px;}
.track-bar .sel-date { width: 400px; margin: 0 auto;}
#vslListPage .list-header {background: #1d46a1; font-size: 20px; color: #fff; width: 100%; padding:10px}
#vslListPage .list-body .min-btn button,
#vslListPage .list-body .max-btn button { font-size: 0px; width: 26px; height: 26px; float: right; background-color: unset; margin-top: 5px;}
#vslListPage .list-body button.win-min { background: url(../images/icon_window.svg) no-repeat  0px 5px; margin-right: 50px; background-size: 300%; top: 10px; position: absolute; right: 20px; }
#vslListPage .list-body button.win-max { background: url(../images/icon_window.svg) no-repeat -46px 0px; margin-right: 50px; background-size: 300%; top: 0px; position: absolute; right: 0px; width: 22px; height: 22px;}
#vslListPage .list-body button + button { margin-left:5px ; margin-right:20px}

#vslListPage .list-body .excel-btn { background: url(../images/icon_excel.png) no-repeat center #457e9300; margin-right: 50px; background-size: 60%; top: 10px; position: absolute; border: 1px solid #e5e5e5;  right: 60px; border-radius: 5px; }
#vslListPage .list-body { padding: 10px; }
#vslListPage .list-body .min-btn .x_btn { top: 10px; }
#vslListPage .list-body .max-btn .x_btn { width: 22px; height: 22px; background: url(../images/icon_menu.png) no-repeat -59px -412px; position: absolute; top: 0px; right: 0px; }

.datepicker-days table tr:nth-child(even) { background: unset;}

.typhoon-popup .col-sm-12 { color: #ffffff; font-weight: bold; background: #268ad0; border-radius: 4px; text-align: center; padding: 2px; }

#vslListGrid th, #vslListGrid td { font-size: 12px; color: #000 !important; }
th[data-column-name=PRI_WAVE_PERIOD], th[data-column-name=SIG_WAVE_HEIGHT]{white-space: break-spaces;}

.dot-icon { width: 8px; height: 8px; background: #fff; border: 2px solid #555555; border-radius: 30px; }
.port-dot-icon { width: 8px; height: 8px; background: #fff; border: 2px solid #13605b; border-radius: 30px;}
.port-icon { background: url(/images/map/port.png) no-repeat;}
.current-animation-icon { background: url(/images/map/current_ship.gif) no-repeat; background-size: 60px; }
.alert-animation-icon { background: url(/images/map/alert_ship.gif) no-repeat; background-size: 60px; }
.iot-icon { background: url(/images/map/iot.png) no-repeat; background-size: 13.5px; }
.ship-icon { background: url(/images/map/ship_container.png) no-repeat; background-size: 13.5px; }
.alert-icon { background: url(/images/map/ship_alert.png) no-repeat; background-size: 12.5px; }
.basic-icon { background: url(/images/map/mark.png) no-repeat; background-size: 24px; }
.current-iot-icon { background: url(/images/map/current_iot.png) no-repeat; background-size: 19px; }
.current-ship-icon { background: url(/images/map/current_ship.png) no-repeat; background-size: 19px; }
.detection-icon { width: 5px; height: 5px; border: 1px solid #f44336; border-radius: 30px; background-color: #e93c30; }

.unread .tui-grid-cell-content::after {content:"";background: url(/images/icon-alarm.png) no-repeat;background-size: 18px;position: absolute;width: 18px;height: 18px;margin-top: 1px;margin-left: 5px;}
.tui-grid-cell-content span.badge {font-size: 11px;}


.fleet-grp { padding-top: 20px; padding-left: 15px;}
.fleet-grp > span { font-size: 18px; color: #1863b7; font-weight: bold; padding-right: 5px; }
.fleet-grp > p { font-size: 14px; padding: 5px; word-wrap: break-word; white-space: pre-wrap; min-height: 40px; max-height: 70px; overflow-y: scroll; text-overflow: ellipsis;}
.fleet-grp p::-webkit-scrollbar { display: none; /* 크롬, 사파리, 엣지 */ }
.fleet-grp p { -ms-overflow-style: none; /* IE, Edge */ scrollbar-width: none; /* Firefox */ }

.sidebar {
    padding: 10px ; 
    z-index: 1;
    width: 250px;
    flex-shrink: 0;
    overflow: hidden;
}

.sidebar .scroll-container { height: 600px }
.sidebar .group-contents { max-height: 100%; overflow-y: auto; }
.sidebar .group-contents::-webkit-scrollbar { display: none; /* 크롬, 사파리, 엣지 */ }
.sidebar .group-contents { -ms-overflow-style: none; /* IE, Edge */ scrollbar-width: none; /* Firefox */ }
.sidebar li { position: relative;float: left; width: 100%; list-style: none; transition: 0.5s; font-size: 15px;}
.sidebar li li { border-top: none;}
.sidebar li:first-child { border-top: none;}
.sidebar ul > .sub:not(:first-child) > a:after { pointer-events: none; position: relative; float: right; content: '';  margin-top: 7px; vertical-align: middle; transition: 0.5s; width: 0.5rem; height: 0.5rem; border-bottom: 1px solid currentColor; border-left: 1px solid currentColor; transform: rotate(-45deg) translate(50%, 0%); -webkit-transform: rotate(-135deg); transform-origin: center center; transition: transform ease-in-out 100ms; margin-right: 1rem;}
/* .sidebar li.lock { background: url(../images/img_lock.png) no-repeat 260px 13px} */
/* .sidebar.active li.lock::after { content:""; background: url(../images/img_lock.png) no-repeat 0px -34px ; width: 18px;  height: 18px;  position:absolute; right: 10px; top: 30px } */
/* .sidebar li.lock a::after {display: none;} */
.sidebar input[type=checkbox] { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0;display: block; cursor: pointer;}


.sidebar li li:hover { background: #fff !important;}
.sidebar .submenu { border-radius: 8px ; max-height: 0; overflow: hidden; border-top: none; transition: max-height ease-in-out; display: grid;  position: relative; padding: 0px 10px;}
/* .sidebar ul li >.submenu { box-shadow: 0 0 0 1px #94d2e9 inset;} */

.sidebar input[type=checkbox]:checked ~ .submenu { max-height: 80%; border-radius: 8px ;padding: 0px; padding-bottom: 0px; padding-top: 10px; }
.sidebar input[type=checkbox]:checked ~ a:after { transform: rotate(-45deg)!important; }
.sidebar .submenu li.sub { list-style: none;padding-left: 45px; }
.sidebar .submenu .sub {
    padding: 5px 10px;
    background-color: #E6F3F7;
    border-radius: 5px;
    margin: 2px 0px;
}
.sidebar .submenu .sub.addGrp { background-color: #0f67a5 !important;}
.sidebar .submenu .sub.addGrp p { color: #fff; }
.sidebar .submenu .group-color {  
    display: inline-block;
    width: 15px;
    height: 15px;
    background-color: #3498db; /* 기본 색상 */
    margin-right: 10px;
    vertical-align: middle; 
    border: 1px solid #002d91; /* 테두리 설정 */
}

.main-fleet-grp .main-content { overflow: hidden;}
.main-fleet-grp .main-content .group-nm {  margin: 0 15px 0 5px; vertical-align: middle; }
.main-fleet-grp .main-content i { display: none;  cursor: pointer; padding-right: 5px; color: #1863b7;}

.page-content { overflow: hidden; }
.fleet-grp .group-color {  
    display: inline-block;
    width: 15px;
    height: 15px;
    margin-left: 5px;
    background-color: #3498db; /* 기본 색상 */
    vertical-align: middle; 
    border: 1px solid #002d91; /* 테두리 설정 */
}
.group-contents .sub:hover { background-color: #cde1fd; }
.group-contents .sub.clicked { background-color: #a7caff; }
.submenu .addGrp:hover { background-color: #cfcfcf !important; }

.sidebar > .sub .sub { padding: 5px; position: relative ; }
/* .sidebar > .sub .sub + .sub {border-top: 1px solid #b4dcea  } */
/* .sidebar > .sub .sub a {font-weight: bold; color: #3893b4; font-size: 14px;padding:5px ;display: flex; justify-content: space-between; padding:2px 0px} */
/* .sidebar > .sub .sub a::after {pointer-events: none; position: relative; float: right; content: '';  vertical-align: middle; transition: 0.5s; width: 0.4rem; height: 0.4rem; border-bottom: 1.5px solid currentColor; border-left: 1.5px solid currentColor; transform: rotate(-45deg) translate(50%, 0%); -webkit-transform: rotate(-135deg); transform-origin: center center; transition: transform ease-in-out 100ms; margin-top: 5px;} */
.sidebar > .sub .sub a.ui-jump::after { display: none;}
.sidebar > .sub .sub .submenu { border-top: none !important; padding: 0px }

#vesselModal .a-c { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 600px; margin: auto; }
#vesselModal .a-c span { flex-shrink: 0; margin-right: 10px; }
#vesselModal .a-c select { flex-shrink: 0; margin-right: 10px; width: auto; }
#vesselModal .a-c input { flex-grow: 1; margin-right: 10px; }
#vesselModal .a-c button { flex-shrink: 0; }
.modal .modal-btn { margin-top: 10px; }

.grp-frm { width: 60% !important; margin: 0 auto; }
.grp-frm label { font-weight: bold; }

.tui-grid-cell-content {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ui-widget.ui-widget-content.ui-autocomplete { max-height: 210px !important; background: #fff !important; z-index: 99999; }

.ui-autocomplete { width: 270px; max-height: 300px; top: 216px; left: 15px; border-radius: 10px; overflow-y: scroll;}
.ui-autocomplete .ui-state-active{border: none !important; background: none !important; color: #3b6ddd !important; font-weight: bold !important; }
.ui-autocomplete li{ padding: 4px 12px;}
.ui-autocomplete li:has(.ui-state-active) { background-color: #e8f5fa; }
.ui-autocomplete li label{width: 20px; height: 13px; display: inline-flex; background-repeat: no-repeat; vertical-align: middle;}

.btn-alarm { cursor: pointer; z-index: 9999; width: 30px ; height: 30px; background: url(../images/alarm.svg) no-repeat center #fff; right: 10px ; top:120px;position:absolute ; max-height: 750px; overflow: inherit; background-size: 70%;}
.btn-alarm span{float: right;background: #ffffff;border: solid 1px #E91E63;width: 18px;height: 19px;text-align: center;border-radius: 10px;font-weight: bold;font-size: 10px;color: #E91E63;overflow: hidden; // 너비를 넘어가면 안보이게text-overflow: ellipsis; // 글자가 넘어가면 말줄임(...) 표시;text-overflow: ellipsis; // 너비를 넘어가면 안보이게text-overflow: ellipsis; // 글자가 넘어가면 말줄임(...) 표시;}
.list-alarm { z-index: 9999; background: #fff ; width: 350px ; right: 10px ; top:120px;position:absolute ; max-height: 750px; overflow: auto;}
.list-alarm .ttl { padding:15px ; font-size:15px ; font-weight: bold ; border-bottom: 1px solid #DEDFE6}
.list-alarm .sel-alarm { border-bottom: 1px solid #DEDFE6 ; padding: 15px}
.list-alarm .form-check { display: inline-block ; }
.list-alarm .form-check + .form-check { margin-left:15px}
.list-alarm .form-check input[type=checkbox] {vertical-align: sub; }
.list-alarm li { position: relative ; padding: 10px 20px 20px; line-height: 30px ;overflow: hidden;}
.list-alarm li a { display:inline-block ; font-size: 0px ;position: absolute; right: 15px; top: 15px }
.list-alarm li a.new { background: url("../images/icon-alarm.png") no-repeat center ; width: 30px; height: 30px ; }
.list-alarm li a.read { background: url(../images/icon-read.svg) no-repeat center ; width: 30px; height: 30px}
.list-alarm li strong {}
.list-alarm li strong.vssl { border-radius: 30px ; background:#D2E1FE; padding:0px 12px ; margin-top: 10px ; text-align: center ; float: left ; font-size: 12px}
.list-alarm li .vssl-list { padding: 17px 0px 0px 14px; float: left ;line-height: 20px}
.list-alarm li strong.title:hover,
.list-alarm li .vssl-list p {cursor: pointer;}
.list-alarm li strong.title:hover,
.list-alarm li .vssl-list p:hover { text-decoration: underline; }
.list-alarm li + li { border-top: 1px solid #DEDFE6}
.list-alarm .ttl .close_btn { display: block; width: 30px; height: 30px; background: url(../images/icon_menu.png) no-repeat -55px -408px; float: right; cursor: pointer; margin-top: -3px;}
.list-alarm .alarm-info { font-size: 11px; display: inline-block; float: right; margin-top: 5px;}
.alarm-info b.unread-cnt { color: #E91E63; }
.alarm-info b.total-cnt { color: #040e27; }

.layer-opacity-control {  padding: 3px 10px; position: absolute; top: 10px; left: 150px; float: left; background: rgba(255,255,255,0.3); z-index: 9999; width: 200px; border-radius: 5px; box-shadow: 3px 3px 50px -2px rgba(0,0,0,0.2);  }
.layer-opacity-control input { padding: auto; }
.layer-opacity-control .form-check { display: grid; }
.layer-opacity-control span { font-size: 12px; color: #000;}
.layer-opacity-control .form-range { height:1.2rem}

#mainGrid td[data-column-name=STATUS] { text-align: -webkit-center !important; }
#mainGrid td[data-column-name=STATUS] div.tui-grid-cell-content { background: #8d8d8d; width: 50px; height: 20px; color: #ffff; text-align: center; font-weight: bold; border-radius: 5px; font-size: 11px; padding: 3px; }
#mainGrid td[data-column-name=STATUS].active div.tui-grid-cell-content { background: #0d6efd; }

.slider-wrapper { width: 90%; margin-left: 7%; }
.ui-state-default, .ui-widget-content .ui-state-default { margin-top: 0px; width: 11px; height: 11px; border: none; background: #3b6ddd; border-radius: 10px; }
.ui-slider-horizontal .ui-slider-range { height: 2px; background: #3b6ddd; }
.input-range.ui-slider { border: 1px solid #b2b2b2; background: #b2b2b2; height: 2px; }
.ui-slider-handle .range-tooltip { position: absolute; top: -25px; left: 50%; transform: translateX(-50%); padding: 0px 3px; border: 1px solid #3b95dd; background: #fff; border-radius: 2px; color: #3b95dd; border-radius: 1px; font-size: 12px; font-weight: 100; }
.ui-slider-handle:nth-child(2) > .range-tooltip { left: 5px; }
.ui-slider-handle:nth-child(3) > .range-tooltip { left: -12px; }

td[data-column-name=UNLOCODE] i { margin-left: 5px; color: #3F51B5; cursor: pointer; }

.modal-fleet-grp .modal-content.new-grp { width: 600px !important;}
.main-fleet-grp .sidebar li.sub { padding: 12px; border: solid .5px; border-radius: 10px;border-color: #0c338d; margin-bottom: 5px; }
.main-fleet-grp .sidebar li.sub a { color: #0c338d !important; font-weight: bold;}
.main-fleet-grp .sidebar .group-contents p { font-size: 13px; font-weight: normal;}
.main-fleet-grp .btn-grp button.com_btn { background: #0f67a5 !important; color: #fff !important; }
.modal-fleet-grp .grp-frm input { font-size: 14px !important; }
.modal-fleet-grp .grp-frm input,
.modal-fleet-grp .grp-frm textarea { font-size: 12px; font-weight: normal; padding-left: 10px; color: #000 !important; }

.modal-fleet-grp .modal-header h3 { font-size: 21px; }
.tui-grid-cell-content .badge { border: solid 1px #0c338d; background: #ffffff; color: #0c338d; margin: 2px; border-radius: 10px;}

.leaflet-control-minimap { bottom: 40px !important;}


.toggle-container {
    width: 250px;
    height: 40px;
    padding: 3px;
    background: #FFFFFF;
    border-radius: 30px;
    font-size: 16px;
    font-weight: 500;
    position: absolute;
    right: 50px;
    top: 80px;
    z-index: 777;
    /* display: none; */
  }
  
  .toggle-container input[type="checkbox"] {
    cursor: pointer;
    position: absolute;
    inset: 0;
    appearance: none;
    z-index: 2;
  }
  
  .toggle-container input[type="checkbox"]:checked + label.toggle-label:before {
    transform: translateX(100%);
  }
  
  .toggle-container input[type="checkbox"]:checked + label.toggle-label span:nth-child(1) {
    color: #111;
  }
  
  .toggle-container input[type="checkbox"]:checked + label.toggle-label span:nth-child(2) {
    color: #00237C;
  }
  
  .toggle-container input[type="checkbox"] + label.toggle-label {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    user-select: none;
    cursor: pointer;

    /* pointer-events: none; */
  }
  
  .toggle-container input[type="checkbox"] + label.toggle-label:before {
    content: "";
    position: absolute;
    width: 50%;
    inset: 0;
    background: #A6D7E8;
    border-radius: 30px;
    box-shadow: 0px 10px 20px 0px rgba(16, 39, 68, 0.1);
    transform: translateX(0);
    transition: transform 250ms cubic-bezier(0.93, 0.26, 0.07, 0.69);
  }
  
  .toggle-container input[type="checkbox"] + label.toggle-label span {
    position: relative;
    transition: 200ms linear;
  }
  
  .toggle-container input[type="checkbox"] + label.toggle-label span:nth-child(1) {
    color: #00237C;
  }
  
  .toggle-container input[type="checkbox"] + label.toggle-label span:nth-child(2) {
    color: #111;
  }

  .toggle-container span {
    display: flex;
    align-items: center;
  }

  .toggle-container img {
    margin-right: 15px;
  }

.btn-set button.chat {
    position: relative;
}

.btn-set button.chat::after {
    content: "ChatVue";
    position: absolute;
    background: #ffffff;
    color: #333333;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
    top: 50%;
    right: 100%;
    transform: translateY(-50%);
    margin-right: 10px;
    white-space: nowrap;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    border: 1px solid #cccccc;
}

.btn-set button.chat:hover::after {
    visibility: visible;
    opacity: 1;
}

.btn-set button.vsl-list {
    position: relative;
}

.btn-set button.vsl-list::after {
    content: "Vessel List";
    position: absolute;
    background: #ffffff;
    color: #333333;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
    top: 50%;
    right: 100%;
    transform: translateY(-50%);
    margin-right: 10px;
    white-space: nowrap;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    border: 1px solid #cccccc;
}

.btn-set button.vsl-list:hover::after {
    visibility: visible;
    opacity: 1;
}

.navi.active .portvue-section { border-top: 1px solid rgb(255 255 255 / 30%); border-radius: 0; margin: 0;  margin-top: 440px;}

