/* site.css — iphonekoubou-style restoration derived from HTML semantics */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",sans-serif;
  font-size:15px;line-height:1.7;color:#222;background:#fff;
  -webkit-text-size-adjust:100%;
}
img{max-width:100%;height:auto;display:block;border:0}
a{color:#0a7cc1;text-decoration:none}
a:hover{color:#f60;text-decoration:underline}
ul{list-style:none;padding:0;margin:0}
table{border-collapse:collapse;width:100%}
h1,h2,h3,h4,h5,h6{margin:0 0 .5em;line-height:1.3;font-weight:700}
p{margin:0 0 1em}
.font-oswald{font-family:"Oswald",sans-serif;font-weight:500}
.fc_orange{color:#f60}
.fw_bold{font-weight:700}
.fs_sm{font-size:.78em;color:#555;font-weight:400}
.alignc{text-align:center}
.brpc{display:inline}
.pc-only{display:block}
.sp-only{display:none}
.l_container{max-width:1100px;margin:0 auto;padding:0 18px}
.l_container_wide{max-width:1180px;margin:0 auto;padding:0 18px}
.l_margin{margin:60px 0}
.bg_gray{background:#f4f6f8;padding:50px 0}
.bg_campaign{background:linear-gradient(180deg,#fff 0%,#fff 100%)}

/* ---------- Header ---------- */
.site_header{background:#fff;border-bottom:3px solid #0a7cc1;position:relative;z-index:50}
.site_header_container{
  max-width:1180px;margin:0 auto;padding:10px 18px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;
}
.header_logo img{height:54px;width:auto;display:block}
.sp_submenu{display:flex;align-items:center;gap:14px;justify-self:end}
.sp_submenu .h_map img{height:38px}
.gnav_wrap{grid-column:1 / -1}
.gnav{display:flex;flex-direction:column;gap:6px}
.gnav_list{display:flex;flex-wrap:wrap;justify-content:center;background:#0a7cc1;border-radius:4px;padding:0}
.gnav_list > li.gnav_item{
  flex:1 1 auto;text-align:center;border-right:1px solid rgba(255,255,255,.25);position:relative;
}
.gnav_list > li.gnav_item:last-child{border-right:0}
.gnav_list .gnav_item > a,
.gnav_list .gnav_item > .gnav_sub_ttl{
  display:block;padding:14px 10px;color:#fff;font-weight:700;font-size:13px;line-height:1.2;cursor:pointer;
}
.gnav_list .gnav_item > a:hover,
.gnav_list .gnav_item:hover > .gnav_sub_ttl{background:#085a8e;text-decoration:none}
.gnav_sub{
  position:absolute;top:100%;left:0;right:0;background:#085a8e;
  display:none;z-index:60;padding:6px 0;min-width:180px;text-align:left;
}
.gnav_item:hover .gnav_sub{display:block}
.gnav_sub_inner > li > a{display:block;padding:8px 14px;color:#fff;font-size:13px;border-bottom:1px solid rgba(255,255,255,.12)}
.gnav_sub_inner > li:last-child > a{border-bottom:0}
.gnav_sub_inner > li > a:hover{background:#0a7cc1;text-decoration:none}
.gnav_top{
  display:flex;justify-content:flex-end;align-items:center;gap:18px;
  padding:6px 8px;font-size:13px;color:#333;flex-wrap:wrap;
}
.gnav_top_add{font-size:12px;color:#444}
.gnav_top_tel{font-size:18px;color:#f60;font-weight:700;letter-spacing:.5px}
.gnav_top_map a{
  display:inline-block;padding:4px 12px;border:1px solid #0a7cc1;color:#0a7cc1;border-radius:3px;font-size:12px;
}
.gnav_top_map a:hover{background:#0a7cc1;color:#fff;text-decoration:none}
.gnav_toggle{display:none}
.fix-btn{
  position:fixed;right:16px;bottom:16px;z-index:80;width:170px;box-shadow:0 4px 12px rgba(0,0,0,.18);border-radius:8px;overflow:hidden;
}
.fix-btn img{display:block;width:100%}

/* ---------- Slider / Hero ---------- */
.slider_wrap{margin:0;background:#0d2740;padding:14px 0;text-align:center}
#top_slider{
  display:flex;overflow-x:auto;gap:14px;padding:0 18px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
#top_slider::-webkit-scrollbar{display:none}
.slider_item{flex:0 0 78%;max-width:900px;scroll-snap-align:center}
.slider_item img{width:100%;height:auto;border-radius:6px;margin:0 auto}
.slider_arrows{display:none}
/* If slick.js initializes, slick-slide gets transformed; let it work but keep above as fallback */
.slick-slider .slider_item{flex:0 0 auto;max-width:none}

/* ---------- Section title ---------- */
.sec_title{
  text-align:center;font-size:26px;color:#0d2740;margin:0 0 30px;position:relative;padding-bottom:16px;
}
.sec_title:after{
  content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:60px;height:3px;background:#f60;
}
.sec_title .fc_orange{color:#f60}

/* ---------- Pricing tables ---------- */
.price_campaign{background:#fff}
.price_table_wrap{margin-bottom:36px;border:1px solid #d8e2ea;border-radius:8px;overflow:hidden;background:#fff}
.price_table_ttl{
  background:#0a7cc1;color:#fff;padding:14px 20px;font-size:18px;margin:0;
}
.price_table_inner{display:grid;grid-template-columns:200px 1fr;gap:0;align-items:stretch}
.price_table_inner.secret{display:block}
.price_table_inner_left{background:#f4f8fb}
.price_table_inner_right{overflow-x:auto}
.price_table{width:100%;font-size:13px}
.price_table th,.price_table td{
  border-bottom:1px solid #e3e8ee;padding:10px 8px;text-align:center;vertical-align:middle;line-height:1.4;
}
.price_table_left th{background:#f4f8fb;color:#0d2740;font-weight:700;min-height:62px;height:62px}
.price_table_left tr.price_table_price_area:nth-child(even) th{background:#eaf1f7}
.price_table_right thead th{background:#0d2740;color:#fff;font-weight:600;font-size:12px;line-height:1.35}
.price_table_right tbody td{background:#fff;height:62px}
.price_table_right tbody tr:nth-child(even) td{background:#fafbfc}
.price_num{color:#f60;font-family:"Oswald",sans-serif;font-size:22px;font-weight:700;letter-spacing:.5px}
.price_num_sm{font-size:14px}
.price_table_btm td{background:#fff8e6;color:#222;padding:14px;text-align:center;border-top:1px solid #e3e8ee}
.price_table_add td{background:#fff8e6}
.price_table_add2 td{background:#0d2740;color:#fff;font-weight:600}
.price_campaign_att{font-size:12px;color:#555;margin-top:14px;line-height:1.6}
.bnr_wrap{margin:24px 0;text-align:center}
.bnr_wrap img{display:inline-block;border-radius:8px;box-shadow:0 4px 14px rgba(0,0,0,.08)}
.border_r6{border-radius:6px}

/* ---------- Price discount block ---------- */
.price_discount img{margin:0 auto;border-radius:8px;box-shadow:0 4px 14px rgba(0,0,0,.08)}
.tokuten{
  background:#fff8e6;border:2px dashed #f60;border-radius:8px;padding:20px;margin:20px auto;max-width:760px;text-align:center;
}
.tokuten h3{color:#f60;font-size:20px;margin:8px 0 0}
.tokuten dl{display:flex;align-items:center;gap:14px;justify-content:center;margin:8px 0}
.tokuten dt img{width:42px;height:auto}
.tokuten dd{margin:0;font-size:16px;font-weight:700;color:#0d2740}

/* ---------- Repair condition grid ---------- */
.repair_condition .l_container{padding-bottom:0}
.repair_list{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:0 0 8px;
}
.repair_list > li{background:#fff;border:1px solid #d8e2ea;border-radius:8px;transition:transform .15s,box-shadow .15s}
.repair_list > li:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.repair_list > li > a{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 10px;text-align:center;color:#0d2740}
.repair_list > li > a:hover{text-decoration:none}
.repair_list_icon{display:flex;align-items:center;justify-content:center;height:64px;width:64px}
.repair_list_icon img{max-width:56px;max-height:56px;width:auto;height:auto;border-radius:0}
.repair_list_name{font-size:14px;font-weight:700;color:#0d2740}
.repair_list_link{display:inline-block;font-size:12px;color:#fff;background:#0a7cc1;padding:4px 10px;border-radius:3px}

/* ---------- Merits (5 alternating rows) ---------- */
.merit_list{display:flex;flex-direction:column;gap:24px;margin:0}
.merit_list > li{
  display:grid;grid-template-columns:1fr 380px;gap:30px;align-items:center;
  background:#fff;border:1px solid #e3e8ee;border-radius:10px;overflow:hidden;
}
.merit_list > li:nth-child(even){grid-template-columns:380px 1fr}
.merit_list > li:nth-child(even) .merit_txt_area{order:2}
.merit_list > li:nth-child(even) .merit_img_area{order:1}
.merit_txt_area{padding:26px 30px}
.merit_num{font-size:48px;color:#f60;line-height:1;margin:0 0 8px;font-family:"Oswald",sans-serif;font-weight:500}
.merit_title{font-size:22px;color:#0d2740;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #f60;display:inline-block}
.merit_img_area{
  min-height:230px;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#eaf1f7;
}
.toku_gift_wrap{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.toku_gift{flex:1 1 180px}
.toku_gift a{
  display:block;text-align:center;background:#0a7cc1;color:#fff;padding:12px;border-radius:6px;font-size:13px;line-height:1.4;
}
.toku_gift a:hover{background:#085a8e;text-decoration:none}
.toku_gift .fc_orange{color:#ffe082}

/* ---------- Secret comparison ---------- */
.secret_table{font-size:13px;background:#fff;margin-bottom:24px;border:1px solid #d8e2ea}
.secret_table thead th{background:#0d2740;color:#fff;padding:12px 8px;font-weight:600;border:1px solid #0d2740}
.secret_table tbody th{background:#f4f8fb;color:#0d2740;padding:12px 8px;width:130px;text-align:left;font-weight:700;border:1px solid #d8e2ea;vertical-align:top}
.secret_table tbody td{padding:12px;border:1px solid #d8e2ea;vertical-align:top;line-height:1.55}
.secret_table tbody td.fc_orange{background:#fff8e6;color:#0d2740}
.secret_table tbody td ul{margin:0;padding-left:18px;list-style:disc}
.secret_table tbody td ul li{margin-bottom:4px}
.secret_table_acnt{background:#f60 !important;color:#fff !important}
.secret_txt_wrap{background:#fff;border:2px solid #f60;border-radius:8px;padding:24px;margin:24px 0;text-align:center}
.secret_txt_wrap dt{display:inline-block;background:#f60;color:#fff;padding:4px 18px;border-radius:99px;font-weight:700;margin-bottom:10px}
.secret_txt_wrap dd{margin:0;font-size:15px;line-height:1.7;color:#0d2740}
.price_table_att{font-size:12px;color:#888;margin:0 0 8px}
.btn{display:inline-block;padding:14px 26px;border-radius:6px;font-weight:700;line-height:1.3;text-align:center}
.btn_primary{background:#f60;color:#fff;box-shadow:0 4px 12px rgba(255,102,0,.25)}
.btn_primary:hover{background:#e45500;color:#fff;text-decoration:none}

/* ---------- Area section ---------- */
.area_txt{text-align:center;font-size:15px;line-height:1.9;color:#222}

/* ---------- Grid (sister site banners) ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid_item{margin:0}
.grid_item img{width:100%;height:auto;border-radius:6px}

/* ---------- Footer ---------- */
.footer{background:#0d2740;color:#cfd8e0;padding:50px 0 30px;margin-top:60px}
.footer a{color:#cfd8e0}
.footer a:hover{color:#fff;text-decoration:underline}
.footer_inner{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;align-items:start}
.footer_bnr_zenkoku{grid-column:1 / -1;display:block;margin:0 0 26px;text-align:center}
.footer_bnr_zenkoku img{margin:0 auto;max-width:360px;border-radius:6px}
.footer_inner_item h2{color:#fff;font-size:15px;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:8px;margin-bottom:12px}
.footer_inner_item h2 a{color:#fff}
.footer_nav_list{display:flex;flex-direction:column;gap:6px;list-style:none;padding:0}
.footer_nav_list li{display:block}
.footer_nav_list li a{font-size:13px;color:#cfd8e0}
.footer_nav_repair{margin-top:38px}

/* ---------- Mobile ---------- */
@media (max-width: 900px){
  .pc-only{display:none}
  .sp-only{display:block}
  .site_header_container{grid-template-columns:1fr auto;gap:10px}
  .gnav_list{flex-direction:column}
  .gnav_list > li.gnav_item{border-right:0;border-bottom:1px solid rgba(255,255,255,.2);text-align:left}
  .gnav_sub{position:static}
  .gnav_top{justify-content:flex-start}
  .price_table_inner{grid-template-columns:1fr}
  .price_table_inner_left{display:none} /* mobile uses inline labels */
  .repair_list{grid-template-columns:repeat(2,1fr)}
  .merit_list > li,
  .merit_list > li:nth-child(even){grid-template-columns:1fr}
  .merit_list > li:nth-child(even) .merit_txt_area{order:0}
  .merit_list > li:nth-child(even) .merit_img_area{order:1}
  .merit_img_area{min-height:180px}
  .footer_inner{grid-template-columns:repeat(2,1fr)}
  .grid{grid-template-columns:1fr}
  .fix-btn{width:120px}
  .sec_title{font-size:22px}
}
@media (max-width: 480px){
  .repair_list{grid-template-columns:1fr 1fr}
  .footer_inner{grid-template-columns:1fr}
  .price_num{font-size:18px}
}
