:root{
  --main: #10c1bb; /* emerald */
  --sub: #7cb727;  /* light green */
  --accent: #f5c521; /* yellow */
  --bg: #ffffff;
  --muted: #f4f6f5;
  --text: #16322f;
  --max-width: 1200px;
  --radius: 10px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{font-family: 'Noto Sans JP', 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;color:var(--text);background:var(--bg);margin:0;line-height:1.65;-webkit-font-smoothing:antialiased}
.container{max-width:var(--max-width);margin:0 auto;padding:1rem}

/* Header */
.site-header{background:var(--main);color:#fff;position:sticky;top:0;z-index:40;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1rem}
.logo{text-decoration:none;color:#fff;font-weight:700;font-size:1.05rem;display:inline-flex;align-items:center;gap:0.6rem}
.logo::before{content:'';display:inline-block;width:32px;height:32px;background-image:url("../images/rogo_icon.png");background-size:contain;background-repeat:no-repeat;background-position:center;flex:0 0 32px;margin-right:0}
.nav-list{display:flex;gap:0.5rem;align-items:center;margin:0;padding:0;list-style:none}
.nav-list a{color:#fff;text-decoration:none;padding:0.55rem 0.65rem;border-radius:6px;display:inline-block}
.nav-list a:hover{background:rgba(255,255,255,0.2)}
.nav-list .cta{background:var(--accent);color:#41300c;border-radius:6px;padding:0.45rem 0.9rem;font-weight:600}
.nav-list .cta:hover{background:var(--accent);color:#41300c;transform:translateY(-2px);box-shadow:0 10px 22px rgba(245,197,33,0.22)}
.hamburger{display:none;background:transparent;border:0;color:#fff;font-size:1.4rem;padding:0.4rem}
/* hide injected mobile close button by default (only show in mobile media query) */
.site-nav .nav-close{display:none}

/* Footer */
.site-footer{background:#07211f;color:#fff;padding:1.2rem 0;margin-top:2.4rem}
.site-footer .footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.site-footer .footer-nav a{color:#fff;text-decoration:none;margin-right:0.6rem;opacity:0.95;font-weight:300}
.site-footer .footer-nav .sep{color:rgba(255,255,255,0.45);margin:0 0.4rem}
.site-footer .copyright{margin:0;font-weight:300}
@media(max-width:600px){
  .site-footer .footer-inner{flex-direction:column;align-items:center;gap:0.6rem}
  .site-footer .footer-nav{order:0;text-align:center}
  .site-footer .footer-nav a{display:inline-block;margin:0 0.4rem}
  .site-footer .copyright{order:1;text-align:center}
}
.site-footer p { font-size: 1em; color:#fff;text-decoration:none}
.site-footer a { font-size: 0.9em; color:#fff;text-decoration:none}

/* Hero */
.main-heading, main h2 {
  font-size:1.8rem;
  margin-bottom:1.5rem;
  font-weight:700;
  letter-spacing:-0.02em;
  color:var(--text);
  text-align: center;
  position:relative;
  padding-bottom:0.6rem;
}
.main-heading::after, main h2::after{
    content:"";
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    bottom:0;
    width:120px;
    height:3px;
    border-radius:4px;
    background:linear-gradient(90deg,var(--main),var(--accent));
    box-shadow:0 6px 18px rgba(16,193,187,0.12);
}

@media(max-width:600px){
  .main-heading, main h2{font-size:1.4rem;padding-bottom:0.5rem}
  .main-heading::after, main h2::after{width:80px;height:3px}
}
.hero{padding:3.2rem 0;background-color:rgba(16,193,187,0.02);background:linear-gradient(90deg,rgba(16,193,187,0.22),rgba(245,197,33,0.2))}
.hero-grid{display:grid;grid-template-columns:1fr 580px;gap:2rem;align-items:center}
main h2.eyebrow{color:var(--sub);font-weight:700;margin:0 0 0.4rem; font-size:1.25em; text-align: left;}
main h2.eyebrow::after {display:none;}
.hero h1{font-size:2.4rem;margin:0.5em 0;line-height:1.2}
.lead{color:rgba(22,50,47,0.9);margin:0 0 1rem}
.hero-ctas{margin-top:30px;display:flex;gap:0.75rem}
.hero-media{width: 580px;}
.media-box{padding:15px;width: 580px;display:flex;align-items:center;justify-content:center;color:#7a8f8d;font-size:0.95rem}
.media-box img {width: 100%;}

/* Content page header (full-width style for content pages) */
.page-intro{
  background: linear-gradient(135deg, rgba(16,193,187,0.35) 0%, rgba(16,193,187,0.12) 40%, rgba(124,183,39,0.35) 100%);
  border-bottom: 1px solid rgba(6,20,19,0.06);
  padding: 3rem 0;
  position: relative;
  overflow: hidden;
}
.page-intro::before{
  /* subtle diagonal stripe overlay for texture */
  content: '';
  position: absolute;
  inset: 0;
  background-image: linear-gradient(135deg, rgba(255,255,255,0.03) 10%, rgba(255,255,255,0) 10%);
  opacity: 0.6;
  pointer-events: none;
}
.page-intro .container{align-items:center;justify-content:center;text-align:center}
.page-intro .main-heading{margin:0;color:#ffffff;font-size:2.6rem;letter-spacing: 0.1em; font-weight:800; line-height:1.6;text-shadow:0 6px 12px #10c1bb;}
.page-intro .subtitle{margin-top:0.6rem;color:rgba(255,255,255,0.95);font-size:1.05rem;font-weight:600;opacity:0.98}
.page-intro h3.lead{display:block;margin:0.8rem auto 0;max-width:900px;color:#333;font-size:1.1rem;font-weight:300;}
/* remove underline for H1 used in page-intro */
.page-intro .main-heading::after{display:none}
@media(max-width:600px){
  .page-intro{padding:1.4rem 0;margin-bottom:1rem}
  .page-intro .main-heading{font-size:1.45rem}
  .page-intro .subtitle{font-size:0.95rem}
  .page-intro p.lead{font-size:0.95rem;padding:0 1rem}
}

/* Buttons */
.btn{display:inline-block;text-decoration:none;padding:0.66rem 1rem;border-radius:10px;transition:all .18s ease}
.btn-primary{background:var(--accent);color:#41300c;box-shadow:0 6px 18px rgba(245,197,33,0.18);font-weight:700}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(245,197,33,0.22)}
.btn-outline{background:#fff;border:2px solid var(--main);color:var(--main);font-weight:600}
.btn-outline:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(255,255,255,0.2)}

/* CTA panel for service pages */
.service-cta{padding:2rem;border-radius:12px;margin:55px 0 0;background:linear-gradient(90deg, rgba(16,193,187,0.08), rgba(124,183,39,0.03));display:flex;flex-direction:column;align-items:center;gap:0.75rem;text-align:center;border:1px solid rgba(6,20,19,0.03)}
.service-cta h2{margin:0;font-size:1.6rem;color:var(--text);font-weight:800}
.service-cta p{max-width:820px;margin:0;color:rgba(22,50,47,0.92);font-size:1rem}
.service-cta .btn-primary{padding:0.95rem 1.3rem;font-size:1.06rem;min-width:240px;border-radius:12px}
.service-cta .btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(15,33,31,0.08)}
@media(max-width:600px){
  .service-cta{padding:1.1rem;border-radius:10px}
  .service-cta h2{font-size:1.15rem}
  .service-cta p{padding:0 1rem}
  .service-cta .btn-primary{width:100%;min-width:0;font-size:1rem;padding:0.85rem}
}

/* CTA actions: align buttons horizontally on desktop, stack on mobile */
.service-cta .cta-actions{display:flex;gap:0.8rem;justify-content:center;align-items:center;margin:1.1rem 0}
@media(max-width:600px){
  .service-cta .cta-actions{flex-direction:column;width:100%}
  .service-cta .cta-actions .btn-primary{width:100%}
}

/* Features */
.features{padding:2rem 0}
.feature-list{display:flex;gap:1rem;padding:0;margin:0;list-style:none}
.feature-list li{flex:1;background:var(--muted);padding:1.1rem;border-radius:12px;box-shadow:0 6px 18px rgba(19,29,28,0.03)}
.feature-list strong{display:block;color:var(--text);margin-bottom:0.4rem}

.how{padding:2rem 0}

.site-footer{background:#07211f;color:#fff;padding:1.2rem 0;margin-top:2.4rem}

/* Small utilities */
.container > h1{margin-top:0}

/* Responsive */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .media-box{width: 100%;height:auto;}
}
@media(max-width:768px){
  .site-nav{display:block; }
  .nav-list{flex-direction:column;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0.01));padding:1rem;border-radius:8px}
  .site-nav{position:fixed;right:0;top:0;bottom:0;left:0;display:none;padding:1.2rem;z-index:60}
  .site-nav.open{display:block}
  .site-nav .nav-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.45);z-index:1;opacity:0;transition:opacity .18s}
  .site-nav .nav-backdrop.open{opacity:1}
  .site-nav .nav-close{position:absolute;top:12px;right:12px;z-index:3;display:none;background:var(--main);color:#fff;border:0;width:40px;height:40px;border-radius:8px;font-size:18px;align-items:center;justify-content:center}
  .site-nav .nav-close.open{display:flex}
  .site-nav .nav-list{position:relative;z-index:2}
  .nav-list{flex-direction:column;background:var(--bg);padding:1.2rem;border-radius:8px;box-shadow:0 12px 30px rgba(3,16,15,0.12)}
  .nav-list a{padding:0.9rem 0.8rem;font-size:1.05rem;color:#10c1bb;border-bottom:1px solid #ccc;}
  .hamburger{display:block}
  body.no-scroll{overflow:hidden;height:100%}
  .feature-list{flex-direction:column}
  .hero h1{font-size:1.6rem}
}

/* accessibility focus */
a:focus{outline:3px solid rgba(16,193,187,0.24);outline-offset:3px}

@media (prefers-reduced-motion: reduce){
  *{transition:none!important}
}

/* Highlight current page via aria-current for links and breadcrumb */
a[aria-current="page"], [aria-current="page"]{
  color: var(--accent);
  font-weight:300;
}


.reasons{display:flex;gap:1rem;list-style:none;padding:0;margin:0 0 1rem 0}
.reasons li{flex:1;background:#e9f8f7;padding:0;border-radius:12px;border:1px solid rgba(6,20,19,0.04);overflow:hidden;display:flex;align-items:center}
.reasons li .reason-icon{background:linear-gradient(135deg,var(--main),var(--sub));width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:12px;margin:0 1rem 0 -8px;flex-shrink:0;box-shadow:0 10px 26px rgba(16,193,187,0.14);padding:0.6rem}
.reasons li .reason-icon svg{display:block;width:48px;height:48px}
.reasons li .reason-icon i{font-size:28px;color:#fff;display:block}
.reasons li .reason-body{padding:1.25rem 1.25rem 1.25rem 0}
.reasons li .reason-body strong{display:block;margin-bottom:0;color:var(--text);font-size:1.05rem;}
.reasons li .reason-body p{margin:0.4rem 0 0;}
/* reasons-grid: 4-column card layout for choice page */
.reasons-list{padding:1.6rem 0}
.reasons-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:0.8rem}
.reason-card{background:#fff;border-radius:12px;padding:1rem;border:1px solid rgba(6,20,19,0.06);box-shadow:0 8px 18px rgba(6,20,19,0.06);text-align:center;display:flex;flex-direction:column;align-items:center}
.reason-card .card-media{width:100%;height:140px;display:flex;align-items:center;justify-content:center;margin-bottom:0.8rem}
.reason-card .card-media img{max-width:100%;max-height:100%;object-fit:cover;border-radius:8px}
.reason-card h3{margin:0 0 0.6rem;font-size:1.05rem;color:var(--text)}
.reason-card p{margin:0;color:#556862;font-size:0.95rem}

@media(max-width:1100px){
  .reasons-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .reasons-grid{grid-template-columns:1fr}
  .reason-card .card-media{height:120px}
}
/* reasons-list custom layout removed — using default .reasons styles */
.testimonials blockquote{background:var(--muted);margin: 1rem 0; padding:1rem 1.2rem;border-left:7px solid var(--main);border-radius:8px;position:relative;padding-left:4rem}
.testimonials blockquote::before{
  /* use Font Awesome user icon inside a circular badge */
  content: "\f007";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  left:12px;
  top:50%;
  transform: translateY(-50%);
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  background-color: var(--main);
  color: #fff;
  border-radius:8px;
  box-shadow:0 8px 22px rgba(16,193,187,0.12);
  font-size:18px;
}

/* Breadcrumb */
.breadcrumb {margin:0 0 2rem; padding: 5px; border-bottom: 1px solid #d6e9e8; width:100% !important;display:block;}
.breadcrumb .container{margin: 0 auto; padding:0;}
.breadcrumb ol{list-style:none;padding:0;margin:0 auto;display:flex;gap:0.6rem;align-items:center;font-size:0.95rem;color:#556862;max-width:var(--max-width);width:100%;}
.breadcrumb a{color:var(--main);text-decoration:none}
.breadcrumb li+li::before{content:'/';color:#9aa6a3;margin-right:0.6rem}
.breadcrumb [aria-current="page"]{color:var(--text);font-weight:300}


/* Pricing cards */
.price-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:start;margin-top:2rem}
.card{flex:1;background:#fff;border-radius:12px;padding:1.2rem;border:1px solid rgba(6,20,19,0.04);box-shadow:0 8px 20px rgba(15,33,31,0.04)}
.card h3{position: relative;margin-top:0;padding-bottom: 8px; font-size:1.35rem;font-weight:700;text-align: center;color: var(--main);}
.card h3::after{
    content:"";
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    bottom:0;
    width:80px;
    height:2px;
    border-radius:4px;
    background:linear-gradient(90deg,var(--main),var(--accent));
    box-shadow:0 6px 18px rgba(16,193,187,0.12);
}
.price{font-size:1.1rem;font-weight:700;color:var(--sub);margin:0.3rem 0 0.8rem;text-align:center}
.note{font-size: 0.9em; text-align: center; margin-top:1rem;color:#556862}
.pcontents{font-size: 1em; margin: 1rem 0; padding: 0; list-style: none;}
.price-image { width: 80%; margin: 0 auto; display: block; }
.price-image img { width: 100%; height: auto; }

/* simple form styles */
input[type="text"],input[type="email"],input[type="tel"],textarea,select{width:100%;padding:0.6rem;border-radius:8px;border:1px solid rgba(6,20,19,0.08);margin-top:0.3rem;box-sizing:border-box}

/* Contact form: card layout, grid and refined controls */
.contact-form{padding:1.2rem; width:100%; max-width:100%; box-sizing:border-box; margin: 0 auto;}
.contact-form form{max-width:100%;margin:0 auto;display:grid;grid-template-columns:1fr;gap:1rem;padding:30px 40px;background:#fff;border-radius:12px;border:1px solid rgba(6,20,19,0.04);box-shadow:0 12px 30px rgba(3,16,15,0.04)}
.contact-form form > div{display:grid;grid-template-columns:35% 65%;align-items:center;gap:1rem}
.contact-form label{font-weight:700;color:var(--text);margin:0;padding-right:0.35rem}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form textarea,
.contact-form select{padding:0.75rem;border-radius:10px;border:1px solid rgba(6,20,19,0.08);background:#fff;transition:all .16s ease;font-size:0.98rem;min-width:0;width:100%;box-sizing:border-box}
.contact-form textarea{min-height:140px;resize:vertical;align-self:start}
.contact-form span{ background-color: #10c1bb; color: #fff; float: right; font-size: 0.75rem; font-weight: 800; padding: 0.15rem 0.5rem; border-radius: 6px; margin-left: 0.5rem; }

/* style select to match inputs and show custom chevron */
.contact-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310c1bb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:18px 18px;padding-right:2.2rem}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--main);box-shadow:0 6px 18px rgba(16,193,187,0.08)}

/* Make message and bottom controls span full width */
.contact-form textarea{min-height:140px;flex:1}
.contact-form form .consent, .contact-form form .form-actions{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between}
.contact-form form .consent label{font-weight:400}
/* center the consent block (checkbox + label) */
.contact-form form .consent{justify-content:center}
/* center submit actions and enlarge the primary button */
.contact-form form .form-actions{justify-content:center}
.contact-form form .form-actions .btn.btn-primary{min-width:260px;padding:0.9rem 1.4rem;font-size:1.2rem;border:none;box-shadow:none}
.contact-form form .form-actions .btn.btn-primary:focus{outline:none;box-shadow:none}
/* center the consent block (checkbox + label) */
.contact-form form .consent{justify-content:center}
.contact-form form .form-actions .btn{min-width:180px}

/* Checkbox styling small tweak */
.contact-form input[type="checkbox"]{width:auto;margin-right:0.6rem;transform:translateY(1px)}

/* helper text */
.contact-form .help{font-size:0.92rem;color:#6f7f7d;margin-top:0.35rem}

@media(max-width:900px){
  .contact-form form{grid-template-columns:1fr}
  .contact-form form .form-actions{justify-content:center}
}

/* Mobile: stack label and input vertically (label 100% then input 100%) */
@media (max-width:768px) {
  .contact-form form > div{grid-template-columns:1fr;align-items:stretch}
  .contact-form form > div label{display:block;margin-bottom:0.5rem}
  .contact-form form > div input,
  .contact-form form > div textarea,
  .contact-form form > div select{width:100%;box-sizing:border-box}
  .contact-form form .consent{justify-content:center}
  .contact-form form .form-actions{justify-content:center}
  .contact-form{padding:0.8rem}
  .contact-form form{padding:0.9rem}
  /* make submit button adapt to small screens */
  .contact-form form .form-actions .btn.btn-primary{min-width:0;width:100%;max-width:none}
  .contact-form form .form-actions .btn{min-width:0}

}

/* Contact grid: title and form side-by-side on wide screens */
  .contact-form form .consent label{display:block;width:100%;text-align:center;padding:0.4rem 0}
  .contact-form form .consent label input[type="checkbox"]{margin-right:0.6rem;vertical-align:middle}
/* Company / simple tables: follow site card design */
.table{background:linear-gradient(180deg,#ffffff,#f8fffe);border-radius:12px;padding:0.8rem;border:1px solid rgba(6,20,19,0.04);box-shadow:0 12px 30px rgba(3,16,15,0.04);overflow:auto}
.table table{width:100%;border-collapse:collapse;min-width:0;table-layout:fixed}
.table th,.table td{word-break:break-word;overflow-wrap:break-word}
.table th,.table td{padding:0.9rem 1rem;text-align:left;vertical-align:top}
.table th{background:linear-gradient(90deg,rgba(16,193,187,0.06),rgba(124,183,39,0.03));color:var(--text);font-weight:700;border-bottom:1px solid rgba(6,20,19,0.04); width: 30%;}
.table td{background:#fff;border-bottom:1px solid rgba(6,20,19,0.03);color:#556862}
.table tr:last-child td{border-bottom:0}

@media (max-width:900px){
  .table th,.table td{padding:0.7rem 0.8rem;font-size:0.95rem; width: auto;}
  .table table{min-width:0}
}


/* required label indicator: use a visible badge (span) when present, fallback to ::after */
label.required span{display:block;background:var(--main);color:#fff;font-weight:800;padding:0.12rem 0.45rem;border-radius:6px;margin-left:0.5rem;font-size:0.85rem; float: right;}

/* Ensure the checkbox label keeps aligned items */
.contact-form .consent label{display:flex;align-items:center;gap:0.6rem}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr}
}

/* Responsive label sizing for contact form */
@media (max-width:1100px){
  .contact-form label{flex:0 0 130px;min-width:110px}
}
@media (max-width:900px){
  .contact-form label{flex:0 0 120px;min-width:90px}
}
@media (max-width:600px){
  .contact-form label{flex:0 0 100px;min-width:70px}
}

/* Common issues cards */
.common-issues {margin-top:2rem;}
.issues-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:0.8rem}
.issues-grid article{background:#fff;border-radius:12px;padding:1rem 1.1rem;border:1px solid rgba(6,20,19,0.06);box-shadow:0 8px 18px rgba(6,20,19,0.1);position:relative;overflow:hidden}
.issues-grid article h3{margin:0 0 0.4rem;font-size:1.05rem;color:var(--text)}
.issues-grid article p{margin:0;color:#556862;font-size:0.95rem}

/* numbered badge */
.issues-grid{counter-reset:issues}
.issues-grid article::before{counter-increment:issues;content:counter(issues);position:absolute;left:1rem;top:1rem;width:36px;height:36px;border-radius:50%;background:var(--main);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 6px 14px rgba(16,193,187,0.14)}
.issues-grid article h3{padding-left:48px}

.issues-img{width:50%;margin:0 auto 0.8rem}
.issues-img img{max-width:100%;object-fit:cover}

/* For service page we use icons inside cards and hide the numeric badge */
.service-list .issues-grid.service-issues article::before{display:none}
.service-list .issues-grid.service-issues article{padding:1rem;border-radius:12px}
.service-list .issues-grid.service-issues .card-head{display:flex;align-items:center;gap:0.9rem;margin-bottom:0.45rem}
.service-list .issues-grid.service-issues .service-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,var(--main),var(--sub));box-shadow:0 10px 24px rgba(16,193,187,0.12);flex-shrink:0}
.service-list .issues-grid.service-issues .service-icon svg{width:28px;height:28px;display:block}
.service-list .issues-grid.service-issues .service-icon i{font-size:20px;color:#fff;display:block}
.service-list .issues-grid.service-issues h3{margin:0;font-size:1.05rem}
.service-list .issues-grid.service-issues p{margin:0;color:#556862}

/* service-card layout: title top, image center, text bottom */
.service-card{padding:1rem;border-radius:12px;background:#fff;border:1px solid rgba(6,20,19,0.06);box-shadow:0 8px 18px rgba(6,20,19,0.06);display:flex;flex-direction:column;align-items:center;text-align:center}
.service-card h3{margin:0 0 0.6rem;font-size:1.05rem;color:var(--text);width:100%;text-align:center;align-self:center;padding-left:0}

/* Ensure service-card titles are not affected by the numbered-badge padding used in other .issues-grid articles */
.service-list .issues-grid.service-issues .service-card h3{
  font-size: 1.25em;
  background: linear-gradient(transparent 70% , #f8d77e 70%);
  padding-left:0;
  margin-left:0;
}
.service-card .card-media{width:100%;height:120px;display:flex;align-items:center;justify-content:center;margin:0.8rem auto}
.service-card .card-media img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}
.service-card p{margin:0;color:#556862;font-size:0.95rem}

@media(max-width:1100px){
  .price-cards{grid-template-columns:repeat(2,1fr)}
  .issues-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:800px){
  .price-cards{grid-template-columns:1fr}
}
@media(max-width:600px){
  .issues-grid{grid-template-columns:1fr}
  .issues-grid article::before{left:calc(50% - 18px);top:12px}
  .issues-grid article h3{padding-left:0;padding-top:36px;text-align:center}
  .issues-grid article p{text-align:center}
}

@media(max-width:600px){
  .testimonials blockquote{padding-left:2.4rem}
  .testimonials blockquote::before{left:10px;width:28px;height:20px;font-size:14px;border-radius:5px}
  .testimonials blockquote::after{left:36px;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:6px solid var(--main)}
}

@media(max-width:800px){
  .reasons{flex-direction:column}
  .reasons li{display:flex}
  .reasons li .reason-icon{width:72px;height:72px;padding:0.45rem;border-radius:12px}
  .reasons li .reason-icon svg{width:34px;height:34px}
  .reasons li .reason-body{padding:0.8rem}
}

/* Proofs / Case studies (口コミ風カード) */
.proofs{padding:1.6rem 0}
.proofs p{color:#556862;margin-bottom:1rem}
.proofs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:0.8rem}
.proof-card{background:#fff;border-radius:12px;padding:1rem;border:1px solid rgba(6,20,19,0.06);box-shadow:0 8px 18px rgba(6,20,19,0.06);display:flex;flex-direction:column;gap:0.6rem}
.proof-meta{display:flex;justify-content:space-between;align-items:center;gap:0.6rem}
.proof-meta .client{font-weight:700;color:var(--text)}
.proof-meta .project-type{font-size:0.9rem;color:var(--main);background:rgba(16,193,187,0.06);padding:0.2rem 0.6rem;border-radius:8px}
.proof-card .quote{
  margin:0;
  color:#1f3b38;
  background: #ecfafa; /* rgba(16,193,187,0.08) over white */
  padding:1rem;
  border-radius:12px;
  position:relative;
  font-style:normal;
}
.proof-card .quote::before{
  content:'“';
  font-size:32px;
  color:var(--main);
  position:absolute;
  left:12px;
  top:-10px;
}
.proof-card .quote::before{
  /* removed: decorative border triangle disabled per request */
  display:none;
}
.proof-card .quote::after{
  /* speech bubble tail (foreground) - left ~25%; color matches bubble background */
  content:'';
  position:absolute;
  left:25%;
  transform:translateX(-50%);
  bottom:-16px;
  width:0;
  height:0;
  border-left:13px solid transparent;
  border-right:13px solid transparent;
  border-top:16px solid #ecfafa; /* same solid color as .quote background */
}

.proof-footer{display:flex;align-items:center;gap:0.8rem;margin-top:0.75rem}
.avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,var(--main),var(--sub));color:#fff}
.avatar svg{width:22px;height:22px;fill:currentColor}
.proof-footer .proof-meta{display:block}
.proof-footer .client{font-weight:700;color:var(--text);font-size:0.98rem}

@media(max-width:900px){
  .proofs-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .proofs-grid{grid-template-columns:1fr}
  .proof-card{padding:0.9rem}
}

/* FAQ styling */
.faq-list{margin-top:1.2rem}
.faq-list details{border:1px solid rgba(6,20,19,0.1);border-radius:12px;margin:0.6rem 0;overflow:hidden;background:#fff}
.faq-list summary{list-style:none;display:flex;align-items:center;justify-content:flex-start;gap:0.8rem;padding:1rem 1.1rem;cursor:pointer;font-weight:700;color:var(--text); font-size:1.15rem}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::before{content:"Q";display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--main),var(--sub));color:#fff;font-weight:800;margin:0;font-size:18px}
.faq-list summary .summary-text{flex:1;text-align:left}
.faq-list summary::after{content:'';width:28px;height:28px;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310c1bb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:center;transition:transform .18s ease}
.faq-list details[open] summary::after{transform:rotate(180deg)}
.faq-list .answer{padding:1rem 1.1rem 1.2rem;background:linear-gradient(180deg,#ffffff,#f8fffe);color:#26403d;display:flex;align-items:center;gap:0.8rem}
.faq-list .answer::before{content:'A';display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--accent);color:#fff;font-weight:800;margin:0;font-size:18px}
.faq-list .answer p{margin:0;flex:1;line-height:1.45}
.faq-list summary .summary-text{line-height:1.45}

@media(max-width:600px){
  .faq-list summary{padding:0.9rem}
  .faq-list .answer{padding:0.8rem}
  /* prevent badge shrinking on small screens */
  .faq-list summary::before,
  .faq-list .answer::before{
    width:36px;
    height:36px;
    flex:0 0 36px;
    font-size:16px;
    border-radius:8px;
  }
  .faq-list summary .summary-text,
  .faq-list .answer p{
    line-height:1.4;
  }
}

/* Flow steps (サービスの流れ) */
.flow-steps{padding:1.6rem 0}
.flow-steps ol{display:block;list-style:none;padding:0;margin:0}
.flow-step{background:#fff;border-radius:12px;padding:1rem;border:1px solid rgba(6,20,19,0.06);box-shadow:0 8px 20px rgba(6,20,19,0.04);display:flex;gap:0.9rem;align-items:flex-start;margin:0 auto}
.flow-step .step-index{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--main),var(--sub));color:#fff;font-weight:800;flex:0 0 48px;font-size:18px}
.flow-step .step-body h3{margin:0 0 0.4rem;font-size:1.05rem;color:var(--text)}
.flow-step .step-body p{margin:0;color:#556862;font-size:0.95rem;line-height:1.5}
.flow-note{margin-top:0.8rem;color:#556862;text-align:center}

/* spacing between steps */
.flow-step + .flow-step{margin-top:1.1rem}

/* arrow list item placed between steps (visible on all widths) */
.flow-arrow{list-style:none;height:56px;display:flex;align-items:center;justify-content:center}
.flow-arrow .arrow-icon{width:34px;height:34px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310c1bb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:center;background-size:contain}

@media(max-width:600px){
  .flow-step{padding:0.9rem;gap:0.7rem}
  .flow-step .step-index{width:40px;height:40px;flex:0 0 40px;font-size:16px}
  .flow-arrow{height:44px}
  .flow-arrow .arrow-icon{width:28px;height:28px}
}

/* choice ページ専用: need-repaire セクションを「左テキスト / 右イメージ」にする
   スコープを .choice-page に限定して他ページに影響しないようにする */
.choice-page .need-repaire{
  margin:1.8rem 0;
  width: 1200px !important;
}
/* 見出しは全幅にして中央寄せ */
.choice-page .need-repaire h2{margin:0 0 2rem;text-align:center}
/* rpaire-box を flex で左右並びにする（デフォルトはモバイル向けに text 左 / image 右） */
.choice-page .need-repaire .rpaire-box{display:flex;flex-direction: row-reverse; align-items: center; width: 100%;}
.choice-page .need-repaire .rpaire-box .need-repaire-text{width: 50%;min-width:0;margin:0 2% 0 0;color:#556862}
.choice-page .need-repaire .rpaire-box .need-repaire-image{width:48%;}
.choice-page .need-repaire .rpaire-box .need-repaire-image img{width:100%;height:auto;display:block;border-radius:8px;max-width:100%}
.choice-page .need-repaire > *{min-width:0}
.choice-page .need-repaire .rpaire-box .need-repaire-text h3{margin-top:0;color:var(--text);font-size:1.35rem;color:#1f3b38;}
/* 中サイズでイメージを少し小さく */
@media (max-width:900px){
  .choice-page .need-repaire .rpaire-box img{flex-basis:300px}
}

/* スマホでは縦積みにする */
@media (max-width:700px){
  .choice-page .need-repaire .rpaire-box{flex-direction:column}
  .choice-page .need-repaire .rpaire-box img{flex-basis:auto;max-width:100%;margin-top:0.6rem}
}

/* Top page: ensure hero media never forces horizontal scroll on small screens
   Scoped to .hero so other pages are unaffected */
@media (max-width:640px) {
  .hero { overflow-x: hidden; }
  .hero .hero-grid { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .hero .hero-media, .hero .media-box { width: 100% !important; max-width: 100% !important; box-sizing: border-box; }
  .hero .media-box img { width: 100%; height: auto; display: block; max-width:100%; }
  /* guard against large images inside hero-content */
  .hero .hero-content, .hero .hero-media { min-width: 0; }
}

.sp_none {
    display:block;
}
.pc_none {
    display:none;
}
@media (max-width: 768px) {
    .pc_none {
        display: block;
    }
    .sp_none {
        display: none;
    }
}
p.contact_caution {
    font-size: 0.85em;
    line-height: 1.2;
    color: #e93939;
    text-align: center;
    font-weight: bolder;
    padding-top: 5px;
    margin-bottom: 45px;
}