/*
Theme Name: tt5-topthanks
Template: twentytwentyfive
Description: トップサンクス 訪問看護師 採用サイト
Version: 1.0
*/

/* ==============================
   Reset (selective)
   ============================== */
*,*::before,*::after{box-sizing:border-box}
body{overflow-x:clip;font-family:'Noto Sans JP','Zen Maru Gothic',sans-serif;color:#3a3a3a;background:#fffdf9;line-height:1.8;-webkit-text-size-adjust:100%;text-size-adjust:100%;line-break:strict;overflow-wrap:break-word}
html{scroll-behavior:smooth;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:all .3s ease}
ul{list-style:none}
:root{
  --primary:#4a8c8c;--primary-light:#6db3a6;--primary-dark:#3a7070;
  --accent:#e8a87c;--accent-light:#f5d0b3;
  --warm-bg:#fffdf9;--cream:#fef6ee;--light-green:#eef7f2;--soft-gray:#f5f3f0;
  --text-main:#3a3a3a;--text-sub:#6b6b6b;--text-light:#999;--white:#ffffff;
  --shadow:0 4px 20px rgba(74,140,140,0.1);--shadow-lg:0 8px 40px rgba(74,140,140,0.12);
  --radius:16px;--radius-lg:24px;--radius-xl:32px;
}

/* ==============================
   WP FSE Overrides
   ============================== */
.wp-site-blocks{overflow:visible !important}
.wp-site-blocks > header.wp-block-template-part{position:sticky;top:0;z-index:1000}
body .wp-site-blocks > main.wp-block-group{margin-top:0 !important}

/* Kill WP flow gap between top-level sections inside post-content */
.entry-content.is-layout-flow > *,
.wp-block-post-content.is-layout-flow > *,
.wp-block-post-content > *{margin-block-start:0 !important}

/* Kill WP flow gap between template parts in wp-site-blocks */
:where(.wp-site-blocks) > *{margin-block-start:0 !important}

/* Override parent theme link underlines */
a:where(:not(.wp-element-button)){text-decoration:none !important}

/* Override parent theme heading styles - line-height:inherit lets body 1.8 apply; component CSS overrides as needed */
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:inherit;font-size:inherit;overflow-wrap:break-word}
/* Progressive enhancement: auto-phrase enables safe balance for Japanese (Chrome 119+, Safari未対応) */
@supports(word-break:auto-phrase){h1,h2,h3,h4,h5,h6{word-break:auto-phrase;text-wrap:balance}}

/* Override parent theme body font-size (parent uses clamp with font-weight:300) */
body{font-size:16px !important;font-weight:400 !important}

/* Remove WP default flow/flex gaps inside our sections */
.hero .is-layout-flow > *,
.section .is-layout-flow > *,
.cta-band .is-layout-flow > *,
.footer .is-layout-flow > *{margin-block-start:0 !important}
.hero .is-layout-flex,
.section .is-layout-flex,
.cta-band .is-layout-flex,
.footer .is-layout-flex{gap:0}

/* iOS Safari: flex子要素のmin-width修正（テキスト折り返し対策） */
.work-point > *,.timeline-item > *,.flow-steps > *,.hero-tags > *{min-width:0}

/* WP default padding on groups */
.hero .wp-block-group,
.section .wp-block-group,
.cta-band .wp-block-group,
.footer .wp-block-group{padding-top:0;padding-right:0;padding-bottom:0;padding-left:0}

/* ==============================
   Header
   ============================== */
.header{background:rgba(255,253,249,0.95);backdrop-filter:blur(10px);border-bottom:1px solid #e5e5e5;transition:box-shadow .3s ease}
.header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.06)}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px !important;padding-right:24px !important;padding-bottom:12px !important;padding-left:24px !important}
.header-inner.is-layout-flex{gap:0}
.logo{display:flex;align-items:center;gap:10px}
/* Logo image block */
.wp-block-image.logo-img{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important}
.wp-block-image.logo-img img{height:44px;width:auto;object-fit:contain}
.wp-block-image.logo-img a{display:block}
.nav{display:flex;align-items:center;gap:28px}
.nav p{margin-top:0 !important;margin-bottom:0 !important;margin-block-start:0 !important;margin-block-end:0 !important}
.nav a{font-size:14px;font-weight:500;color:var(--text-sub);position:relative;padding:4px 0}
.nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--primary);border-radius:2px;transition:width .3s ease}
.nav a:hover{color:var(--primary)}
.nav a:hover::after{width:100%}
.header-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--accent),#e89b6c);color:var(--white);font-weight:600;font-size:14px;padding:10px 24px;border-radius:50px;box-shadow:0 4px 15px rgba(232,168,124,0.35);transition:all .3s ease}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,168,124,0.45)}

/* Header CTA - WP button overrides */
.header .wp-block-buttons{margin:0}
.header .wp-block-button{margin:0}
div.wp-block-button.header-cta{padding-top:0 !important;padding-right:0 !important;padding-bottom:0 !important;padding-left:0 !important;background:transparent !important;box-shadow:none !important;border:none !important;border-radius:0 !important}
.wp-block-button.header-cta .wp-block-button__link,
.wp-block-button.header-cta .wp-element-button{display:inline-flex !important;align-items:center !important;gap:8px !important;background:linear-gradient(135deg,var(--accent),#e89b6c) !important;color:var(--white) !important;font-weight:600 !important;font-size:14px !important;padding-top:10px !important;padding-right:24px !important;padding-bottom:10px !important;padding-left:24px !important;border-radius:50px !important;box-shadow:0 4px 15px rgba(232,168,124,0.35) !important;transition:all .3s ease !important;border:none !important}
.wp-block-button.header-cta .wp-block-button__link:hover,
.wp-block-button.header-cta .wp-element-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,168,124,0.45) !important}

/* Hamburger button (mobile only) */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;z-index:10}
.hamburger span{width:24px;height:2px;background:var(--text-main);border-radius:2px;transition:all .3s ease}

/* Mobile nav overlay */
.mobile-nav{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(255,253,249,0.98);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-nav.active{display:flex}
.mobile-nav a{font-size:18px;font-weight:600;color:var(--text-main);padding:12px;text-decoration:none !important}
.mobile-nav a:hover{color:var(--primary)}
.mobile-nav .close-btn{position:absolute;top:20px;right:24px;font-size:28px;cursor:pointer;color:var(--text-main);background:none;border:none}
.mobile-nav .btn-line{display:inline-flex;align-items:center;gap:8px;background:#06c755;color:var(--white) !important;font-weight:700;font-size:16px;padding-top:14px;padding-right:36px;padding-bottom:14px;padding-left:36px;border-radius:50px;box-shadow:0 4px 15px rgba(6,199,85,0.3);margin-top:12px}
.mobile-nav .btn-line:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(6,199,85,0.4)}
body.mobile-nav-open{overflow:hidden}

/* ==============================
   Buttons (3-layer pattern for WP)
   ============================== */
/* Layer 1: Standalone */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--white);font-weight:600;font-size:15px;padding:14px 32px;border-radius:50px;border:none;cursor:pointer;box-shadow:0 4px 20px rgba(74,140,140,0.3);transition:all .3s ease}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(74,140,140,0.4);color:var(--white)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;background:var(--white);border:2px solid var(--primary);color:var(--primary);font-weight:600;font-size:15px;padding:12px 28px;border-radius:50px;cursor:pointer;transition:all .3s ease}
.btn-secondary:hover{background:var(--primary);color:var(--white)}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--accent);font-weight:700;font-size:16px;padding:14px 36px;border-radius:50px;box-shadow:0 4px 15px rgba(0,0,0,0.1);transition:all .3s ease;border:none;cursor:pointer}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.15)}
.btn-line{display:inline-flex;align-items:center;gap:8px;background:#06c755;color:var(--white);font-weight:700;font-size:16px;padding:14px 36px;border-radius:50px;box-shadow:0 4px 15px rgba(6,199,85,0.3);transition:all .3s ease;border:none;cursor:pointer}
.btn-line:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(6,199,85,0.4);color:var(--white)}

/* Layer 2: WP wrapper reset */
div.wp-block-button.btn-primary,
div.wp-block-button.btn-secondary,
div.wp-block-button.btn-white,
div.wp-block-button.btn-line{padding-top:0 !important;padding-right:0 !important;padding-bottom:0 !important;padding-left:0 !important;background:transparent !important;box-shadow:none !important;border:none !important;border-radius:0 !important}

/* Layer 3: WP inner link */
.wp-block-button.btn-primary .wp-block-button__link,
.wp-block-button.btn-primary .wp-element-button{display:inline-flex !important;align-items:center !important;gap:8px !important;background:linear-gradient(135deg,var(--primary),var(--primary-light)) !important;color:var(--white) !important;font-weight:600 !important;font-size:15px !important;padding-top:14px !important;padding-right:32px !important;padding-bottom:14px !important;padding-left:32px !important;border-radius:50px !important;border:none !important;box-shadow:0 4px 20px rgba(74,140,140,0.3) !important;transition:all .3s ease !important}
.wp-block-button.btn-primary .wp-block-button__link:hover,
.wp-block-button.btn-primary .wp-element-button:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(74,140,140,0.4) !important;color:var(--white) !important}

.wp-block-button.btn-secondary .wp-block-button__link,
.wp-block-button.btn-secondary .wp-element-button{display:inline-flex !important;align-items:center !important;gap:8px !important;background:var(--white) !important;border:2px solid var(--primary) !important;color:var(--primary) !important;font-weight:600 !important;font-size:15px !important;padding-top:12px !important;padding-right:28px !important;padding-bottom:12px !important;padding-left:28px !important;border-radius:50px !important;transition:all .3s ease !important;box-shadow:none !important}
.wp-block-button.btn-secondary .wp-block-button__link:hover,
.wp-block-button.btn-secondary .wp-element-button:hover{background:var(--primary) !important;color:var(--white) !important}

.wp-block-button.btn-white .wp-block-button__link,
.wp-block-button.btn-white .wp-element-button{display:inline-flex !important;align-items:center !important;gap:8px !important;background:var(--white) !important;color:var(--accent) !important;font-weight:700 !important;font-size:16px !important;padding-top:14px !important;padding-right:36px !important;padding-bottom:14px !important;padding-left:36px !important;border-radius:50px !important;box-shadow:0 4px 15px rgba(0,0,0,0.1) !important;transition:all .3s ease !important;border:none !important}
.wp-block-button.btn-white .wp-block-button__link:hover,
.wp-block-button.btn-white .wp-element-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.15) !important}

.wp-block-button.btn-line .wp-block-button__link,
.wp-block-button.btn-line .wp-element-button{display:inline-flex !important;align-items:center !important;gap:8px !important;background:#06c755 !important;color:var(--white) !important;font-weight:700 !important;font-size:16px !important;padding-top:14px !important;padding-right:36px !important;padding-bottom:14px !important;padding-left:36px !important;border-radius:50px !important;box-shadow:0 4px 15px rgba(6,199,85,0.3) !important;transition:all .3s ease !important;border:none !important}
.wp-block-button.btn-line .wp-block-button__link:hover,
.wp-block-button.btn-line .wp-element-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(6,199,85,0.4) !important;color:var(--white) !important}

/* Buttons container reset */
.hero-buttons .wp-block-buttons,
.cta-band-buttons .wp-block-buttons{display:flex;gap:12px;flex-wrap:wrap}
.hero-buttons .wp-block-buttons{margin-top:8px}
.cta-band-buttons .wp-block-buttons{justify-content:center}

/* ==============================
   Hero
   ============================== */
.hero{padding-top:60px !important;padding-right:24px !important;padding-bottom:80px !important;padding-left:24px !important;background:linear-gradient(170deg,var(--cream) 0%,var(--light-green) 50%,var(--warm-bg) 100%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(109,179,166,0.12) 0%,transparent 70%);border-radius:50%}
.hero::after{content:'';position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(232,168,124,0.1) 0%,transparent 70%);border-radius:50%}
.hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;position:relative;z-index:1}
.hero-content{display:flex;flex-direction:column;gap:20px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--white);border:1px solid rgba(74,140,140,0.15);border-radius:50px;padding-top:6px !important;padding-right:16px !important;padding-bottom:6px !important;padding-left:16px !important;width:fit-content;font-size:13px;color:var(--primary);font-weight:500}
.hero-badge .dot{width:8px;height:8px;background:var(--accent);border-radius:50%;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-family:'Zen Maru Gothic',sans-serif;font-size:clamp(26px,4vw,40px);font-weight:700;line-height:1.5;color:var(--text-main)}
.hero h1 .hl{background:linear-gradient(transparent 60%,rgba(232,168,124,0.3) 60%);padding:0 4px}
.hero-desc{font-size:15px;color:var(--text-sub);line-height:2}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px}
.hero-tags.is-layout-flex{gap:8px}
.hero-tag{background:var(--white);border:1px solid rgba(74,140,140,0.12);border-radius:50px;padding-top:6px !important;padding-right:16px !important;padding-bottom:6px !important;padding-left:16px !important;font-size:13px;color:var(--primary-dark);font-weight:500}
.hero-tag i{color:var(--primary) !important;margin-right:3px}
.hero-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.hero-image{background:var(--white);border-radius:var(--radius-xl);padding-top:16px !important;padding-right:16px !important;padding-bottom:16px !important;padding-left:16px !important;box-shadow:var(--shadow-lg);position:relative}
.hero-image-inner{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--light-green),var(--cream));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-light)}
.hero-float{position:absolute;background:var(--white);border-radius:var(--radius);padding-top:12px !important;padding-right:16px !important;padding-bottom:12px !important;padding-left:16px !important;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:13px}
.hero-float.f1{top:-10px;right:20px;animation:float 4s ease-in-out infinite}
.hero-float.f2{bottom:20px;left:-15px;animation:float 4s ease-in-out infinite 1s}
.hero-float .fi{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.fi.green{background:rgba(109,179,166,0.15)}
.fi.green i{color:var(--primary)}
.fi.orange{background:rgba(232,168,124,0.15)}
.fi.orange i{color:var(--accent)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
/* Hero float text paragraphs */
.hero-float p{margin-top:0 !important;margin-bottom:0 !important;margin-block-start:0 !important;margin-block-end:0 !important}
.hero-float-text{display:flex;flex-direction:column}

/* wp:image block placeholders */
.wp-block-image.hero-image-inner{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important;width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--light-green),var(--cream));border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center}
.wp-block-image.hero-image-inner img{width:100%;height:100%;object-fit:cover}
.wp-block-image.nav-card-img{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important;width:100%;aspect-ratio:16/10;overflow:hidden}
.wp-block-image.nav-card-img img{width:100%;height:100%;object-fit:cover}
.wp-block-image.nav-card-img.c1{background:linear-gradient(135deg,#e8f4f0,#d4ede5)}
.wp-block-image.nav-card-img.c2{background:linear-gradient(135deg,#fef0e5,#fce0cc)}
.wp-block-image.nav-card-img.c3{background:linear-gradient(135deg,#e5eef8,#d0e0f0)}
.wp-block-image.nav-card-img.c4{background:linear-gradient(135deg,#f5eef8,#e8ddf0)}
.wp-block-image.about-img-box{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important;width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--light-green),var(--cream));border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.wp-block-image.about-img-box img{width:100%;height:100%;object-fit:cover}
.wp-block-image.message-photo{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important;width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,var(--cream),var(--light-green));border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.wp-block-image.message-photo img{width:100%;height:100%;object-fit:cover}

/* ==============================
   Section Common
   ============================== */
.section{padding-top:80px !important;padding-right:24px !important;padding-bottom:80px !important;padding-left:24px !important}
.section-header{text-align:center;margin-bottom:50px}
.section-label{display:inline-block;font-size:12px;font-weight:600;letter-spacing:2px;color:var(--primary);text-transform:uppercase;margin-bottom:8px}
.section-title{font-family:'Zen Maru Gothic',sans-serif;font-size:clamp(24px,3.5vw,32px);font-weight:700;color:var(--text-main);margin-bottom:12px}
.section-desc{font-size:15px;color:var(--text-sub);max-width:600px;margin:0 auto}
.section-inner{max-width:1100px;margin:0 auto}
.sub-heading{font-family:'Zen Maru Gothic',sans-serif;font-size:22px;font-weight:700;color:var(--text-main);margin-bottom:24px;display:flex;align-items:center;gap:10px}
.sub-heading.center{justify-content:center}
.sub-heading span i{color:var(--primary) !important}

/* ==============================
   Vision
   ============================== */
.vision-section{background:var(--soft-gray)}
.vision-grid{display:grid !important;grid-template-columns:1fr 1fr;gap:30px}
.vision-card{background:var(--white);border-radius:var(--radius-lg);padding-top:40px !important;padding-right:40px !important;padding-bottom:40px !important;padding-left:40px !important;position:relative;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease;width:100%}
.vision-card:hover{transform:translateY(-4px)}
.vision-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.vision-card.mission::before{background:linear-gradient(90deg,var(--primary),var(--primary-light))}
.vision-card.vision::before{background:linear-gradient(90deg,var(--accent),var(--accent-light))}
.vision-card .v-label{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}
.vision-card.mission .v-label{color:var(--primary)}
.vision-card.vision .v-label{color:var(--accent)}
.vision-card h3{font-family:'Zen Maru Gothic',sans-serif;font-size:20px;font-weight:700;color:var(--text-main);margin-bottom:16px;line-height:1.5}
.vision-card p{font-size:14px;color:var(--text-sub);line-height:1.9;margin:0}

/* ==============================
   Nav Cards
   ============================== */
.nav-cards-section{background:var(--warm-bg)}
.nav-cards{display:grid !important;grid-template-columns:repeat(4,1fr);gap:20px}
.nav-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:all .3s ease;cursor:pointer;border:1px solid rgba(74,140,140,0.06);display:block;position:relative;width:100%}
.nav-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.nav-card-img{width:100%;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-light)}
.nav-card-img.c1{background:linear-gradient(135deg,#e8f4f0,#d4ede5)}
.nav-card-img.c2{background:linear-gradient(135deg,#fef0e5,#fce0cc)}
.nav-card-img.c3{background:linear-gradient(135deg,#e5eef8,#d0e0f0)}
.nav-card-img.c4{background:linear-gradient(135deg,#f5eef8,#e8ddf0)}
.nav-card-body{padding-top:20px !important;padding-right:20px !important;padding-bottom:20px !important;padding-left:20px !important}
.nav-card-body p{margin-top:0 !important;margin-bottom:0 !important}
.nav-card-num{font-size:11px;font-weight:700;color:var(--primary);letter-spacing:1px;margin-bottom:4px}
.nav-card h3{font-family:'Zen Maru Gothic',sans-serif;font-size:16px;font-weight:700;color:var(--text-main);margin-bottom:8px}
.nav-card p{font-size:13px;color:var(--text-sub);line-height:1.7;margin:0}
.nav-card-arrow{display:flex;align-items:center;gap:4px;margin-top:12px;font-size:13px;font-weight:600;color:var(--primary)}
.nav-card-arrow a{position:static}
.nav-card-arrow a::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;z-index:1}
.nav-card-arrow::after{content:'→';transition:transform .3s ease}
.nav-card:hover .nav-card-arrow::after{transform:translateX(4px)}

/* ==============================
   Numbers
   ============================== */
.numbers-section{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:var(--white)}
.numbers-section .section-label{color:rgba(255,255,255,0.7)}
.numbers-section .section-title{color:var(--white)}
.numbers-grid{display:grid !important;grid-template-columns:repeat(4,1fr);gap:24px}
.number-item{text-align:center;padding-top:24px !important;padding-right:16px !important;padding-bottom:24px !important;padding-left:16px !important}
.number-item p{margin-top:0 !important;margin-bottom:0 !important}
.number-item .num{font-family:'Zen Maru Gothic',sans-serif;font-size:clamp(36px,5vw,52px);font-weight:700;display:block;margin-bottom:4px;background:linear-gradient(135deg,var(--white),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.number-item .unit{font-size:16px;-webkit-text-fill-color:var(--accent-light)}
.number-item .label{font-size:14px;color:rgba(255,255,255,0.85);font-weight:500}

/* ==============================
   PAGE 2: About
   ============================== */
.about-section{background:var(--warm-bg)}
.about-work-grid{display:grid !important;grid-template-columns:1fr 1fr;gap:40px;align-items:start;margin-bottom:60px}
.about-img-box{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--light-green),var(--cream));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-light);box-shadow:var(--shadow)}
.about-work-content p{font-size:14px;color:var(--text-sub);line-height:2;margin-bottom:16px}
.work-points{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.work-point{display:flex;gap:12px;align-items:flex-start;background:var(--white);padding-top:16px !important;padding-right:16px !important;padding-bottom:16px !important;padding-left:16px !important;border-radius:var(--radius);box-shadow:var(--shadow)}
.work-point.is-layout-flex{gap:12px;align-items:flex-start}
.work-point-icon{font-size:22px !important;flex-shrink:0;margin-top:2px;color:var(--primary) !important;line-height:1 !important}
.work-point-icon p{margin:0 !important}
.work-point strong{display:block;font-size:14px;color:var(--text-main);margin-bottom:4px}
.work-point span{font-size:13px;color:var(--text-sub)}
.features-grid{display:grid !important;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px;margin-bottom:60px}
.feature-card{background:var(--white);border-radius:var(--radius-lg);padding-top:32px !important;padding-right:32px !important;padding-bottom:32px !important;padding-left:32px !important;box-shadow:var(--shadow);transition:transform .3s ease;position:relative;overflow:hidden;width:100%}
.feature-card:hover{transform:translateY(-4px)}
.feature-num{position:absolute;top:16px;right:20px;font-family:'Zen Maru Gothic',sans-serif;font-size:48px;font-weight:700;color:rgba(74,140,140,0.07)}
.feature-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px !important;margin-bottom:16px}
.feature-icon-wrap p{margin:0 !important;font-size:inherit !important;line-height:1 !important;color:inherit !important}
.feature-icon-wrap.green{background:rgba(109,179,166,0.12)}
.feature-icon-wrap.green i{color:var(--primary) !important}
.feature-icon-wrap.blue{background:rgba(100,150,200,0.12)}
.feature-icon-wrap.blue i{color:#6496c8 !important}
.feature-icon-wrap.orange{background:rgba(232,168,124,0.12)}
.feature-icon-wrap.orange i{color:var(--accent) !important}
.feature-icon-wrap.pink{background:rgba(200,120,140,0.12)}
.feature-icon-wrap.pink i{color:#c8788c !important}
.feature-card h4{font-family:'Zen Maru Gothic',sans-serif;font-size:16px;font-weight:700;color:var(--text-main);margin-bottom:12px;line-height:1.6}
.feature-card p{font-size:13px;color:var(--text-sub);line-height:1.9;margin:0}
.persona-area{background:var(--light-green);border-radius:var(--radius-lg);padding-top:40px !important;padding-right:40px !important;padding-bottom:40px !important;padding-left:40px !important}
.persona-grid{display:grid !important;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}
.persona-req{background:var(--white);border-radius:var(--radius);padding-top:24px !important;padding-right:24px !important;padding-bottom:24px !important;padding-left:24px !important;box-shadow:var(--shadow)}
.persona-req h4{font-family:'Zen Maru Gothic',sans-serif;font-size:16px;font-weight:700;color:var(--primary-dark);margin-bottom:16px}
.persona-req h4 i{margin-right:6px}
.persona-req ul,.persona-req .wp-block-list{display:flex;flex-direction:column;gap:10px;padding-left:0 !important;margin-top:0 !important;margin-bottom:0 !important}
.persona-req li{font-size:14px;color:var(--text-sub);padding-left:20px;position:relative;line-height:1.7;list-style:none !important}
.persona-req li::before{content:'✓';position:absolute;left:0;color:var(--primary);font-weight:700}

/* ==============================
   PAGE 3: Daily Flow
   ============================== */
.daily-section{background:var(--soft-gray)}
.timeline{max-width:700px;margin:0 auto 50px;position:relative}
.timeline::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--primary-light),var(--accent));border-radius:3px}
.timeline-item{display:flex;gap:24px;margin-bottom:32px;position:relative;align-items:flex-start !important;flex-wrap:nowrap !important}
.timeline-item.is-layout-flex{gap:24px;align-items:flex-start !important;flex-wrap:nowrap !important}
.timeline-dot{width:50px;height:50px;min-width:50px;border-radius:50%;background:var(--white);border:3px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:12px !important;font-weight:700 !important;color:var(--primary) !important;flex-shrink:0;z-index:1;box-shadow:var(--shadow)}
p.timeline-dot{margin:0 !important;padding:0 !important}
.timeline-content{background:var(--white);border-radius:var(--radius);padding-top:20px !important;padding-right:24px !important;padding-bottom:20px !important;padding-left:24px !important;box-shadow:var(--shadow);flex:1}
.timeline-content h4{font-family:'Zen Maru Gothic',sans-serif;font-size:16px;font-weight:700;color:var(--text-main);margin-bottom:6px}
.timeline-content h4 i{color:var(--primary) !important;margin-right:6px;font-size:15px !important}
.timeline-content p{font-size:13px;color:var(--text-sub);margin:0;line-height:1.8}
.comfort-grid{display:grid !important;grid-template-columns:repeat(3,1fr);gap:20px}
.comfort-card{background:var(--white);border-radius:var(--radius-lg);padding-top:28px !important;padding-right:28px !important;padding-bottom:28px !important;padding-left:28px !important;text-align:center;box-shadow:var(--shadow);transition:transform .3s ease;width:100%}
.comfort-card:hover{transform:translateY(-4px)}
.comfort-icon{font-size:36px !important;margin-bottom:12px;color:var(--primary) !important;line-height:1 !important}
.comfort-card h4{font-family:'Zen Maru Gothic',sans-serif;font-size:15px;font-weight:700;color:var(--text-main);margin-bottom:8px}
.comfort-card p{font-size:13px;color:var(--text-sub);margin:0;line-height:1.8}

/* ==============================
   PAGE 4: Company
   ============================== */
.company-section{background:var(--warm-bg)}
.message-area{display:grid !important;grid-template-columns:300px 1fr;gap:40px;align-items:start;margin-bottom:60px}
.message-photo{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,var(--cream),var(--light-green));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-light);box-shadow:var(--shadow)}
.message-content h3{font-family:'Zen Maru Gothic',sans-serif;font-size:24px;font-weight:700;color:var(--text-main);margin-bottom:20px;line-height:1.6}
.message-content p{font-size:14px;color:var(--text-sub);line-height:2;margin-bottom:16px}
.message-sign{font-family:'Zen Maru Gothic',sans-serif;font-size:16px;font-weight:700;color:var(--primary-dark);margin-top:20px}

/* Info table (WP table block) */
.wp-block-table.info-table{margin-bottom:0;border-radius:var(--radius-lg);overflow:hidden}
.wp-block-table.info-table table{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border-radius:0}
.wp-block-table.info-table thead{border-bottom:none !important}
.wp-block-table.info-table th,.wp-block-table.info-table td{padding-top:16px !important;padding-right:24px !important;padding-bottom:16px !important;padding-left:24px !important;text-align:left;font-size:14px;border:none !important;border-bottom:1px solid #e5e5e5 !important}
.wp-block-table.info-table th{background:var(--light-green) !important;color:var(--primary-dark);font-weight:600;width:180px;white-space:nowrap}
.wp-block-table.info-table td{color:var(--text-sub)}
.wp-block-table.info-table tr:last-child th,.wp-block-table.info-table tr:last-child td{border-bottom:none !important}
.wp-block-table.info-table a{color:var(--primary);font-weight:500}
.wp-block-table.info-table a:hover{color:var(--primary-dark)}

/* ==============================
   PAGE 5: Recruit
   ============================== */
.recruit-section{background:var(--soft-gray)}

/* Salary tables (WP table block) */
.wp-block-table.salary-table{margin-bottom:24px !important;border-radius:var(--radius-lg);overflow:hidden}
.wp-block-table.salary-table table{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border-radius:0;table-layout:auto !important}
.wp-block-table.salary-table thead{border-bottom:none !important}
.wp-block-table.salary-table th,.wp-block-table.salary-table td{padding-top:14px !important;padding-right:24px !important;padding-bottom:14px !important;padding-left:24px !important;text-align:left;font-size:14px;border:none !important;border-bottom:1px solid #e5e5e5 !important}
.wp-block-table.salary-table thead th{background:linear-gradient(135deg,var(--primary),var(--primary-dark)) !important;color:var(--white) !important;font-weight:600}
.wp-block-table.salary-table tbody th{background:var(--light-green) !important;color:var(--primary-dark);font-weight:600;width:220px}
.wp-block-table.salary-table tbody td{color:var(--text-sub)}
.wp-block-table.salary-table tr:last-child th,.wp-block-table.salary-table tr:last-child td{border-bottom:none !important}

/* Flow steps */
.flow-area{margin-top:60px}
.flow-area-desc{text-align:center;color:var(--text-sub);margin-bottom:32px;font-size:15px}
.flow-steps{display:flex !important;gap:0 !important;justify-content:center;flex-wrap:wrap;margin-top:32px;position:relative;align-items:stretch !important}
.flow-steps.is-layout-flex{gap:0 !important}
.flow-step{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;min-width:160px;position:relative;padding-top:0 !important;padding-right:12px !important;padding-bottom:0 !important;padding-left:12px !important}
.flow-step:not(:last-child)::after{content:'';position:absolute;right:-8px;top:32px;width:24px;height:3px;background:var(--primary-light);border-radius:3px}
.flow-num{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--white) !important;font-family:'Zen Maru Gothic',sans-serif;font-size:22px !important;font-weight:700 !important;display:flex;align-items:center;justify-content:center;margin-bottom:20px !important;box-shadow:0 4px 15px rgba(74,140,140,0.25);line-height:1 !important}
.flow-step h4{font-family:'Zen Maru Gothic',sans-serif;font-size:14px;font-weight:700;color:var(--text-main);margin-bottom:6px}
.flow-step p{font-size:12px;color:var(--text-sub);line-height:1.7;margin:0}

/* ==============================
   CTA Band
   ============================== */
.cta-band{background:linear-gradient(135deg,var(--accent),#e89060);padding-top:50px !important;padding-right:24px !important;padding-bottom:50px !important;padding-left:24px !important;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-50px;left:50%;transform:translateX(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,0.08) 0%,transparent 60%);border-radius:50%}
.cta-band-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.cta-band h2{font-family:'Zen Maru Gothic',sans-serif;font-size:clamp(22px,3vw,28px);font-weight:700;color:var(--white);margin-bottom:12px}
.cta-band p{font-size:15px;color:rgba(255,255,255,0.9);margin-bottom:24px}
.cta-band-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ==============================
   Footer
   ============================== */
.footer{background:#2a3a3a;color:rgba(255,255,255,0.7);padding-top:50px !important;padding-right:24px !important;padding-bottom:30px !important;padding-left:24px !important}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-grid{display:grid !important;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-grid.wp-block-columns{display:grid !important;grid-template-columns:1.5fr 1fr 1fr;gap:40px}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.wp-block-image.footer-logo-img{margin-top:0 !important;margin-bottom:0 !important;margin-left:0 !important;margin-right:0 !important}
.wp-block-image.footer-logo-img img{height:36px;width:auto;object-fit:contain}
.footer-info{font-size:13px;line-height:2;color:rgba(255,255,255,0.6)}
.footer h4{font-size:14px;font-weight:600;color:var(--white);margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links p{margin:0 !important}
.footer-links a{font-size:13px;color:rgba(255,255,255,0.6);transition:color .3s ease}
.footer-links a:hover{color:var(--white)}
.footer-links a i{margin-right:6px;width:16px;text-align:center}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;text-align:center;font-size:12px;color:rgba(255,255,255,0.4)}


/* ==============================
   Additional WP Spacing Overrides
   ============================== */
/* Nested flow gap resets */
.hero-content .is-layout-flow > *,
.hero-image .is-layout-flow > *,
.vision-card .is-layout-flow > *,
.nav-card-body .is-layout-flow > *,
.about-work-content .is-layout-flow > *,
.feature-card .is-layout-flow > *,
.timeline-content .is-layout-flow > *,
.comfort-card .is-layout-flow > *,
.message-content .is-layout-flow > *,
.flow-step .is-layout-flow > *,
.persona-req .is-layout-flow > *,
.flow-area .is-layout-flow > *{margin-block-start:0 !important}

/* WP heading blocks default margin-top override (margin-bottom set by component CSS) */
.hero .wp-block-heading,
.section .wp-block-heading,
.cta-band .wp-block-heading,
.footer .wp-block-heading{margin-top:0}


/* ==============================
   Page Divider
   ============================== */
.wp-block-separator.page-divider{height:6px !important;background:linear-gradient(90deg,var(--primary-light),var(--accent-light),var(--primary-light)) !important;opacity:0.3 !important;border:none !important;max-width:100% !important;margin-top:0 !important;margin-bottom:0 !important;width:100% !important}

/* ==============================
   Responsive
   ============================== */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-content{align-items:center}
  .hero-tags{justify-content:center}
  .hero-buttons{justify-content:center}
  .hero-image{max-width:500px;margin:0 auto;order:-1}
  .nav-cards{grid-template-columns:repeat(2,1fr) !important}
  .numbers-grid{grid-template-columns:repeat(2,1fr) !important}
  .vision-grid{grid-template-columns:1fr !important}
  .about-work-grid{grid-template-columns:1fr !important}
  .features-grid{grid-template-columns:1fr !important}
  .persona-grid{grid-template-columns:1fr !important}
  .message-area{grid-template-columns:1fr !important}
  .message-photo{max-width:300px;margin:0 auto}
  .wp-block-image.message-photo{max-width:300px;margin-left:auto !important;margin-right:auto !important}
  .comfort-grid{grid-template-columns:1fr !important}
  .flow-steps,.flow-steps.is-layout-flex{flex-direction:column !important;align-items:center;gap:40px !important}
  .flow-step:not(:last-child)::after{display:none}
  .footer-grid,.footer-grid.wp-block-columns{grid-template-columns:1fr !important}
}
@media(max-width:768px){
  .nav{display:none !important}
  .header .wp-block-buttons{display:none !important}
  .hamburger{display:flex}
  .wp-block-image.logo-img img{height:36px}
  .hero{padding-top:40px !important;padding-right:20px !important;padding-bottom:60px !important;padding-left:20px !important}
  .section{padding-top:60px !important;padding-right:20px !important;padding-bottom:60px !important;padding-left:20px !important}
  .nav-cards{grid-template-columns:repeat(2,1fr) !important}
  .numbers-grid{grid-template-columns:repeat(2,1fr) !important;gap:16px !important}
  .cta-band-buttons,.cta-band-buttons .wp-block-buttons{flex-direction:column;align-items:center}
  .wp-block-table.info-table th{width:120px;font-size:13px}
  .wp-block-table.salary-table tbody th{width:160px;font-size:13px}
  .vision-card{padding-top:24px !important;padding-right:24px !important;padding-bottom:24px !important;padding-left:24px !important}
  .feature-card{padding-top:20px !important;padding-right:20px !important;padding-bottom:20px !important;padding-left:20px !important}
  .persona-area{padding-top:24px !important;padding-right:24px !important;padding-bottom:24px !important;padding-left:24px !important}
  .hero h1 br,.hero-desc br,.vision-card h3 br,.vision-card p br,.feature-card p br,.nav-card p br,.timeline-content p br,.cta-band p br{display:none}
  .hero-desc,.vision-card p,.about-work-content p,.feature-card p,.comfort-card p,.timeline-content p,.message-content p,.persona-req li,.work-point span{text-align:justify;font-feature-settings:"palt" 1;letter-spacing:-0.04em}
  .comfort-card p,.timeline-content p,.work-point span{line-height:1.9 !important}
  .persona-req li{line-height:1.9 !important}
  .nav-card p{line-height:1.8 !important}
  .vision-card p::after,.feature-card p::after,.nav-card p::after,.comfort-card p::after,.timeline-content p::after,.message-content p::after,.about-work-content p::after{content:'.';display:inline-block;width:0;font-size:0;color:transparent}
}
@media(max-width:480px){
  .hero-buttons,.hero-buttons .wp-block-buttons{flex-direction:column;width:100%}
  .wp-block-button.btn-primary,
  .wp-block-button.btn-secondary{width:100%}
  .wp-block-button.btn-primary .wp-block-button__link,
  .wp-block-button.btn-secondary .wp-block-button__link{width:100%;justify-content:center !important}
  .hero-float{display:none}
  .wp-block-table.info-table th,.wp-block-table.info-table td{padding-top:12px !important;padding-right:16px !important;padding-bottom:12px !important;padding-left:16px !important;font-size:13px}
  .wp-block-table.salary-table th,.wp-block-table.salary-table td{padding-top:10px !important;padding-right:14px !important;padding-bottom:10px !important;padding-left:14px !important;font-size:12px}
}
