@charset "utf-8";
/* CSS Document */



/* 追加
------------------------------------------------------------*/
.fb_timeline{text-align:center;margin:0 auto 10px;}
.indent-1 {padding-left:1em;text-indent:-1em;}
.indent-2 {padding-left:2em;text-indent:-2em;}
.indent-15 {padding-left:1.5em;text-indent:-1.5em;}
.fade{display:none;}
.banner_img{text-align:center;margin:0 auto;clear:both;}
.banner_img img{border-radius:20px;}
br.pcbr{display:block;}
br.spbr{display:none;}
.text_box{text-align:justify;padding:0;}
.text_box p{margin-bottom:1.5em;}
.text_box ul,.text_box ol{margin-left:1em;list-style-position: outside;}
.text_box ul li{list-style:none;margin-bottom:0.5em;position: relative;padding: 0 0 0 1.5em;}
.text_box li::before {
  content: "\f054";
  font-family: FontAwesome;
font-weight: 400;
padding-right:5px;
color:#F8B500;
position: absolute;
left: 0.5em;
}
.text_box_w{background:#fff;text-align:justify;padding:1em 2em;margin:20px auto 50px;}
.text_box_w img{width:200px;margin-top:5px;}
.text_box_w li > p{font-weight:400;margin-left:1em;}

.sptel{display:none;}
.twoblock{display:flex;flex-wrap:wrap;justify-content:space-between;}
.block_area{width:49%;}


.marker{background: linear-gradient(transparent 70%, #fff7fa 70%);padding:0 2em 0;}
.marker2{color:#317091;font-weight:700;}
.marker-space{letter-spacing:-0.5em;}
.pagetop {display: none;position: fixed;bottom: 50px;right:5%;width:66px;z-index:100;}
.pagetop a {display: block;}
.pagetop img{width:100%;}
.sp_btn{display:none;}

.slides img{width:100%;}
.head_img{position: relative;margin-bottom:30px;}
.head_img img{width:100%;}
.head_title{position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);font-size:30px;color:#317091;font-family: dnp-shuei-mincho-pr6n, sans-serif;font-weight: 700;font-style: normal;background:rgba(255,255,255,0.9);z-index:9999;min-height:80px;display:flex;justify-content:center;align-items:center;letter-spacing:0.3em;width:40%;line-height:1;}

h2.title{font-size:26px;text-align:center;margin:50px auto 0;}
h2.title_sub{font-size:20px;text-align:center;color:#c7b299;font-family: "futura-pt", sans-serif;font-weight: 400;font-style: normal;margin-bottom:50px;}
h2.title_sub_w{font-size:20px;text-align:center;color:#fff;font-family: "futura-pt", sans-serif;font-weight: 400;font-style: normal;margin-bottom:10px;}
h3.title{font-family: "ryo-gothic-plusn", sans-serif;font-weight: 500;font-style: normal;font-size:24px;display:flex;align-items:center;justify-content:center;width:100%;margin:80px auto 40px;}
h3.title::before{content:"";width:110px;flex:none;height:2px;background:#c7b299;margin:0 10px 0 0;}
h3.title::after{content:"";width:110px;flex:none;height:2px;background:#c7b299;margin:0 0 0 10px;}


/*back
------------------------------------------------------------*/
.pnavi{text-align:center;font-size:16px;margin-top:20px;}



/*TOP
------------------------------------------------------------*/
.worry { width: 100%; background: linear-gradient(90deg, #f4f9ff 0%, #fff 50%, #f4f9ff 100%); padding: 44px 0 42px; }
.worry-inner { width: min(94%, 1200px); margin: 0 auto; display: grid; grid-template-columns: 1fr 64px 1fr; align-items: center; gap: 44px; }
.worry h2 { color: #06284b; font-size: clamp(24px, 2.4vw, 32px); font-weight: 900; line-height: 1.45; text-align: center; margin: 0 0 24px; letter-spacing: .04em; }
.worry h2 span { color: #073f7f; font-size: 1.25em; display: inline-block; position: relative; }
.worry h2 span::after { content: ""; width: 100%; height: 8px; background: rgba(255,125,0,.25); position: absolute; left: 0; bottom: 2px; z-index: -1; }
.worry-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.worry-list li { background: rgba(255,255,255,.92); color: #111; font-size: 16px; font-weight: 700; line-height: 1.6; border-radius: 6px; padding: 12px 18px 12px 54px; position: relative; box-shadow: 0 4px 14px rgba(6,40,75,.05); }
.worry-list li::before { content: "✓"; width: 22px; height: 22px; background: #07427f; color: #fff; border-radius: 5px; font-size: 15px; font-weight: 900; line-height: 22px; text-align: center; position: absolute; left: 22px; top: 50%; transform: translateY(-50%); }
.worry-arrow { width: 0; height: 0; border-style: solid; border-width: 34px 0 34px 28px; border-color: transparent transparent transparent #073f7f; margin: 44px auto 0; }
.worry-result-list { display: grid; gap: 14px; }
.worry-result { background: rgba(255,255,255,.92); border-radius: 6px; padding: 16px 22px; display: grid; grid-template-columns: 58px 1fr; align-items: center; gap: 18px; box-shadow: 0 4px 14px rgba(6,40,75,.05); }
.worry-result-icon { width: 52px; height: 52px; border: 2px solid #073f7f; color: #073f7f; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 28px; line-height: 1; }
.worry-result p { color: #111; font-size: 16px; font-weight: 800; line-height: 1.55; margin: 0; }
.worry-result span { color: #ff6500; font-size: 22px; font-weight: 900; }
@media screen and (max-width: 1023px) { .worry { padding: 42px 0; } .worry-inner { grid-template-columns: 1fr; gap: 28px; } .worry-arrow { border-width: 26px 22px 0 22px; border-color: #073f7f transparent transparent transparent; margin: 0 auto; } }
@media screen and (max-width: 600px) { .worry h2 { font-size: 23px; margin-bottom: 18px; } .worry-list li { font-size: 14px; padding: 12px 14px 12px 48px; } .worry-list li::before { left: 16px; } .worry-result { grid-template-columns: 46px 1fr; gap: 14px; padding: 14px 16px; } .worry-result-icon { width: 42px; height: 42px; font-size: 22px; } .worry-result p { font-size: 14px; } .worry-result span { font-size: 18px; } }

.plan { width: 100%; background: #fff; padding: 52px 0 56px; }
.plan-inner { width: min(94%, 1200px); margin: 0 auto; }
.plan-title { color: #06284b; font-size: clamp(26px, 2.6vw, 36px); font-weight: 900; line-height: 1.4; text-align: center; margin: 0 0 26px; letter-spacing: .04em; }
.plan-title span { color: #073f7f; font-size: 1.25em; position: relative; }
.plan-title span::after { content: ""; width: 100%; height: 8px; background: rgba(255,125,0,.25); position: absolute; left: 0; bottom: 3px; z-index: -1; }
.plan-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; }
.plan-card { background: #fff; border-radius: 8px; padding: 28px 24px 30px; position: relative; text-align: center; box-shadow: 0 8px 24px rgba(6,40,75,.06); }
.plan-card-light { border: 2px solid #8ac89b; background: linear-gradient(180deg, #f8fff9 0%, #fff 100%); }
.plan-card-standard { border: 2px solid #07427f; background: linear-gradient(180deg, #f8fbff 0%, #fff 100%); }
.plan-card-premium { border: 2px solid #c89a42; background: linear-gradient(180deg, #fffaf0 0%, #fff 100%); }
.plan-badge { width: 70px; height: 70px; background: #ffd800; color: #06284b; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-direction: column; font-size: 15px; font-weight: 900; line-height: 1.2; position: absolute; right: -12px; top: -16px; transform: rotate(-10deg); }
.plan-label { font-size: 15px; font-weight: 900; line-height: 1.4; margin: 0 0 4px; }
.plan-card-light .plan-label { color: #17803a; }
.plan-card-standard .plan-label { color: #073f7f; }
.plan-card-premium .plan-label { color: #9a6a17; }
.plan-card h3 { font-size: clamp(24px, 2.2vw, 32px); font-weight: 900; line-height: 1.3; margin: 0 0 22px; }
.plan-card-light h3 { color: #17803a; }
.plan-card-standard h3 { color: #073f7f; }
.plan-card-premium h3 { color: #9a6a17; }
.plan-main { min-height: 110px; background: rgba(255,255,255,.82); border-radius: 8px; display: grid; grid-template-columns: 76px 1fr; align-items: center; gap: 14px; padding: 18px 16px; margin: 0 0 24px; text-align: left; }
.plan-icon { color: #073f7f; font-size: 44px; line-height: 1; text-align: center; }
.plan-main p { color: #111; font-size: 14px; font-weight: 700; line-height: 1.7; margin: 0; }
.plan-price { color: #111; font-size: 18px; font-weight: 800; line-height: 1.4; margin: 0 0 22px; }
.plan-price strong { font-size: clamp(34px, 3vw, 44px); font-weight: 900; letter-spacing: -.03em; }
.plan-card-light .plan-price strong { color: #17803a; }
.plan-card-standard .plan-price strong { color: #073f7f; }
.plan-card-premium .plan-price strong { color: #b57916; }
.plan-price span { font-size: 13px; font-weight: 700; }
.plan-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; text-align: left; width: fit-content; max-width: 100%; margin-inline: auto; }
.plan-card li { color: #111; font-size: 15px; font-weight: 700; line-height: 1.5; padding-left: 22px; position: relative; }
.plan-card li::before { content: "✓"; color: #073f7f; font-weight: 900; position: absolute; left: 0; top: 0; }
@media screen and (max-width: 1023px) { .plan-list { grid-template-columns: 1fr; max-width: 620px; margin: 0 auto; } .plan-card { padding: 28px 22px; } .plan-badge { right: 12px; top: -14px; } }

@media screen and (max-width: 600px) { .plan { padding: 42px 0 46px; } .plan-title { font-size: 24px; margin-bottom: 22px; } .plan-main { grid-template-columns: 58px 1fr; min-height: 0; padding: 16px 14px; } .plan-icon { font-size: 34px; } .plan-main p { font-size: 13px; } .plan-price { font-size: 15px; } .plan-price strong { font-size: 34px; } .plan-card li { font-size: 14px; } }


/*制作実績
------------------------------------------------------------*/
.works-page { width: min(94%, 1200px); margin: 70px auto 90px; color: #222; }
.works-lead { width: min(100%, 900px); margin: 0 auto 46px; text-align: center; }
.works-lead h2 { color: #06284b; font-size: clamp(26px, 2.8vw, 38px); font-weight: 900; line-height: 1.55; margin: 0 0 18px; }
.works-lead p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; }
.works-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.works-card { background: #fff; border: 1px solid #d9e3ee; border-radius: 12px; overflow: hidden; box-shadow: 0 8px 24px rgba(6,40,75,.06); transition: transform .2s ease, box-shadow .2s ease; }
.works-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(6,40,75,.1); }
.works-image { width: 100%; aspect-ratio: 16 / 9; background: #f4f8fc; overflow: hidden; }
.works-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s ease; }
.works-card:hover .works-image img { transform: scale(1.04); }
.works-body { padding: 20px 22px 22px; }
.works-body h2 { color: #06284b; font-size: 18px; font-weight: 900; line-height: 1.45; margin: 0 0 10px; }
.works-body p { width: fit-content; background: #f4f8fc; color: #073f7f; border: 1px solid #d9e3ee; border-radius: 999px; font-size: 13px; font-weight: 800; line-height: 1; padding: 8px 14px; margin: 0; }
.works-empty { grid-column: 1 / -1; text-align: center; font-size: 16px; font-weight: 700; line-height: 2; margin: 0; }
.works-card a { display: block; color: inherit; text-decoration: none; height: 100%; }
@media screen and (max-width: 1023px) { .works-list { grid-template-columns: repeat(2, 1fr); gap: 22px; } }
@media screen and (max-width: 767px) { .works-page { width: min(92%, 1200px); margin: 50px auto 64px; } .works-lead { margin-bottom: 34px; text-align: left; } .works-lead h2 { font-size: 25px; } .works-lead p { font-size: 15px; line-height: 1.9; } .works-list { grid-template-columns: 1fr; gap: 20px; } .works-body { padding: 18px 18px 20px; } .works-body h2 { font-size: 19px; } }



/*料金プラン
------------------------------------------------------------*/
.price-page { width: min(94%, 1200px); margin: 70px auto 90px; color: #222; }
.price-lead { width: min(100%, 900px); margin: 0 auto 52px; text-align: center; }
.price-lead h2 { color: #06284b; font-size: clamp(26px, 2.8vw, 38px); font-weight: 900; line-height: 1.55; margin: 0 0 22px; }
.price-lead p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; text-align: left; }
.price-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; margin: 0 0 64px; }
.price-card { background: #fff; border-radius: 14px; padding: 34px 26px 32px; position: relative; text-align: center; box-shadow: 0 8px 26px rgba(6,40,75,.07); overflow: hidden; }
.price-card::before { content: ""; width: 100%; height: 6px; position: absolute; left: 0; top: 0; }
.price-light { border: 1px solid #b9dfc4; }
.price-standard { border: 2px solid #073f7f; transform: translateY(0px); }
.price-premium { border: 1px solid #d8b978; }
.price-light::before { background: #2ca24e; }
.price-standard::before { background: #073f7f; }
.price-premium::before { background: #b57916; }
.price-badge { width: 92px; height: 92px; background: #ff6500; color: #fff; border-radius: 50%; font-size: 15px; font-weight: 900; line-height: 92px; text-align: center; position: absolute; right: -14px; top: -16px; transform: rotate(10deg); box-shadow: 0 8px 18px rgba(255,101,0,.22); }
.price-label { font-size: 15px; font-weight: 900; line-height: 1.4; margin: 0 0 8px; }
.price-light .price-label { color: #2ca24e; }
.price-standard .price-label { color: #073f7f; }
.price-premium .price-label { color: #9a6a17; }
.price-card h3 { font-size: clamp(24px, 2.3vw, 32px); font-weight: 900; line-height: 1.3; margin: 0 0 12px; }
.price-light h3 { color: #2ca24e; }
.price-standard h3 { color: #073f7f; }
.price-premium h3 { color: #9a6a17; }
.price-desc { color: #333; font-size: 14px; font-weight: 700; line-height: 1.6; margin: 0 0 22px; }
.price-main { background: #f4f8fc; border-radius: 10px; padding: 18px 12px 16px; margin: 0 0 24px; }
.price-main span { color: #06284b; font-size: 14px; font-weight: 900; line-height: 1; display: block; margin: 0 0 6px; }
.price-main strong { font-size: clamp(36px, 3.4vw, 48px); font-weight: 900; line-height: 1; letter-spacing: -.04em; }
.price-main em { color: #111; font-style: normal; font-size: 18px; font-weight: 900; line-height: 1; }
.price-light .price-main strong { color: #2ca24e; }
.price-standard .price-main strong { color: #073f7f; }
.price-premium .price-main strong { color: #b57916; }
.price-card ul { list-style: none; padding: 0; margin: 0; text-align: left; display: grid; gap: 10px; }
.price-card li { color: #222; font-size: 15px; font-weight: 600; line-height: 1.6; padding-left: 26px; position: relative; }
.price-card li::before { content: "✓"; color: #ff6500; font-weight: 900; position: absolute; left: 0; top: 0; }
.price-note { width: min(100%, 900px); margin: 0 auto; background: linear-gradient(90deg, #f4f9ff 0%, #fff 100%); border-radius: 14px; padding: 34px 38px; }
.price-note h2 { color: #06284b; font-size: clamp(23px, 2.2vw, 30px); font-weight: 900; line-height: 1.45; margin: 0 0 16px; }
.price-note p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; }
.price-note ul{margin-left:1.5em;}
@media screen and (max-width: 1023px) { .price-list { grid-template-columns: 1fr; max-width: 620px; margin: 0 auto 56px; } .price-standard { transform: none; } .price-badge { right: 0px; top: -12px;width: 80px; height: 80px;  } }

@media screen and (max-width: 767px) { .price-page { width: min(92%, 1200px); margin: 50px auto 64px; } .price-lead { margin-bottom: 38px; } .price-lead h2 { font-size: 22px; text-align: left; } .price-lead p { font-size: 15px; line-height: 1.9; } .price-card { padding: 30px 22px 28px; } .price-main strong { font-size: 38px; } .price-card li { font-size: 14px; } .price-note { padding: 28px 22px; font-size: 15px;} .price-note p { font-size: 15px; line-height: 1.9; } }
.price-option { width: min(100%, 900px); margin: 56px auto 0; }
.price-option h2 { color: #06284b; font-size: clamp(23px, 2.2vw, 30px); font-weight: 900; line-height: 1.45; margin: 0 0 20px; padding-bottom: 12px; border-bottom: 2px solid #073f7f; }
.price-option-table { background: #fff; border: 1px solid #d9e3ee; border-radius: 14px; overflow: hidden; box-shadow: 0 8px 24px rgba(6,40,75,.05); }
.price-option-row { display: grid; grid-template-columns: 1fr 180px; align-items: center; border-bottom: 1px solid #d9e3ee; }
.price-option-row:last-child { border-bottom: none; }
.price-option-row p { color: #222; font-size: 15px; font-weight: 700; line-height: 1.7; margin: 0; padding: 17px 22px; }
.price-option-row span { height: 100%; background: #f4f8fc; color: #073f7f; font-size: 17px; font-weight: 900; line-height: 1.4; display: flex; align-items: center; justify-content: flex-end; padding: 17px 22px; border-left: 1px solid #d9e3ee; box-sizing: border-box; }
.price-server { width: min(100%, 900px); margin: 40px auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.price-server-box { background: linear-gradient(180deg, #f8fbff 0%, #fff 100%); border: 1px solid #d9e3ee; border-radius: 14px; padding: 30px 28px; box-shadow: 0 8px 24px rgba(6,40,75,.05); }
.price-server-box h2 { color: #06284b; font-size: 24px; font-weight: 900; line-height: 1.45; margin: 0 0 18px; padding-bottom: 10px; border-bottom: 2px solid #073f7f; }
.price-server-price { color: #073f7f; font-size: 42px; font-weight: 900; line-height: 1.1; margin: 0 0 18px; letter-spacing: -.03em; }
.price-server-price span { color: #111; font-size: 18px; font-weight: 900; }
.price-server-box ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.price-server-box li { color: #222; font-size: 14px; font-weight: 600; line-height: 1.8; padding-left: 24px; position: relative; }
.price-server-box li::before { content: "※"; color: #ff6500; font-weight: 900; position: absolute; left: 0; top: 0; }
.price-domain-list { display: grid; gap: 12px; }
.price-domain-list div { background: #fff; border: 1px solid #d9e3ee; border-radius: 10px; padding: 18px 20px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.price-domain-list p { color: #06284b; font-size: 22px; font-weight: 900; line-height: 1; margin: 0; }
.price-domain-list span { color: #073f7f; font-size: 22px; font-weight: 900; line-height: 1; }
@media screen and (max-width: 767px) { .price-option { margin-top: 42px; } .price-option-row { grid-template-columns: 1fr; } .price-option-row p { padding: 15px 18px 8px; } .price-option-row span { justify-content: flex-start; border-left: none; padding: 8px 18px 15px; background: #fff; color: #ff6500; } .price-server { grid-template-columns: 1fr; gap: 18px; margin-top: 28px; } .price-server-box { padding: 26px 22px; } .price-server-box h2 { font-size: 22px; } .price-server-price { font-size: 36px; } .price-domain-list p,.price-domain-list span { font-size: 20px; } }

/*QA
------------------------------------------------------------*/
.faq-page { width: min(90%, 900px); margin: 70px auto 90px; color: #222; }
.faq-intro { margin: 0 0 46px; }
.faq-page h2 { color: #06284b; font-size: clamp(24px, 2.4vw, 32px); font-weight: 900; line-height: 1.45; margin: 0 0 22px; padding-bottom: 12px; border-bottom: 2px solid #073f7f; }
.faq-page p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; }
.faq-list { display: grid; gap: 18px; }
.faq-item { background: #fff; border: 1px solid #d9e3ee; border-radius: 10px; overflow: hidden; box-shadow: 0 6px 18px rgba(6,40,75,.04); }
.faq-item h3 { background: #f4f8fc; color: #06284b; font-size: 18px; font-weight: 900; line-height: 1.6; margin: 0; padding: 20px 24px 20px 68px; position: relative; }
.faq-item h3 span { width: 34px; height: 34px; background: #073f7f; color: #fff; border-radius: 50%; font-size: 18px; font-weight: 900; line-height: 34px; text-align: center; position: absolute; left: 22px; top: 18px; }
.faq-answer { padding: 22px 24px 24px 68px; position: relative; }
.faq-answer span { width: 34px; height: 34px; background: #ff6500; color: #fff; border-radius: 50%; font-size: 18px; font-weight: 900; line-height: 34px; text-align: center; position: absolute; left: 22px; top: 24px; }
.faq-answer p { color: #222; font-size: 16px; font-weight: 500; line-height: 1.9; margin: 0; }
@media screen and (max-width: 767px) { .faq-page { width: min(92%, 900px); margin: 50px auto 64px; } .faq-intro { margin-bottom: 36px; } .faq-page h2 { font-size: 23px; margin-bottom: 18px; } .faq-page p { font-size: 15px; line-height: 1.9; } .faq-list { gap: 14px; } .faq-item h3 { font-size: 16px; padding: 17px 16px 17px 56px; } .faq-item h3 span { width: 30px; height: 30px; font-size: 16px; line-height: 30px; left: 16px; top: 17px; } .faq-answer { padding: 18px 16px 20px 56px; } .faq-answer span { width: 30px; height: 30px; font-size: 16px; line-height: 30px; left: 16px; top: 20px; } .faq-answer p { font-size: 15px; line-height: 1.85; } }



/*サービスの特徴
------------------------------------------------------------*/
.feature-page { width: min(94%, 1200px); margin: 70px auto 90px; color: #222; }
.feature-lead { width: min(100%, 900px); margin: 0 auto 56px; text-align: center; }
.feature-lead h2 { color: #06284b; font-size: clamp(26px, 2.8vw, 38px); font-weight: 900; line-height: 1.55; margin: 0 0 22px; }
.feature-lead p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; text-align: left; }
.feature-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 0 0 76px; }
.feature-card { background: #fff; border: 1px solid #d9e3ee; border-radius: 12px; padding: 34px 26px 30px; position: relative; box-shadow: 0 8px 24px rgba(6,40,75,.05); overflow: hidden; }
.feature-card::before { content: ""; width: 100%; height: 5px; background: linear-gradient(90deg, #073f7f 0%, #ff6500 100%); position: absolute; left: 0; top: 0; }
.feature-num { color: rgba(7,63,127,.08); font-size: 58px; font-weight: 900; line-height: 1; position: absolute; right: 18px; top: 20px; letter-spacing: -.04em; }
.feature-icon { width: 64px; height: 64px; background: #f4f8fc; color: #073f7f; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; line-height: 1; margin: 0 0 20px; }
.feature-card h3 { color: #06284b; font-size: 21px; font-weight: 900; line-height: 1.45; margin: 0 0 14px; position: relative; z-index: 2; }
.feature-card p { font-size: 15px; font-weight: 500; line-height: 1.9; margin: 0; position: relative; z-index: 2; }
.feature-flow { background: linear-gradient(90deg, #f4f9ff 0%, #fff 50%, #f4f9ff 100%); border-radius: 14px; padding: 44px 38px 46px; }
.feature-flow h2 { color: #06284b; font-size: clamp(24px, 2.4vw, 32px); font-weight: 900; line-height: 1.45; text-align: center; margin: 0 0 30px; }
.feature-flow-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.feature-flow-item { background: #fff; border-radius: 10px; padding: 24px 20px 22px; text-align: center; position: relative; box-shadow: 0 6px 18px rgba(6,40,75,.05); }
.feature-flow-item:not(:last-child)::after { content: ""; width: 16px; height: 16px; border-top: 3px solid #073f7f; border-right: 3px solid #073f7f; position: absolute; right: -15px; top: 50%; transform: translateY(-50%) rotate(45deg); z-index: 2; }
.feature-flow-item span { color: #ff6500; font-size: 13px; font-weight: 900; line-height: 1; display: block; margin: 0 0 12px; letter-spacing: .08em; }
.feature-flow-item h3 { color: #06284b; font-size: 19px; font-weight: 900; line-height: 1.45; margin: 0 0 10px; }
.feature-flow-item p { font-size: 14px; font-weight: 500; line-height: 1.8; margin: 0; text-align: left; }
@media screen and (max-width: 1023px) { .feature-list { grid-template-columns: repeat(2, 1fr); } .feature-flow-list { grid-template-columns: 1fr 1fr; } .feature-flow-item:not(:last-child)::after { display: none; } }
@media screen and (max-width: 767px) { .feature-page { width: min(92%, 1200px); margin: 50px auto 64px; } .feature-lead { margin-bottom: 40px; } .feature-lead h2 { font-size: 22px; text-align: left; } .feature-lead p { font-size: 15px; line-height: 1.9; } .feature-list { grid-template-columns: 1fr; gap: 18px; margin-bottom: 50px; } .feature-card { padding: 30px 22px 26px; } .feature-num { font-size: 48px; } .feature-icon { width: 56px; height: 56px; font-size: 24px; } .feature-card h3 { font-size: 20px; } .feature-card p { font-size: 14px; } .feature-flow { padding: 34px 20px 36px; } .feature-flow-list { grid-template-columns: 1fr; gap: 14px; } .feature-flow-item p { text-align: center; } }

/*会社概要
------------------------------------------------------------*/
.page-head { width: 100%; background: linear-gradient(90deg, #f4f9ff 0%, #fff 50%, #f4f9ff 100%); padding: 78px 0 70px; }
.page-head-inner { width: min(94%, 1200px); margin: 0 auto; text-align: center; }
.page-head p { color: #ff6500; font-size: 15px; font-weight: 900; line-height: 1; letter-spacing: .14em; margin: 0 0 14px; }
.page-head h1 { color: #06284b; font-size: clamp(34px, 3.4vw, 46px); font-weight: 900; line-height: 1.35; margin: 0; letter-spacing: .06em; }
.company-page { width: min(90%, 900px); margin: 70px auto 90px; color: #222; }
.company-intro { margin: 0 0 64px; }
.company-page h2 { color: #06284b; font-size: clamp(24px, 2.4vw, 32px); font-weight: 900; line-height: 1.45; margin: 0 0 22px; padding-bottom: 12px; border-bottom: 2px solid #073f7f; }
.company-page p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0; }
.company-info table { width: 100%; border-collapse: collapse; }
.company-info th { width: 28%; background: #f4f8fc; color: #06284b; font-size: 15px; font-weight: 800; line-height: 1.6; text-align: left; vertical-align: top; padding: 18px 20px; border: 1px solid #d9e3ee; }
.company-info td { color: #222; font-size: 15px; font-weight: 500; line-height: 1.8; vertical-align: top; padding: 18px 20px; border: 1px solid #d9e3ee; }
@media screen and (max-width: 767px) { .page-head { padding: 54px 0 48px; } .company-page { width: min(92%, 900px); margin: 50px auto 64px; } .company-intro { margin-bottom: 46px; } .company-page h2 { font-size: 23px; margin-bottom: 18px; } .company-page p { font-size: 15px; line-height: 1.9; } .company-info table,.company-info tbody,.company-info tr,.company-info th,.company-info td { display: block; width: 100%; } .company-info th { padding: 13px 16px; border-bottom: none; } .company-info td { padding: 14px 16px 18px; } }


/*固定ページ
------------------------------------------------------------*/
.page-content { width: min(90%, 900px); margin: 80px auto; color: #222; line-height: 2; }
.page-content h1 { color: #06284b; font-size: clamp(32px, 3vw, 36px); font-weight: 900; line-height: 1.4; margin: 0 0 40px; text-align: center; }
.page-content h2 { color: #06284b; font-size: clamp(22px, 2vw, 20px); font-weight: 800; line-height: 1.5; margin: 60px 0 20px; padding-bottom: 10px; border-bottom: 2px solid #073f7f; }
.page-content h3 { color: #06284b; font-size: 22px; font-weight: 800; line-height: 1.5; margin: 40px 0 15px; }
.page-content p { font-size: 16px; font-weight: 500; line-height: 2; margin: 0 0 20px; }
.page-content ul { margin: 20px 0; padding: 0; list-style: none; }
.page-content li { font-size: 16px; font-weight: 500; line-height: 2; padding-left: 28px; position: relative; margin-bottom: 8px; }
.page-content li::before { content: ""; width: 8px; height: 8px; background: #073f7f; border-radius: 50%; position: absolute; left: 0; top: 14px; }
.page-content a { color: #073f7f; text-decoration: underline; transition: .2s; }
.page-content a:hover { opacity: .7; }
.page-content table { width: 100%; border-collapse: collapse; margin: 24px 0; }
.page-content th { background: #f4f8fc; color: #06284b; font-size: 15px; font-weight: 700; padding: 15px; border: 1px solid #d9e3ee; width: 30%; }
.page-content td { font-size: 15px; padding: 15px; border: 1px solid #d9e3ee; }
.page-content strong { font-weight: 800; }
.page-content hr { border: none; border-top: 1px solid #d9e3ee; margin: 50px 0; }
@media screen and (max-width: 767px) { .page-content { width: min(92%, 900px); margin: 50px auto; } }
@media screen and (max-width: 767px) { .page-content h1 { font-size: 26px; margin-bottom: 30px; } }
@media screen and (max-width: 767px) { .page-content h2 { font-size: 20px; margin: 40px 0 15px; } }
@media screen and (max-width: 767px) { .page-content p { font-size: 15px; line-height: 1.9; } }
@media screen and (max-width: 767px) { .page-content li { font-size: 15px; line-height: 1.9; } }
@media screen and (max-width: 767px) { .page-content th,.page-content td { font-size: 14px; padding: 12px; } }



@media screen and (max-width:767px) {
br.pcbr{display:none;}
br.spbr{display:block;}
}