@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;600;700&family=Noto+Sans+JP:wght@300;400;500;700&family=Shippori+Mincho:wght@400;600;700;800&display=swap');

/* ============================================
   工藤工業株式会社 統合スタイルシート
   元のNetlifyサイトの全ページCSSを統合
   ============================================ */

/* ===== index ===== */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;
  --blue-pale:#d6eef8;--blue-mist:#eaf5fb;
  --white:#ffffff;--cream:#f8f6f1;
  --gold:#b8960c;--gold-light:#d4af37;
  --text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;
  --border:#c8dde8;--header-h:70px;
}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
/* HERO */
.hero{margin-top:var(--header-h);min-height:100svh;background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 45%,#1a7ab8 100%);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:3rem 1.4rem 5rem;}
.hero-pattern{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.03) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.03) 60px);pointer-events:none;}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;}
.hero-inner{max-width:700px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero-badge{display:inline-block;background:var(--gold);color:var(--white);font-size:10px;letter-spacing:0.15em;padding:5px 14px;margin-bottom:1.2rem;font-weight:500;}
.hero-year{font-family:'Shippori Mincho',serif;font-size:11px;letter-spacing:0.2em;color:rgba(255,255,255,0.55);margin-bottom:0.8rem;}
.hero-title{font-family:'Shippori Mincho',serif;font-size:clamp(26px,5vw,42px);font-weight:700;color:var(--white);line-height:1.55;margin-bottom:1.4rem;letter-spacing:0.04em;}
.hero-title em{font-style:normal;color:var(--blue-light);border-bottom:2px solid var(--gold);padding-bottom:1px;}
.hero-subtitle{font-size:13px;color:rgba(255,255,255,0.85);line-height:2;margin-bottom:2rem;border-left:3px solid var(--gold);padding-left:0.9rem;}
.hero-cta{display:flex;flex-direction:column;gap:10px;max-width:320px}
.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--gold);color:var(--white);padding:14px 24px;font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;text-decoration:none;transition:background 0.2s;}
.btn-primary:hover{background:#9a7a08}
.btn-secondary{display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,0.1);color:var(--white);border:1.5px solid rgba(255,255,255,0.5);padding:13px 24px;font-size:13px;letter-spacing:0.1em;text-decoration:none;transition:border-color 0.2s,background 0.2s;}
.btn-secondary:hover{border-color:var(--white);background:rgba(255,255,255,0.18)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:2.5rem;border-top:1px solid rgba(255,255,255,0.2);padding-top:1.5rem;}
.stat-item{text-align:center;padding:0.4rem}
.stat-num{font-family:'Shippori Mincho',serif;font-size:26px;font-weight:700;color:var(--gold-light);line-height:1;}
.stat-unit{font-size:11px;color:var(--gold-light)}
.stat-label{font-size:10px;color:rgba(255,255,255,0.65);margin-top:4px;letter-spacing:0.06em}
/* SECTION */
section{padding:4rem 1.4rem}
.sec-inner{max-width:900px;margin:0 auto}
.section-head{margin-bottom:2rem}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:24px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;}
.sec-desc{font-size:13px;color:var(--text-mid);line-height:2;margin-top:0.8rem;}
/* GREETING */
.greeting-section{background:var(--cream)}
.philosophy-box{background:var(--blue-deep);padding:1.6rem;border-left:4px solid var(--gold);margin-bottom:1.5rem}
.philosophy-label{font-family:'Shippori Mincho',serif;font-size:13px;font-weight:700;color:var(--gold-light);margin-bottom:0.6rem;letter-spacing:0.1em}
.philosophy-text{font-family:'Shippori Mincho',serif;font-size:15px;color:var(--white);line-height:2.1;}
.greeting-text{font-size:13px;color:var(--text-mid);line-height:2.2;margin-bottom:1.2rem}
.greeting-sign{text-align:right}
.greeting-sign .company{font-size:11px;color:var(--text-light);letter-spacing:0.08em;margin-bottom:4px}
.greeting-sign .name{font-family:'Shippori Mincho',serif;font-size:18px;font-weight:700;color:var(--text-dark);letter-spacing:0.1em}
/* HISTORY */
.history-section{background:var(--blue-deep);padding:4rem 1.4rem}
.history-section .sec-label{color:var(--gold-light);border-color:var(--gold-light)}
.history-section .sec-title{color:var(--white)}
.history-lead{font-family:'Shippori Mincho',serif;font-size:15px;line-height:2.1;color:rgba(255,255,255,0.88);border-left:3px solid var(--gold);padding-left:1rem;margin-bottom:2rem;}
.timeline{position:relative;margin-top:1.5rem}
.timeline::before{content:'';position:absolute;left:20px;top:0;bottom:0;width:1px;background:rgba(255,255,255,0.2);}
.tl-item{display:flex;gap:1rem;margin-bottom:1.8rem;}
.tl-dot{width:40px;height:40px;flex-shrink:0;border:2px solid var(--gold);border-radius:50%;background:var(--blue-deep);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;}
.tl-dot span{font-size:8px;color:var(--gold);font-weight:700}
.tl-content{padding-top:0.5rem}
.tl-year{font-family:'Shippori Mincho',serif;font-size:13px;color:var(--gold-light);font-weight:600;letter-spacing:0.1em;}
.tl-text{font-size:13px;color:rgba(255,255,255,0.8);line-height:1.7;margin-top:3px}
/* SERVICES */
.services-overview{background:var(--white)}
.svc-grid{display:flex;flex-direction:column;gap:12px}
.svc-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--blue-mid);padding:1.3rem;text-decoration:none;display:block;color:inherit;transition:box-shadow 0.2s;}
.svc-card:hover{box-shadow:0 4px 16px rgba(10,61,107,0.1)}
.svc-card-num{font-size:9px;letter-spacing:0.15em;color:var(--blue-light);font-weight:500;margin-bottom:0.3rem;}
.svc-card-title{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;color:var(--blue-deep);margin-bottom:0.4rem;}
.svc-card-desc{font-size:12px;color:var(--text-mid);line-height:1.8}
.svc-more{display:inline-flex;align-items:center;gap:6px;margin-top:1.5rem;color:var(--blue-mid);font-size:13px;letter-spacing:0.08em;text-decoration:none;border-bottom:1px solid var(--blue-mid);padding-bottom:2px;font-weight:500;}
/* NEWS */
.news-section{background:var(--cream)}
.news-list{display:flex;flex-direction:column}
.news-item{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;}
.news-item:first-child{border-top:1px solid var(--border)}
.news-item:hover{background:var(--blue-mist)}
.news-date{font-size:11px;color:var(--text-light);white-space:nowrap;min-width:80px}
.news-cat{font-size:10px;background:var(--blue-pale);color:var(--blue-mid);padding:2px 8px;border-radius:2px;white-space:nowrap;flex-shrink:0}
.news-title-text{font-size:13px;color:var(--text-dark);line-height:1.7}
.more-btn{display:inline-flex;align-items:center;gap:6px;margin-top:1.5rem;color:var(--blue-mid);font-size:13px;text-decoration:none;border-bottom:1px solid var(--blue-mid);padding-bottom:2px;font-weight:500;}
/* CONTACT */
.contact-section{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);text-align:center;}
.contact-section .sec-label{color:var(--gold-light);border-color:var(--gold-light)}
.contact-section .sec-title{color:var(--white)}
.contact-lead{font-size:13px;color:rgba(255,255,255,0.82);line-height:2;margin-bottom:2rem}
.tel-block{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.25);padding:1.5rem;margin-bottom:1rem;}
.tel-label-big{font-size:10px;letter-spacing:0.15em;color:rgba(255,255,255,0.6);margin-bottom:0.5rem}
.tel-number{font-family:'Shippori Mincho',serif;font-size:30px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;display:block;text-decoration:none;}
.tel-hours{font-size:11px;color:rgba(255,255,255,0.55);margin-top:6px}
.address-block{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-top:1rem;border-top:1px solid rgba(255,255,255,0.15);padding-top:1rem;}
.address-block strong{color:rgba(255,255,255,0.92);font-weight:500}
/* FOOTER */
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem;}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem;}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem;}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
/* STICKY */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){
  .pc-nav,.header-tel{display:none}
  .hamburger{display:flex}
  .header-tel-sp{display:block;text-align:right;text-decoration:none}
  .header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light);}
  .header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}
}
@media(min-width:901px){
  .drawer,.drawer-overlay,.sticky-cta{display:none}
  body{padding-bottom:0}
  .hero{padding:4rem 2rem 6rem}
  .svc-grid{display:grid;grid-template-columns:repeat(2,1fr)}
}



/* ===== services ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3;margin-bottom:0.6rem}
.page-lead{font-size:13px;color:rgba(255,255,255,0.78);line-height:2;border-left:3px solid var(--gold);padding-left:1rem}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
.content-wrap{max-width:900px;margin:0 auto;padding:3rem 1.4rem 2rem}
.sec-block{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.sec-block:last-child{border-bottom:none}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;margin-bottom:1.2rem}
.contact-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);padding:3rem 1.4rem;text-align:center;margin-top:2rem}
.cb-inner{max-width:600px;margin:0 auto}
.cb-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.7rem}
.cb-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:0.8rem}
.cb-lead{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-bottom:1.5rem}
.cb-tel{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.cb-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
.svc-index{background:var(--cream);border-bottom:1px solid var(--border);padding:1rem 1.4rem;position:sticky;top:var(--header-h);z-index:100;}
.svc-index-inner{max-width:900px;margin:0 auto}
.svc-index-list{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.4rem}
.svc-index-list a{font-size:11px;color:var(--blue-mid);background:var(--white);border:1px solid var(--border);padding:5px 10px;text-decoration:none;border-radius:2px;white-space:nowrap;transition:background 0.15s,color 0.15s;}
.svc-index-list a:hover{background:var(--blue-mid);color:var(--white)}
.svc-block{padding:3rem 0;border-bottom:1px solid var(--border)}
.svc-block:last-child{border-bottom:none}
.svc-head{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.8rem}
.svc-no{font-family:'Shippori Mincho',serif;font-size:11px;font-weight:700;letter-spacing:0.12em;color:var(--white);background:var(--blue-mid);padding:4px 10px;white-space:nowrap;flex-shrink:0;margin-top:4px}
.svc-cat{font-size:9px;letter-spacing:0.2em;color:var(--blue-light);margin-bottom:4px}
.svc-name{font-family:'Shippori Mincho',serif;font-size:clamp(18px,4vw,24px);font-weight:700;color:var(--blue-deep);line-height:1.35;letter-spacing:0.04em}
.svc-body{display:flex;flex-direction:column;gap:1.4rem}
.svc-desc{font-size:13px;color:var(--text-mid);line-height:2.1}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:1rem}
.svc-tag{font-size:11px;background:var(--blue-pale);color:var(--blue-mid);padding:4px 10px;border-radius:2px}
.ph-box{width:100%;aspect-ratio:16/9;background:var(--blue-mist);border:1px solid var(--border);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;gap:0.4rem}
.ph-box .ph-num{font-family:'Shippori Mincho',serif;font-size:32px;font-weight:700;color:var(--border)}
.ph-box .ph-lbl{font-size:10px;color:var(--text-light);letter-spacing:0.08em}
.slider-wrap{position:relative;overflow:hidden;border-radius:4px;flex-shrink:0}
.slider-track{display:flex;transition:transform 0.6s cubic-bezier(0.4,0,0.2,1);}
.slide-old{}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(10,61,107,0.7);color:var(--white);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;}
.slider-btn.prev{left:8px}.slider-btn.next{right:8px}
.slider-dots{display:flex;justify-content:center;gap:8px;margin-top:0.6rem}
.dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;border:none;padding:0;transition:background 0.2s,transform 0.2s;}
.dot.active{background:var(--blue-mid);transform:scale(1.2)}
.wp-note{font-size:10px;color:var(--text-light);text-align:center;margin-top:0.3rem;letter-spacing:0.06em}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(min-width:901px){.svc-body{flex-direction:row;align-items:flex-start}.svc-body .ph-side{width:44%;flex-shrink:0}.svc-body .txt-side{flex:1}.svc-body.rev{flex-direction:row-reverse}.ph-box{aspect-ratio:4/3}.slider-wrap{aspect-ratio:4/3}}
@media(max-width:900px){.slider-wrap{aspect-ratio:16/9}.ph-box{aspect-ratio:16/9}}
.slide{position:relative;width:100%;flex-shrink:0;display:flex;flex-direction:column;}
.slide-label{background:var(--blue-deep);padding:0.5rem 0.8rem;min-height:36px;display:flex;align-items:center;}
.slide-works-name{font-family:'Shippori Mincho',serif;font-size:12px;font-weight:600;color:var(--gold-light);letter-spacing:0.06em;}
.slide .ph-box{flex:1;border-radius:0;border-top:none;}


/* ===== history ===== */

*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}
.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3;margin-bottom:0.6rem}
.page-lead{font-size:13px;color:rgba(255,255,255,0.78);line-height:2;border-left:3px solid var(--gold);padding-left:1rem}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
.content-wrap{max-width:900px;margin:0 auto;padding:3rem 1.4rem 2rem}
.sec-block{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.sec-block:last-child{border-bottom:none;padding-bottom:1rem}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;margin-bottom:1.2rem}
.body-text{font-size:13px;color:var(--text-mid);line-height:2.1}
.body-text p{margin-bottom:0.8rem}
.contact-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);padding:3rem 1.4rem;text-align:center;margin-top:2rem}
.cb-inner{max-width:600px;margin:0 auto}
.cb-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.7rem}
.cb-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:0.8rem}
.cb-lead{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-bottom:1.5rem}
.cb-tel{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.cb-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
.history-timeline{position:relative;padding-left:2.5rem;margin-top:1rem}
.history-timeline::before{content:'';position:absolute;left:10px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold),var(--blue-pale))}
.ht-item{position:relative;margin-bottom:2rem}
.ht-dot{position:absolute;left:-2.1rem;top:4px;width:14px;height:14px;border-radius:50%;border:3px solid var(--gold);background:var(--white);z-index:1}
.ht-item.now .ht-dot{background:var(--blue-mid);border-color:var(--blue-mid)}
.ht-year{font-family:'Shippori Mincho',serif;font-size:13px;font-weight:700;color:var(--gold);letter-spacing:0.08em;margin-bottom:5px}
.ht-item.now .ht-year{color:var(--blue-mid)}
.ht-ttl{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:4px}
.ht-txt{font-size:13px;color:var(--text-mid);line-height:1.8}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);margin-bottom:2rem}
.stat-box{padding:1.2rem 0.8rem;text-align:center;border-right:1px solid var(--border)}
.stat-box:last-child{border-right:none}
.stat-num{font-family:'Shippori Mincho',serif;font-size:26px;font-weight:700;color:var(--blue-deep)}
.stat-unit{font-size:11px;color:var(--blue-mid)}
.stat-lbl{font-size:10px;color:var(--text-light);margin-top:4px}
.ph-box{width:100%;aspect-ratio:16/9;background:var(--blue-mist);border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;margin-top:1rem}
.ph-box span{font-size:11px;color:var(--text-light);letter-spacing:0.08em}
@media(max-width:600px){}

/* 施工実績アコーディオン */
.works-item{border:1px solid var(--border);border-radius:4px;margin-bottom:12px;overflow:hidden;cursor:pointer;}
.works-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;background:var(--blue-mist);transition:background 0.2s;}
.works-item:hover .works-header{background:var(--blue-pale)}
.works-item.open .works-header{background:var(--blue-pale)}
.works-header-left{display:flex;align-items:center;gap:0.8rem;flex:1}
.works-cat{font-size:10px;background:var(--blue-mid);color:var(--white);padding:2px 8px;border-radius:2px;white-space:nowrap;letter-spacing:0.06em;flex-shrink:0}
.works-name{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;color:var(--blue-deep);line-height:1.4}
.works-arrow{font-size:12px;color:var(--blue-mid);transition:transform 0.3s;flex-shrink:0}
.works-item.open .works-arrow{transform:rotate(180deg)}
.works-body{display:none;padding:1.2rem}
.works-item.open .works-body{display:block}
.works-photo{width:100%;aspect-ratio:16/9;margin-bottom:1rem}
.ph-placeholder{width:100%;height:100%;background:var(--blue-mist);border:1px dashed var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.ph-placeholder span{font-size:11px;color:var(--text-light);letter-spacing:0.08em}
.works-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:12px}
.works-table tr{border-bottom:1px solid var(--border)}
.works-table td{padding:0.5rem 0.6rem;line-height:1.7;vertical-align:top}
.works-table td:first-child{color:var(--blue-mid);font-weight:500;width:30%;background:var(--cream)}
.works-text{font-size:13px;color:var(--text-mid);line-height:2}

.works-list-toggle:hover .works-header{background:var(--blue-pale)}
.works-list-toggle.open /* カテゴリ別アコーディオン */
.cat-accordion{border:1px solid var(--border);border-radius:4px;margin-bottom:8px;overflow:hidden;cursor:pointer;}
.cat-header{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1.1rem;background:var(--cream);transition:background 0.2s;}
.cat-accordion:hover .cat-header{background:var(--blue-pale)}
.cat-accordion.open .cat-header{background:var(--blue-pale)}
.cat-header-left{display:flex;align-items:center;gap:0.7rem;flex:1}
.cat-badge{font-size:10px;color:var(--white);padding:3px 8px;border-radius:2px;white-space:nowrap;letter-spacing:0.06em;flex-shrink:0}
.cat-title{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;color:var(--blue-deep)}
.cat-arrow{font-size:12px;color:var(--blue-mid);transition:transform 0.3s;flex-shrink:0}
.cat-accordion.open .cat-arrow{transform:rotate(180deg)}
.cat-body{display:none;padding:1rem 1.2rem;background:var(--white);border-top:1px solid var(--border)}
.cat-accordion.open .cat-body{display:block}
.works-ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.works-ul li{font-size:13px;color:var(--text-dark);padding:0.5rem 0.9rem;background:var(--cream);border-left:3px solid var(--blue-light);line-height:1.6}


/* ===== news ===== */

*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
/* ニュースリスト */
.content-wrap{max-width:800px;margin:0 auto;padding:3rem 1.4rem 4rem}
.news-article{border-bottom:1px solid var(--border);overflow:hidden;}
.news-article:first-child{border-top:1px solid var(--border)}
/* タップできるヘッダー行 */
.news-header{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1.2rem 0;cursor:pointer;
  transition:background 0.15s;
}
.news-header:hover{background:var(--blue-mist)}
.news-header .news-date{font-size:11px;color:var(--text-light);white-space:nowrap;min-width:82px;padding-top:2px;flex-shrink:0}
.news-header .news-cat{font-size:10px;background:var(--blue-pale);color:var(--blue-mid);padding:2px 8px;border-radius:2px;white-space:nowrap;flex-shrink:0;margin-top:1px}
.news-header .news-ttl{font-size:13px;color:var(--text-dark);line-height:1.7;flex:1}
.news-header .news-arrow{font-size:12px;color:var(--blue-mid);flex-shrink:0;transition:transform 0.3s;margin-top:2px}
.news-article.open .news-arrow{transform:rotate(180deg)}
/* 展開コンテンツ */
.news-body{
  display:none;
  padding:0 0 1.5rem 0;
}
.news-article.open .news-body{display:block}
/* 写真プレースホルダー */
.news-photo{
  width:100%;aspect-ratio:16/9;
  background:var(--blue-mist);
  border:1px solid var(--border);
  border-radius:4px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;
  margin-bottom:1.2rem;
}
.news-photo .ph-lbl{font-size:11px;color:var(--text-light);letter-spacing:0.08em}
.news-photo .ph-sub{font-size:10px;color:var(--border)}
.news-content{font-size:13px;color:var(--text-mid);line-height:2.1}
.news-content p{margin-bottom:0.8rem}
/* カテゴリ別色 */
.cat-info{background:var(--blue-pale);color:var(--blue-mid)}
.cat-works{background:#e8f5e9;color:#2e7d32}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}


/* ===== company ===== */

*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}
.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3;margin-bottom:0.6rem}
.page-lead{font-size:13px;color:rgba(255,255,255,0.78);line-height:2;border-left:3px solid var(--gold);padding-left:1rem}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
.content-wrap{max-width:900px;margin:0 auto;padding:3rem 1.4rem 2rem}
.sec-block{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.sec-block:last-child{border-bottom:none;padding-bottom:1rem}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;margin-bottom:1.2rem}
.body-text{font-size:13px;color:var(--text-mid);line-height:2.1}
.body-text p{margin-bottom:0.8rem}
.contact-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);padding:3rem 1.4rem;text-align:center;margin-top:2rem}
.cb-inner{max-width:600px;margin:0 auto}
.cb-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.7rem}
.cb-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:0.8rem}
.cb-lead{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-bottom:1.5rem}
.cb-tel{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.cb-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
.info-table{width:100%;border-collapse:collapse}
.info-table tr{border-bottom:1px solid var(--border)}
.info-table td{padding:0.85rem 0.6rem;font-size:13px;vertical-align:top;line-height:1.8}
.info-table td:first-child{color:var(--blue-mid);font-weight:500;width:38%;font-size:12px;letter-spacing:0.04em;background:var(--blue-mist)}
.qual-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.qual-item{padding:0.6rem 0.8rem;font-size:12px;color:var(--text-dark);line-height:1.6;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:0.5rem}
.qual-item:nth-child(odd){border-right:1px solid var(--border)}
.qual-grid{border-bottom:none}
.qual-num{font-weight:700;color:var(--blue-deep);white-space:nowrap}
.org-list{display:flex;flex-direction:column;gap:8px}
.org-item{display:flex;align-items:flex-start;gap:0.8rem;font-size:15px;color:var(--text-dark);line-height:1.8;padding:0.3rem 0}
.org-item::before{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--blue-mid);flex-shrink:0;margin-top:7px}

.map-box{width:100%;max-height:320px;aspect-ratio:16/9;background:var(--blue-mist);border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0.5rem;margin-top:1rem}
.map-box span{font-size:11px;color:var(--blue-mid);letter-spacing:0.08em}
@media(max-width:600px){.qual-grid{grid-template-columns:1fr;border-bottom:none}.qual-item:nth-child(odd){border-right:none}.qual-item{border-bottom:1px solid var(--border);border-top:none}.qual-item:last-child{border-bottom:none}}


/* ===== recruit ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3;margin-bottom:0.6rem}
.page-lead{font-size:13px;color:rgba(255,255,255,0.78);line-height:2;border-left:3px solid var(--gold);padding-left:1rem}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
.content-wrap{max-width:900px;margin:0 auto;padding:3rem 1.4rem 2rem}
.sec-block{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.sec-block:last-child{border-bottom:none}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;margin-bottom:1.2rem}
.contact-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);padding:3rem 1.4rem;text-align:center;margin-top:2rem}
.cb-inner{max-width:600px;margin:0 auto}
.cb-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.7rem}
.cb-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:0.8rem}
.cb-lead{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-bottom:1.5rem}
.cb-tel{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.cb-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
.welfare-ttl{font-family:'Shippori Mincho',serif;font-size:18px;font-weight:700;color:var(--blue-deep);margin-bottom:1.2rem;display:flex;align-items:center;gap:0.6rem;}
.welfare-ttl::before{content:'';display:inline-block;width:4px;height:18px;background:var(--gold);border-radius:2px;flex-shrink:0}
.welfare-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:1.5rem}
.welfare-card{background:var(--white);border:1px solid var(--border);border-radius:4px;padding:1rem;display:flex;align-items:flex-start;gap:0.8rem;}
.wf-label{font-size:11px;letter-spacing:0.08em;color:var(--blue-mid);font-weight:500;margin-bottom:3px}
.wf-text{font-size:13px;color:var(--text-dark);line-height:1.7}
.wf-icon{width:36px;height:36px;flex-shrink:0;background:var(--blue-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px}
.job-card{background:var(--white);border:1px solid var(--border);border-top:4px solid var(--blue-mid);border-radius:0 0 4px 4px;overflow:hidden;margin-bottom:2rem}
.job-hd{background:var(--blue-mist);padding:1.2rem 1.4rem;display:flex;align-items:flex-start;gap:0.8rem;}
.job-num{background:var(--blue-mid);color:var(--white);font-size:10px;font-weight:700;letter-spacing:0.1em;padding:3px 10px;border-radius:2px;flex-shrink:0;margin-top:3px}
.job-name{font-family:'Shippori Mincho',serif;font-size:18px;font-weight:700;color:var(--blue-deep);line-height:1.4}
.job-name small{display:block;font-size:12px;color:var(--text-light);font-weight:400;margin-top:3px}
.job-table{width:100%;border-collapse:collapse}
.job-table tr{border-bottom:1px solid var(--border)}
.job-table td{padding:0.8rem 1.2rem;font-size:13px;vertical-align:top;line-height:1.8}
.job-table td:first-child{background:var(--cream);color:var(--blue-mid);font-weight:500;font-size:12px;width:34%;border-right:1px solid var(--border);}
.salary-ex{margin-top:0.5rem;background:var(--blue-mist);border-radius:4px;padding:0.7rem 0.9rem;font-size:12px;color:var(--text-mid);border-left:2px solid var(--blue-light);}
.apply-box{background:var(--blue-deep);padding:1.4rem}
.apply-ttl{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;color:var(--gold-light);margin-bottom:1rem;}
.apply-row{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:4px;padding:0.9rem 1rem;margin-bottom:0.8rem}
.apply-row .ar-label{font-size:11px;color:rgba(255,255,255,0.6);letter-spacing:0.08em;margin-bottom:4px}
.apply-row .ar-text{font-size:13px;color:rgba(255,255,255,0.88);line-height:1.7}
.apply-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--gold);color:var(--white);padding:13px 20px;font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;text-decoration:none;margin-top:1rem;border-radius:2px;}
@media(min-width:600px){.welfare-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.job-table{display:block}.job-table tr{display:block;border-bottom:1px solid var(--border)}.job-table td{display:block;width:100%!important;border-right:none}.job-table td:first-child{padding:0.5rem 1.2rem;font-size:11px}}

/* ===== contact ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer nav a.active{color:var(--gold-light);border-left:3px solid var(--gold)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3;margin-bottom:0.6rem}
.page-lead{font-size:13px;color:rgba(255,255,255,0.78);line-height:2;border-left:3px solid var(--gold);padding-left:1rem}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
.content-wrap{max-width:900px;margin:0 auto;padding:3rem 1.4rem 2rem}
.sec-block{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.sec-block:last-child{border-bottom:none}
.sec-label{display:inline-block;font-size:9px;letter-spacing:0.2em;color:var(--blue-mid);font-weight:500;border-bottom:1px solid var(--blue-mid);padding-bottom:3px;margin-bottom:0.7rem;}
.sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.45;letter-spacing:0.04em;margin-bottom:1.2rem}
.contact-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,#1a5a8a 100%);padding:3rem 1.4rem;text-align:center;margin-top:2rem}
.cb-inner{max-width:600px;margin:0 auto}
.cb-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.7rem}
.cb-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:0.8rem}
.cb-lead{font-size:12px;color:rgba(255,255,255,0.72);line-height:2;margin-bottom:1.5rem}
.cb-tel{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.cb-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
.tel-section{background:var(--blue-deep);padding:2.5rem 1.4rem;text-align:center;}
.tel-sec-inner{max-width:600px;margin:0 auto}
.tel-sec-label{font-size:9px;letter-spacing:0.2em;color:var(--gold-light);border-bottom:1px solid var(--gold-light);padding-bottom:3px;display:inline-block;margin-bottom:0.8rem}
.tel-sec-title{font-family:'Shippori Mincho',serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:1.2rem}
.tel-box{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.2);padding:1.4rem;margin-bottom:0.6rem}
.tel-box-label{font-size:10px;letter-spacing:0.12em;color:rgba(255,255,255,0.6);margin-bottom:0.5rem}
.tel-big{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:700;color:var(--gold-light);letter-spacing:0.06em;text-decoration:none;display:block}
.tel-hours{font-size:11px;color:rgba(255,255,255,0.5);margin-top:5px}
.form-section{padding:3.5rem 1.4rem;background:var(--cream)}
.form-inner{max-width:620px;margin:0 auto}
.form-row{margin-bottom:1.2rem}
.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-dark);letter-spacing:0.06em;margin-bottom:0.4rem}
.form-req{display:inline-block;font-size:9px;background:var(--blue-mid);color:var(--white);padding:2px 6px;border-radius:2px;margin-left:6px;vertical-align:middle}
.form-input,.form-select,.form-textarea{width:100%;padding:0.75rem 1rem;border:1px solid var(--border);border-radius:4px;font-size:13px;font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);transition:border-color 0.2s,box-shadow 0.2s;appearance:none;-webkit-appearance:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--blue-mid);box-shadow:0 0 0 3px rgba(26,111,168,0.12);}
.form-sw{position:relative}.form-sw::after{content:'▼';position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-light);pointer-events:none;}
.form-textarea{height:150px;resize:vertical;line-height:1.8}
.form-note{font-size:11px;color:var(--text-light);line-height:1.8;margin-bottom:1.5rem;border-left:2px solid var(--border);padding-left:0.8rem}
.form-submit{width:100%;padding:1rem;background:var(--blue-deep);color:var(--white);border:none;border-radius:4px;cursor:pointer;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.1em;display:flex;align-items:center;justify-content:center;gap:8px;transition:background 0.2s;}
.form-submit:hover{background:var(--blue-mid)}
.form-thanks{text-align:center;padding:2.5rem 1rem;background:var(--white);border:1px solid var(--border);border-radius:4px}
.thanks-icon{width:52px;height:52px;border-radius:50%;background:var(--blue-mid);color:var(--white);font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.thanks-title{font-family:'Shippori Mincho',serif;font-size:19px;font-weight:700;color:var(--blue-deep);margin-bottom:0.6rem}
.thanks-text{font-size:13px;color:var(--text-mid);line-height:2}
.thanks-back{display:inline-flex;align-items:center;gap:6px;margin-top:1.5rem;color:var(--blue-mid);font-size:13px;text-decoration:none;border-bottom:1px solid var(--blue-mid);padding-bottom:2px}

/* ===== privacy ===== */

*{margin:0;padding:0;box-sizing:border-box}
:root{--blue-deep:#0a3d6b;--blue-mid:#1a6fa8;--blue-light:#5bb3d8;--blue-pale:#d6eef8;--blue-mist:#eaf5fb;--white:#ffffff;--cream:#f8f6f1;--gold:#b8960c;--gold-light:#d4af37;--text-dark:#1a1a2e;--text-mid:#3a4a5c;--text-light:#6a7f94;--border:#c8dde8;--header-h:70px;}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;padding-bottom:70px}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,61,107,0.97);backdrop-filter:blur(8px);border-bottom:2px solid var(--gold);height:var(--header-h);}
.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:42px;height:42px;background:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.logo-mark svg{width:30px;height:30px}
.logo-text{color:var(--white);line-height:1.25}
.logo-text .kudo-logo-main{font-family:'Shippori Mincho',serif;font-size:15px;font-weight:700;letter-spacing:0.08em;white-space:nowrap}
.logo-text .kudo-logo-sub{font-size:8.5px;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-top:1px;white-space:nowrap}
.pc-nav{display:flex;align-items:center}
.pc-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.05em;padding:0 0.65rem;height:var(--header-h);display:flex;align-items:center;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;}
.pc-nav a:hover,.pc-nav a.active{color:var(--white);border-bottom-color:var(--gold-light);}
.nav-contact-btn{background:var(--gold)!important;color:var(--white)!important;border-bottom:none!important;padding:0 1rem!important;margin-left:0.4rem;font-weight:700!important;height:38px!important;border-radius:3px;font-family:'Shippori Mincho',serif;font-size:13px!important;white-space:nowrap;}
.nav-contact-btn:hover{background:#9a7a08!important;}
.header-tel{color:var(--white);text-align:right;text-decoration:none;flex-shrink:0;}
.header-tel .tel-label{font-size:8.5px;letter-spacing:0.1em;color:rgba(255,255,255,0.6)}
.header-tel .tel-num{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:0.04em;color:var(--gold-light);white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;flex-shrink:0;}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--white);transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.header-tel-sp{display:none}
.drawer{position:fixed;top:var(--header-h);right:0;bottom:0;width:min(300px,85vw);background:var(--blue-deep);border-left:1px solid rgba(212,175,55,0.3);transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow-y:auto;padding:1.5rem 0 3rem;}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,0.5);z-index:998;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer nav a{display:block;color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;letter-spacing:0.06em;padding:1rem 1.8rem;border-bottom:1px solid rgba(255,255,255,0.08);transition:background 0.2s,color 0.2s;}
.drawer nav a:hover{background:rgba(255,255,255,0.06);color:var(--white)}
.drawer-contact-btn{background:var(--gold)!important;color:var(--white)!important;font-family:'Shippori Mincho',serif;font-weight:700!important;text-align:center;margin:0.8rem 1.2rem!important;border-radius:3px;border-bottom:none!important;padding:0.9rem 1.8rem!important;}
.drawer-tel{margin:1.5rem 1.8rem 0;background:rgba(255,255,255,0.06);border:1px solid rgba(212,175,55,0.3);padding:1rem;text-align:center;}
.drawer-tel a{font-family:'Shippori Mincho',serif;font-size:22px;font-weight:700;color:var(--gold-light);text-decoration:none;}
.drawer-tel p{font-size:10px;color:rgba(255,255,255,0.5);margin-top:4px}
.page-hero{margin-top:var(--header-h);background:linear-gradient(160deg,var(--blue-deep) 0%,#0d5285 55%,#1a7ab8 100%);padding:3rem 1.5rem 4rem;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.04) 60px);pointer-events:none;}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;margin-bottom:1.2rem}
.breadcrumb a,.breadcrumb span{font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none}
.breadcrumb .sep{color:rgba(255,255,255,0.35)}.breadcrumb .current{color:var(--gold-light)}
.page-en{font-size:10px;letter-spacing:0.25em;color:var(--gold-light);margin-bottom:0.5rem;font-weight:500}
.page-title{font-family:'Shippori Mincho',serif;font-size:clamp(24px,5vw,36px);font-weight:700;color:var(--white);letter-spacing:0.06em;line-height:1.3}
.page-wave{position:absolute;bottom:-2px;left:0;right:0}
/* コンテンツ */
.content-wrap{max-width:760px;margin:0 auto;padding:3rem 1.4rem 4rem}
.pp-intro{font-size:13px;color:var(--text-mid);line-height:2.1;margin-bottom:2.5rem;padding:1.2rem;background:var(--blue-mist);border-left:3px solid var(--blue-mid);}
.pp-block{margin-bottom:2.5rem}
.pp-h2{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--blue-deep);margin-bottom:0.8rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border);}
.pp-text{font-size:13px;color:var(--text-mid);line-height:2.1}
.pp-text p{margin-bottom:0.8rem}
.pp-text p:last-child{margin-bottom:0}
.pp-list{font-size:13px;color:var(--text-mid);line-height:2;padding-left:1.4rem}
.pp-list li{margin-bottom:0.4rem}
.pp-date{font-size:12px;color:var(--text-light);text-align:right;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);}
footer{background:var(--text-dark);padding:2.5rem 1.4rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;text-align:center}
.footer-logo{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:700;color:var(--white);letter-spacing:0.1em;margin-bottom:1.2rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.3rem 1.2rem;margin-bottom:1.4rem}
.footer-nav a{font-size:11px;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(255,255,255,0.85)}
.footer-copy{font-size:10px;color:rgba(255,255,255,0.28);letter-spacing:0.08em}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:var(--blue-deep);border-top:2px solid var(--gold);padding:0.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:0.8rem;}
.sticky-cta .sc-text{font-size:11px;color:rgba(255,255,255,0.7);line-height:1.4}
.sticky-cta .sc-text strong{color:var(--white);font-size:12px;font-weight:500;display:block}
.sticky-tel{display:flex;align-items:center;gap:6px;background:var(--gold);color:var(--white);text-decoration:none;padding:10px 18px;font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;white-space:nowrap;flex-shrink:0;}
@media(max-width:900px){.pc-nav,.header-tel{display:none}.hamburger{display:flex}.header-tel-sp{display:block;text-align:right;text-decoration:none}.header-tel-sp .tel-num-sp{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--gold-light)}.header-tel-sp .tel-lbl-sp{font-size:8px;color:rgba(255,255,255,0.55)}}
@media(min-width:901px){.drawer,.drawer-overlay,.sticky-cta{display:none}body{padding-bottom:0}.page-hero{padding:4rem 2rem 5rem}}
/* === ロゴテキストのサイズ調整（追記） === */
.logo-text .kudo-logo-main {
  font-size: 22px !important;
}
.logo-text .kudo-logo-sub {
  font-size: 12px !important;
}
/* === トップページ統計項目の数字を白に === */
.hero-stats .stat-num {
  color: #ffffff !important;
}
.hero-stats .stat-unit {
  color: #ffffff !important;
}

/* === 事業案内ページの固定サービスインデックスを非表示 === */
.svc-index {
  display: none !important;
}
/* === トップページ統計項目の数字を白に === */
.hero-stats .stat-num {
  color: #ffffff !important;
}
.hero-stats .stat-unit {
  color: #ffffff !important;
}

/* === 事業案内ページの固定サービスインデックスを非表示 === */
.svc-index {
  display: none !important;
}

/* === スマホヘッダーの電話番号を非表示（下のCTAバーで十分） === */
@media (max-width: 900px) {
  .header-tel-sp {
    display: none !important;
  }
}
/* === スライダー画像のスタイル（追記） === */
.slide-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
  border-radius: 0;
}
@media (min-width: 901px) {
  .slide-img {
    aspect-ratio: 4/3;
  }
}
/* === ヒーロー背景画像（追記 2026/5/2） === */
.hero {
  background: 
    linear-gradient(160deg, rgba(10,61,107,0.95) 0%, rgba(13,82,133,0.93) 45%, rgba(26,122,184,0.92) 100%),
    url('http://kudo.sevennavi.net/wp-content/uploads/2026/05/hero-bg.jpg') center/cover no-repeat;
}
/* === ヒーロー背景画像（追記 2026/5/2 修正版） === */
.hero {
  background: 
    linear-gradient(160deg, rgba(10,61,107,0.78) 0%, rgba(13,82,133,0.72) 45%, rgba(26,122,184,0.68) 100%),
    url('http://kudo.sevennavi.net/wp-content/uploads/2026/05/hero-bg.jpg') center/cover no-repeat;
}
.hero-pattern {
  display: none;
}
/* === 履歴・連絡セクション背景画像（追記 2026/5/2） === */
.history-section {
  background: 
    linear-gradient(160deg, rgba(10,61,107,0.78) 0%, rgba(13,82,133,0.72) 45%, rgba(26,122,184,0.68) 100%),
    url('http://kudo.sevennavi.net/wp-content/uploads/2026/05/history-bg.jpg') center/cover no-repeat;
}
.contact-section {
  background: 
    linear-gradient(135deg, rgba(10,61,107,0.78) 0%, rgba(26,90,138,0.70) 100%),
    url('http://kudo.sevennavi.net/wp-content/uploads/2026/05/contact-bg.jpg') center/cover no-repeat;
}
/* === CONTACT背景（修正版 2026/5/2） === */
.contact-section {
  background: 
    linear-gradient(135deg, rgba(10,61,107,0.30) 0%, rgba(26,90,138,0.25) 100%),
    url('http://kudo.sevennavi.net/wp-content/uploads/2026/05/contact-bg.jpg') center/cover no-repeat;
}
/* === ロゴ画像化対応（追記 2026/5/3） === */
.logo-mark {
  width: auto;
  height: 50px;
  background: transparent;
  border-radius: 0;
  padding: 0;
}
.logo-img {
  height: 50px;
  width: auto;
  display: block;
}
/* === ロゴ スマホ版サイズ制限（追記 2026/5/3） === */
@media (max-width: 900px) {
  .logo-mark {
    height: 40px;
    max-width: 40px;
  }
  .logo-img {
    height: 40px;
    width: auto;
    max-width: 40px;
    object-fit: contain;
  }
}
/* === 社長写真スタイル（追記 2026/5/3） === */
.president-photo {
  display: block;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 0 0.8rem auto;
  border: 3px solid var(--gold-light);
  box-shadow: 0 2px 8px rgba(10,61,107,0.15);
}
/* === 社長写真PC版調整（追記 2026/5/3） === */
@media (min-width: 901px) {
  .greeting-sign {
    margin-top: -1rem;
  }
  .greeting-sign .president-photo {
    width: 180px;
    height: 180px;
  }
}
/* === pc-only PC版だけ表示（追記 2026/5/3） === */
.pc-only {
  display: none;
}
@media (min-width: 901px) {
  .pc-only {
    display: block;
  }
}
/* === ヒーロータイトル「つなぎ続ける」を白色に（追記 2026/5/3） === */
.hero-title em {
  color: #ffffff !important;
}

/* === 代表挨拶 写真の回り込みレイアウト（追記 2026/5/3） === */
.greeting-photo-float {
  display: block;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 1.2rem;
  border: 3px solid var(--gold-light);
  box-shadow: 0 2px 8px rgba(10,61,107,0.15);
}
@media (min-width: 901px) {
  .greeting-photo-float {
    float: right;
    width: 200px;
    height: 200px;
    margin: 0 0 1rem 1.5rem;
    shape-outside: circle(50%);
  }
  .greeting-section .greeting-sign {
    clear: both;
    margin-top: 1.5rem;
  }
}
/* === スマホ版のみ：写真を文章の下に表示（追記 2026/5/3） === */
@media (max-width: 900px) {
  .greeting-section .sec-inner {
    display: flex;
    flex-direction: column;
  }
  .greeting-section .greeting-photo-float {
    order: 99;
    margin: 0 0 0 auto;
  }
  .greeting-section .greeting-sign {
    order: 100;
  }
}