@charset "utf-8";
@import url("https://www.webjapan.co.jp/css/solution/ai-camera.css");
/* CSS Document */
a {
    text-decoration: none !important;
}
figure {
    margin: 0 0 20px 0;
}

header{
 height: auto !important;
}

.breadcrumbs{
 top: 225px;
}

@media print, screen and (min-width:768px){
 .breadcrumbs{
 top: 335px;
}
}

/* セクション共通 */
section {
    padding: 60px 20px;
}
section h2 {
    font-size: 28px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 40px;
    color: #333;
}
.section-subtitle {
    text-align: center;
    font-size: 14px;
    color: #666;
    margin-bottom: 30px;
}
/* レスポンシブ */
@media print, screen and (min-width:768px) {
    .header-section h1 {
        font-size: 24px;
    }
    .main-visual {
        flex-direction: column;
        padding: 40px 20px;
        gap: 30px;
    }
    .button-group {
        flex-direction: row;
        flex-wrap: nowrap;
    }
    .btn {
        width: 100%;
        text-align: center;
        white-space: nowrap;
    }
    section h2 {
        font-size: 22px;
    }
    .feature-with-image, .feature-with-image02 {
        /*flex-direction: column;*/
        gap: 20px;
    }
    .use-cases-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.main-visual{
 background: #003da6;
 padding: 50px 15px;
}

.main-visual h2{
 font-size: 30px;
 font-weight: bold;
 color: #fff;
 margin-bottom: 0;
}
@media screen and (max-width:480px){
 .main-visual h2{
 font-size: 24px;
}
}

#sec01 .flex_box{
 margin-top: 50px;
}

#sec01 .flex_box figure{
 margin-bottom: 20px;
}

#sec01 .flex_box figure img{
 width: 100%;
 height: auto;
}

#sec01 .flex_box .tx_box p{
 text-align: left;
}


@media print, screen and (min-width:768px){
 #sec01 .flex_box{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row-reverse;
 }
 #sec01 .flex_box figure{
  width: 40%;
 margin-bottom: 0;
}
 #sec01 .flex_box .tx_box{
  width: 56%;
}
}

.li_main_func li{
 background: #fff;
 border-radius: 20px;
 padding: 20px;
 margin-bottom: 30px;
}

.li_main_func li h3{
 font-size: 20px;
 font-weight: bold;
 color: #333;
 margin-bottom: 30px;
}

.li_main_func li figure{
 margin-bottom: 20px;
}

.li_main_func li figure img{
 width: 50%;
 height: auto;
}

@media print, screen and (min-width:768px){
 .li_main_func{
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
 }
 .li_main_func li{
  width: 31%;
 }
 
 .li_main_func li:not(:nth-child(3n)){
  margin-right: 30px;
 }
}


.viewer_image li:not(:last-child){
 margin-bottom: 100px;
}

.viewer_image li h3{
 font-size: 22px;
 font-weight: bold;
 color: #333;
 margin-bottom: 30px;
}

.viewer_image li figure{
 
 
}

.viewer_image li figure img{
 width: 100%;
 height: auto;
}

.viewer_image li .pic{
 position: relative;
}

.viewer_image li .pic:not(:last-child){
 margin-bottom: 120px;
}

.viewer_image li .pic:not(:last-child)::before{
 content: "";
 position: absolute;
 bottom: -120px;
 left: 0;
 right: 0;
 margin: auto;
 block-size:0;
 inline-size:0;
 border-top: 40px solid #003da6;
 border-bottom: 40px solid transparent;
 border-left: 80px solid transparent;
 border-right: 80px solid transparent;
}


@media print, screen and (min-width:768px){
 .viewer_image li figure img{
 width: 80%;
 height: auto;
}
}

.button-group {
    display: flex;
    gap: 15px;
    margin-top: 20px;
    flex-wrap: wrap;
    justify-content: center;
}
.btn {
    padding: 15px 40px;
    border: none;
    border-radius: 30px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    text-decoration: none;
    display: inline-block;
    width: 100%;
    max-width: 280px;
    margin: 0;
}
.btn a:hover {
    text-decoration: none;
    color: inherit;
}
.btn-primary {
    background-color: #ffc107;
    color: #333;
}
.btn-primary:hover {
    background-color: #ffb300;
    transform: scale(1.05);
}
.btn-secondary {
    background-color: #fff;
    color: #003da6;
    border: 1px solid #003da6;
}
.btn-secondary:hover {
    background-color: #f0f0f0;
}


/* CTA セクション */
.cta-section {
    background: linear-gradient(135deg, #0099FF 0%, #003da6 100%);
    color: #fff;
    text-align: center;
    padding: 60px 20px;
}
.cta-section h2 {
    color: #fff;
    margin-bottom: 30px;
}
.cta-section p {
    font-size: 16px;
    margin-bottom: 30px;
    opacity: 0.95;
}

