/*
Theme Name: Realisma
Theme URI: https://realisma.jp
Author: Realisma Inc.
Author URI: https://realisma.jp
Description: 株式会社Realisma コーポレートサイト用WordPressテーマ
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: realisma
*/

/* ============================================
   REALISMA CORPORATE SITE — WORDPRESS THEME
   ============================================ */

/* ---------- RESET ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ---------- CUSTOM CURSOR (mouse stalker) ---------- */
/* All cursor styling is handled by JS to avoid cache/timing issues.
   JS adds inline styles to body and .cursor elements on init. */

:root{
  --dark:#050524;
  --dark-light:#0a0a3a;
  --blue:#1E4BE8;
  --cyan:#29D6F5;
  --magenta:#DC0183;
  --purple:#8B5CF6;
  --white:#ffffff;
  --bg:#ffffff;
  --bg-light:#F7F8FC;
  --bg-gray:#F0F1F7;
  --text:#1a1a2e;
  --text-sub:#555566;
  --text-light:#888899;
  --border:#E2E3ED;
  --border-light:#EEEFF5;
  --gradient-brand:linear-gradient(135deg,var(--magenta),var(--blue),var(--cyan));
  --gradient-neon:linear-gradient(90deg,var(--cyan),var(--blue),var(--magenta));
  --gradient-text:linear-gradient(90deg,var(--magenta),var(--purple),var(--blue));
  --shadow-sm:0 2px 8px rgba(5,5,36,.04);
  --shadow-md:0 4px 20px rgba(5,5,36,.07);
  --shadow-lg:0 8px 40px rgba(5,5,36,.10);
  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:16px;
  --radius-xl:24px;
  --font-en:'futura-pt','Inter',sans-serif;
  --font-jp:'futura-pt','Noto Sans JP','Inter',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --header-h:80px;
}

html{scroll-behavior:smooth;font-size:16px}

body{
  font-family:var(--font-jp);
  background:var(--bg);
  color:var(--text);
  line-height:1.8;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

a{text-decoration:none;color:inherit;transition:all .3s var(--ease)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{font-family:var(--font-jp);letter-spacing:.02em}

::selection{background:rgba(30,75,232,.15);color:var(--dark)}

/* ---------- UTILITY ---------- */
.container{width:100%;max-width:1100px;margin:0 auto;padding:0 24px}
.container-sm{max-width:780px}
.container-lg{max-width:1280px}

/* PC-only line break */
.pc-only{display:inline}
@media(max-width:768px){.pc-only{display:none}}

.gradient-text{
  background:var(--gradient-brand);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.section-padding{padding:100px 0}

/* Dark accent section */
.dark-section{
  background:var(--dark);
  color:var(--white);
}
.dark-section .section-title{color:var(--white)}
.dark-section .section-label{color:var(--cyan)}
.dark-section .text-sub{color:rgba(255,255,255,.65)}

/* Light gray section */
.light-section{background:var(--bg-light)}

/* ============================================
   HEADER — UNIFIED
   ============================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--dark);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:all .3s var(--ease);
}
.header.scrolled{
  box-shadow:0 4px 20px rgba(0,0,0,.3);
  border-bottom-color:rgba(255,255,255,.1);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);max-width:1100px;margin:0 auto;padding:0 24px;
}

/* Logo — image-based */
.logo{display:flex;align-items:center;z-index:1001}
.logo img{height:32px;width:auto}

/* Nav */
.nav{display:flex;align-items:center;gap:32px}
.nav-link{
  font-size:.82rem;font-weight:500;letter-spacing:.06em;
  color:rgba(255,255,255,.6);position:relative;padding:4px 0;
  font-family:var(--font-en);
}
.nav-link::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:2px;background:var(--cyan);
  transition:width .3s var(--ease);
}
.nav-link:hover{color:var(--white)}
.nav-link:hover::after{width:100%}
.nav-link.active{color:var(--white);font-weight:600}
.nav-link.active::after{width:100%}

.nav-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 28px;background:var(--magenta);
  border:none;border-radius:6px;
  font-size:.82rem;font-weight:600;color:var(--white);
  cursor:pointer;transition:all .3s var(--ease);
  font-family:var(--font-en);letter-spacing:.04em;
}
.nav-cta:hover{background:var(--white);color:var(--dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;z-index:1001;
}
.hamburger span{width:24px;height:2px;background:var(--white);transition:all .3s var(--ease);border-radius:1px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ============================================
   PAGE HERO (sub-pages)
   ============================================ */
.page-hero{
  padding:140px 0 60px;text-align:center;
  background:var(--bg-light);border-bottom:1px solid var(--border-light);
}
.page-hero-label{
  font-family:var(--font-en);font-size:.72rem;font-weight:600;
  letter-spacing:.25em;text-transform:uppercase;color:var(--blue);
  margin-bottom:12px;
}
.page-hero-title{
  font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;
  line-height:1.3;letter-spacing:-.02em;color:var(--dark);
}
.page-hero-sub{
  margin-top:14px;font-size:.92rem;color:var(--text-sub);line-height:1.8;
  max-width:600px;margin-left:auto;margin-right:auto;
}

/* ============================================
   SECTION HEADER
   ============================================ */
.section-header{text-align:center;margin-bottom:56px}

.section-label{
  display:inline-block;font-family:var(--font-en);
  font-size:.72rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue);margin-bottom:12px;
}

.section-title{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;
  line-height:1.35;letter-spacing:-.02em;color:var(--dark);
}
.section-title .accent{
  background:var(--gradient-brand);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.section-lead{
  margin-top:14px;font-size:.92rem;color:var(--text-sub);
  max-width:560px;margin-left:auto;margin-right:auto;line-height:1.8;
}

.neon-divider{
  width:40px;height:3px;background:var(--gradient-neon);
  border-radius:2px;margin:16px auto 0;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 32px;border-radius:9999px;
  font-size:.9rem;font-weight:600;cursor:pointer;
  transition:all .3s var(--ease);border:none;font-family:var(--font-en);
  letter-spacing:.04em;min-width:300px;
}
.btn-primary{
  background:var(--dark);color:var(--white);
}
.btn-primary:hover{background:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}

.btn-outline{
  background:transparent;color:var(--dark);
  border:1px solid var(--border);
}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}

.btn-white{background:var(--white);color:var(--dark)}
.btn-white:hover{background:var(--magenta);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* CTA section buttons — override btn-white */
.cta-section .btn-white,
.cta .btn-white{background:var(--magenta);color:var(--white)}
.cta-section .btn-white:hover,
.cta .btn-white:hover{background:var(--white);color:var(--dark)}

/* Service section CTA button */
.btn-service{background:var(--blue);color:var(--white)}
.btn-service:hover{background:var(--magenta);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* About section CTA button */
.btn-about{background:var(--magenta);color:var(--white)}
.btn-about:hover{background:var(--white);color:var(--dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}

.btn-sm{padding:10px 22px;font-size:.82rem}

/* Arrow on buttons — disabled */
.btn-arrow::after{display:none}

/* ============================================
   CARDS
   ============================================ */
.card{
  background:var(--white);
  border:1px solid var(--border-light);
  border-radius:var(--radius-lg);
  transition:all .35s var(--ease);
  overflow:hidden;
}
.card:hover{
  border-color:var(--border);
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
}

/* Image placeholder */
.img-placeholder{
  background:var(--bg-light);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);font-size:.82rem;font-weight:500;
  position:relative;overflow:hidden;
}
.img-placeholder img{width:100%;height:100%;object-fit:cover}

/* ============================================
   TABLE
   ============================================ */
.data-table{width:100%;border-collapse:collapse}
.data-table tr{border-bottom:1px solid var(--border-light)}
.data-table tr:last-child{border-bottom:none}
.data-table th,.data-table td{padding:20px 24px;text-align:left;vertical-align:top}
.data-table th{
  width:160px;font-size:.88rem;font-weight:600;
  color:var(--dark);white-space:nowrap;
  background:var(--bg-light);
}
.data-table td{font-size:.9rem;color:var(--text-sub);line-height:1.8}

/* Dark table variant */
.dark-section .data-table tr{border-bottom-color:rgba(255,255,255,.08)}
.dark-section .data-table th{background:rgba(255,255,255,.04);color:var(--cyan)}
.dark-section .data-table td{color:rgba(255,255,255,.75)}

/* ============================================
   FORM ELEMENTS
   ============================================ */
.form-group{display:flex;flex-direction:column;gap:8px}

.form-group label{
  font-size:.85rem;font-weight:600;color:var(--text);
  display:flex;align-items:center;gap:8px;
}
.form-group label .required{
  font-size:.6rem;padding:2px 8px;
  background:var(--magenta);color:var(--white);
  border-radius:4px;font-weight:500;
}

.form-group input,
.form-group select,
.form-group textarea{
  padding:14px 16px;background:var(--bg);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:.92rem;font-family:var(--font-jp);
  transition:all .3s var(--ease);outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(30,75,232,.08);
}
.form-group textarea{min-height:150px;resize:vertical}
.form-group select{cursor:pointer;appearance:none}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--text-light)}

/* ============================================
   TAGS
   ============================================ */
.tag{
  display:inline-block;padding:4px 12px;
  font-size:.7rem;font-weight:600;
  border-radius:4px;letter-spacing:.03em;
  min-width:100px;text-align:center;
}
.tag-info{background:rgba(30,75,232,.08);color:var(--blue)}
.tag-media{background:rgba(220,1,131,.08);color:var(--magenta)}
.tag-press{background:rgba(41,214,245,.1);color:#0ea5c9}

/* ============================================
   FOOTER
   ============================================ */
.footer{
  background:var(--dark);color:var(--white);
  padding:72px 0 32px;
}

.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:40px;margin-bottom:48px;
}

.footer-brand .logo-footer{height:28px;margin-bottom:16px}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.8}

.footer-col h4{
  font-size:.72rem;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:20px;
  font-family:var(--font-en);
}
.footer-col a{
  display:block;font-size:.88rem;color:rgba(255,255,255,.6);
  padding:5px 0;transition:all .3s var(--ease);
}
.footer-col a:hover{color:var(--white);transform:translateX(3px)}

.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:28px;border-top:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;gap:16px;
}
.footer-bottom p{font-size:.72rem;color:rgba(255,255,255,.35);font-family:var(--font-en)}

/* ============================================
   SCROLL ANIMATIONS
   ============================================ */
.reveal{opacity:0;transform:translateY(24px);transition:all .6s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.22s}
.reveal-delay-4{transition-delay:.28s}
.reveal-delay-5{transition-delay:.34s}

/* ============================================
   HOME PAGE — HERO (3D Tubes)
   ============================================ */
/* Hero CSS is now self-contained via inline <style> in front-page.php
   using rlsm- prefixed classes for WordPress compatibility. */

/* HOME — Services Grid */
.services{padding:100px 0;background:var(--bg)}
.services .section-header{margin-bottom:56px}

.services-grid{
  max-width:1100px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:repeat(3, 1fr);gap:40px 32px;
}

.service-card{
  display:flex;flex-direction:column;gap:16px;
  border:none;box-shadow:none;background:transparent;
}
.service-card:hover{transform:none;box-shadow:none;border-color:transparent}

.service-card .img-placeholder{aspect-ratio:3/2;border-radius:var(--radius-lg)}

.service-card-num{
  font-size:.75rem;font-weight:600;color:var(--text-light);
  letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-en);
}
.service-card-title{font-size:1.1rem;font-weight:700;color:var(--dark);line-height:1.4}
.service-card-desc{font-size:.9rem;color:var(--text-sub);line-height:1.8}

.services-cta{text-align:center;margin-top:56px}

/* HOME — About Preview */
.about-preview{padding:100px 0}

.about-preview-inner{
  max-width:1100px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}

.about-preview-image .img-placeholder{aspect-ratio:1;border-radius:var(--radius-lg)}

.about-preview-content .section-label{margin-bottom:12px}

.about-preview-title{
  font-size:clamp(1.8rem, 3.5vw, 2.4rem);font-weight:800;
  line-height:1.3;letter-spacing:-.02em;color:var(--white);margin-bottom:20px;
}

.about-preview-desc{
  font-size:.95rem;color:rgba(255,255,255,.8);line-height:1.8;margin-bottom:28px;
}

/* HOME — News */
.news{padding:100px 0;background:var(--bg)}

.news-container{max-width:1100px;margin:0 auto;padding:0 24px}
.news .section-header{margin-bottom:48px}

.news-list{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}

.news-item{
  padding:20px 0;border-bottom:1px solid var(--border-light);
  display:flex;align-items:center;gap:20px;
  transition:all .3s var(--ease);
}
.news-item:last-child{border-bottom:none}
.news-item:hover{transform:translateX(4px)}

.news-date{
  font-family:var(--font-en);font-size:.85rem;
  color:var(--text-light);white-space:nowrap;min-width:90px;
}
.news-tag{flex-shrink:0}
.news-title{flex:1;font-size:.95rem;font-weight:500;color:var(--dark)}
.news-arrow{color:var(--text-light);font-size:.8rem;flex-shrink:0}

.news-link-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.9rem;font-weight:600;color:var(--blue);
  transition:all .3s var(--ease);
}
.news-link-btn:hover{color:var(--dark);transform:translateX(4px)}

/* HOME — CTA (matches SERVICE cta-section) */
.cta{text-align:center;padding:80px 0}
.cta .section-title{margin-bottom:32px}
.cta .btn{margin-top:20px}

/* ============================================
   SERVICE PAGE
   ============================================ */
.service-detail{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;padding:80px 0;border-bottom:1px solid var(--border-light);
}
.service-detail:last-child{border-bottom:none}
.service-detail.reverse{grid-template-columns:1fr 1fr}
.service-detail.reverse .service-image{order:2}
.service-detail.reverse .service-content{order:1}

.service-image{position:relative}
.service-image .img-placeholder{height:500px;border-radius:var(--radius-lg)}

.service-content h3{
  font-size:2rem;font-weight:800;color:var(--dark);
  margin-bottom:16px;letter-spacing:-.02em;
}
.service-number{
  font-family:var(--font-en);font-size:0.85rem;font-weight:600;
  color:var(--text-light);letter-spacing:0.1em;margin-bottom:8px;
}
.service-description{
  font-size:0.95rem;color:var(--text-sub);line-height:1.8;margin-bottom:32px;
}

.service-points{display:flex;flex-direction:column;gap:14px}
.service-points li{
  font-size:0.9rem;color:var(--text);line-height:1.6;
  display:flex;align-items:flex-start;gap:12px;
}
.service-points li::before{content:'-';color:var(--text-light);font-weight:600;flex-shrink:0}

/* Process Flow */
.process-section{padding:60px 0}
.process-header{text-align:center;margin-bottom:60px}

.process-flow{
  display:grid;grid-template-columns:repeat(5, 1fr);gap:20px;
}
.process-step{text-align:center;position:relative}
.process-number{
  font-family:var(--font-en);font-size:2rem;font-weight:500;
  color:var(--blue);margin-bottom:12px;line-height:1;
}
.process-title{font-size:0.95rem;font-weight:600;color:var(--dark);margin-bottom:12px}
.process-desc{font-size:0.82rem;color:var(--text-light);line-height:1.6}

.process-flow .process-step::after{
  content:'\2192';position:absolute;right:-30px;top:5px;
  font-size:1.5rem;color:var(--text-light);font-weight:300;
}
.process-flow .process-step:last-child::after{display:none}

/* CTA Section (service/about shared) */
.cta-section{text-align:center;padding:80px 0}
.cta-section .section-title{margin-bottom:32px}
.cta-section .btn{margin-top:20px}

/* ============================================
   ABOUT PAGE
   ============================================ */
.mission-section{padding:80px 0}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

.mission-content h2{
  font-size:clamp(1.6rem, 3.2vw, 2.2rem);font-weight:800;
  line-height:1.3;letter-spacing:-0.02em;margin-bottom:24px;color:var(--dark);
  white-space:nowrap;
}
.mission-label{
  font-family:var(--font-en);font-size:0.75rem;font-weight:600;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--blue);
  margin-bottom:16px;display:block;
}
.mission-description{font-size:0.95rem;line-height:1.8;color:var(--text-sub)}
.mission-visual{
  position:relative;height:450px;border-radius:var(--radius-lg);
  background:var(--bg-light);display:flex;align-items:center;
  justify-content:center;overflow:hidden;
}

.values-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:32px;margin-top:60px}
.value-card{padding:40px;background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg)}
.value-image{height:200px;margin-bottom:24px;border-radius:var(--radius-md);background:var(--bg-light)}
.value-title{font-size:1.2rem;font-weight:800;margin-bottom:16px;color:var(--dark)}
.value-description{font-size:0.9rem;color:var(--text-sub);line-height:1.8}

.representative-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.representative-image{
  height:500px;border-radius:var(--radius-lg);background:var(--bg-light);margin-bottom:0;
}
.representative-content h2{
  font-size:clamp(1.6rem, 3vw, 2.2rem);font-weight:800;
  line-height:1.2;margin-bottom:8px;color:var(--dark);
}
.representative-title{font-size:0.95rem;color:var(--blue);font-weight:600;letter-spacing:0.05em;margin-bottom:24px}
.representative-bio{font-size:0.9rem;line-height:1.9;color:var(--text-sub);margin-bottom:24px}
.representative-specialties{display:flex;flex-wrap:wrap;gap:12px}
.specialty-tag{
  padding:8px 16px;background:var(--bg-light);border:1px solid var(--border-light);
  border-radius:20px;font-size:0.8rem;font-weight:600;color:var(--text);
}

/* Team Section — Org Chart */
.team-org-chart{display:flex;flex-direction:column;align-items:center;gap:32px;margin-top:60px}
.team-top{width:100%;max-width:600px}
.team-bottom{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;width:100%}
.team-connector{width:1px;height:24px;background:var(--border);margin:0 auto}
.team-department{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:32px 24px;text-align:center;
}
.team-dept-title{font-size:1.05rem;font-weight:700;color:var(--dark);display:block;text-align:center}
.team-dept-title::before{display:none}

/* ============================================
   COMPANY PAGE
   ============================================ */
.company-info{background:var(--white);padding:80px 0}
.info-card{
  max-width:700px;margin:0 auto;background:var(--white);
  border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:48px;
}
.info-card .data-table{width:100%}

.access-section{
  padding:80px 0;display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;
}
.access-text h3{font-size:1.3rem;font-weight:700;margin-bottom:24px;color:var(--dark)}
.access-text p{font-size:.95rem;color:var(--text-sub);line-height:1.9;margin-bottom:16px}

.map-placeholder{
  border-radius:var(--radius-lg);height:400px;overflow:hidden;
}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-section{padding:80px 0}
.contact-lead{
  text-align:center;margin-bottom:48px;max-width:600px;
  margin-left:auto;margin-right:auto;font-size:0.95rem;
  color:var(--text-sub);line-height:1.8;
}
.contact-form-wrapper{max-width:700px;margin:0 auto 64px}
.contact-form-card{
  background:var(--white);border:1px solid var(--border-light);
  border-radius:var(--radius-lg);padding:48px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.form-row.full{grid-template-columns:1fr}

.contact-form-card .form-group input,
.contact-form-card .form-group select,
.contact-form-card .form-group textarea{
  padding:14px 16px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:0.92rem;font-family:var(--font-jp);
  transition:all 0.3s var(--ease);outline:none;
}

.contact-form-card .form-group select{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23555566' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}

.privacy-check{margin:24px 0;display:flex;align-items:flex-start;gap:12px}
.privacy-check input[type="checkbox"]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--blue)}
.privacy-check label{font-size:0.85rem;color:var(--text-sub);margin:0;cursor:pointer;line-height:1.6}
.privacy-check a{color:var(--blue);text-decoration:underline}

.btn-submit{
  width:100%;padding:14px 32px;background:var(--dark);color:var(--white);
  border:none;border-radius:9999px;font-size:0.9rem;font-weight:600;
  cursor:pointer;transition:all 0.3s var(--ease);font-family:var(--font-en);
  letter-spacing:.04em;
}
.btn-submit:hover{background:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* --- Contact Form 7 overrides --- */
.wpcf7 .screen-reader-response{
  position:absolute!important;overflow:hidden!important;
  clip:rect(1px,1px,1px,1px)!important;clip-path:inset(50%)!important;
  width:1px!important;height:1px!important;margin:-1px!important;
  padding:0!important;border:0!important;
}
.wpcf7-form fieldset.hidden-fields-container{
  border:none!important;padding:0!important;margin:0!important;
  min-width:0;
}
.wpcf7 form{border:none!important;outline:none!important}
.wpcf7 form > output,
.wpcf7 .wpcf7-response-output{
  border:none!important;border-top:none!important;border-bottom:none!important;
  margin:16px 0 0!important;padding:12px 16px!important;
  border-radius:var(--radius-sm);font-size:0.85rem;
  box-shadow:none!important;outline:none!important;
}
.wpcf7 form > output:not(.wpcf7-mail-sent-ok):not(.wpcf7-validation-errors){
  display:none!important;padding:0!important;margin:0!important;
}
.wpcf7 .wpcf7-response-output[style*="display: none"]{display:none!important}
.wpcf7 form hr,.contact-form-card hr{display:none!important}
.wpcf7-form .wpcf7-not-valid-tip{
  display:block;font-size:0.78rem;color:var(--magenta);
  margin-top:4px;position:relative;
}
.wpcf7-form .wpcf7-form-control-wrap{
  display:block;position:relative;
}
.wpcf7-form input.wpcf7-form-control,
.wpcf7-form select.wpcf7-form-control,
.wpcf7-form textarea.wpcf7-form-control{
  width:100%;padding:14px 16px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:0.92rem;font-family:var(--font-jp);
  transition:all 0.3s var(--ease);outline:none;
}
.wpcf7-form input.wpcf7-form-control:focus,
.wpcf7-form select.wpcf7-form-control:focus,
.wpcf7-form textarea.wpcf7-form-control:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,75,232,.08);
}
.wpcf7-form input.wpcf7-not-valid,
.wpcf7-form select.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-not-valid{
  border-color:var(--magenta);
}
.wpcf7-form textarea.wpcf7-form-control{min-height:150px;resize:vertical}
.wpcf7-form select.wpcf7-form-control{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23555566' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}
.wpcf7-form .wpcf7-submit,
.wpcf7 input[type="submit"]{
  width:100%!important;padding:14px 32px!important;background:var(--magenta)!important;color:var(--white)!important;
  border:none!important;border-radius:9999px!important;font-size:0.9rem!important;font-weight:600!important;
  cursor:pointer;transition:all 0.3s var(--ease);font-family:var(--font-en);
  letter-spacing:.04em;
}
.wpcf7-form .wpcf7-submit:hover,
.wpcf7 input[type="submit"]:hover{background:var(--blue)!important;color:var(--white)!important;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.wpcf7-form .wpcf7-acceptance{margin:24px 0}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item{
  display:inline-flex!important;align-items:center!important;gap:8px;
  vertical-align:middle;
}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item label{
  display:inline-flex!important;align-items:center!important;gap:8px;
}
.wpcf7-form .wpcf7-acceptance input[type="checkbox"]{
  width:18px!important;height:18px!important;min-width:18px;
  cursor:pointer;accent-color:var(--blue);
  margin:0!important;padding:0!important;
  vertical-align:middle;position:relative;top:-2px;
}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label{font-size:0.85rem;color:var(--text-sub);line-height:1;vertical-align:middle}
.wpcf7-form .wpcf7-acceptance a{color:var(--blue);text-decoration:underline}
.wpcf7-form p{margin:0}
.wpcf7-form .wpcf7-spinner{display:none}
.wpcf7-form label{
  font-size:0.88rem;font-weight:600;color:var(--text);
}
.wpcf7-form label .required,
.wpcf7-form .required{
  font-size:0.7rem;color:var(--magenta);background:rgba(220,1,131,.08);
  padding:2px 8px;border-radius:4px;margin-left:8px;font-weight:600;
}

/* ============================================
   NEWS PAGE
   ============================================ */
.news-section{padding:80px 0}
.news-filters{display:flex;gap:12px;justify-content:center;margin-bottom:48px;flex-wrap:wrap}
.news-filter-btn{
  padding:10px 24px;background:var(--bg-light);border:1px solid var(--border-light);
  border-radius:50px;color:var(--text-sub);font-size:0.88rem;font-weight:500;
  cursor:pointer;transition:all 0.3s var(--ease);
}
.news-filter-btn:hover{border-color:var(--blue);color:var(--blue);background:rgba(30,75,232,.04)}
.news-filter-btn.active{background:var(--blue);border-color:var(--blue);color:var(--white)}

.news-list-page{max-width:800px;margin:0 auto}
.news-list-page .news-item{
  display:grid;grid-template-columns:120px 1fr auto;gap:20px;
  align-items:center;padding:20px 0;border-bottom:1px solid var(--border-light);
  transition:all 0.3s var(--ease);
}
.news-list-page .news-item:last-child{border-bottom:none}
.news-list-page .news-item:hover{transform:translateX(4px)}
.news-item-date{font-size:0.85rem;color:var(--text-light);font-weight:500;font-family:var(--font-en)}
.news-item-content{display:flex;align-items:center;gap:12px}
.news-item-title{font-size:0.95rem;color:var(--dark);font-weight:500}
.news-item-arrow{color:var(--text-light);font-size:0.9rem;margin-left:auto}

/* ============================================
   NEWS ARTICLE (single)
   ============================================ */
.article-wrapper{max-width:720px;margin:0 auto;padding:140px 0 80px}
.breadcrumb{font-size:0.85rem;color:var(--text-light);margin-bottom:32px;font-family:var(--font-en)}
.breadcrumb a{color:var(--text-light)}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb-separator{margin:0 8px}

/* ---------- PRIVACY POLICY PAGE ---------- */
.breadcrumb-bar{padding:12px 0;background:var(--white)}
.pp-section{padding:60px 0 100px}
.pp-card{
  background:var(--white);border-radius:var(--radius-lg);
  padding:48px 40px;box-shadow:var(--shadow-sm);
}
.pp-heading-main{
  font-size:1.3rem;font-weight:700;color:var(--dark);
  margin-bottom:32px;padding-bottom:12px;border-bottom:2px solid var(--dark);
}
.pp-heading{font-size:1.05rem;font-weight:700;color:var(--dark);margin:28px 0 12px}
.pp-section p{font-size:0.92rem;line-height:1.9;color:var(--text-sub)}
.pp-list{margin:12px 0 8px 1.5em;font-size:0.92rem;line-height:1.9;color:var(--text-sub)}
.pp-list li{margin-bottom:4px}
.mt-lg{margin-top:56px}
.pp-contact-box{margin-top:40px;padding:24px;background:var(--bg-light);border-radius:var(--radius-sm)}
.pp-contact-box p{margin-bottom:6px}
.pp-contact-box a{color:var(--blue);text-decoration:underline}
.pp-company-name{font-weight:600;color:var(--dark)!important;margin-top:16px!important}
.pp-footer{margin-top:48px;text-align:right}
.pp-footer p{margin-bottom:4px;font-size:0.88rem}
.pp-date{margin-top:12px!important;font-size:0.82rem!important;color:var(--text-light)!important}
.footer-pp-link{font-size:.72rem;color:rgba(255,255,255,.35);font-family:var(--font-en);text-decoration:none}
.footer-pp-link:hover{color:rgba(255,255,255,.6)}

.article-meta{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.article-date{font-family:var(--font-en);font-size:0.85rem;font-weight:600;color:var(--text-light);letter-spacing:0.02em}

.article-title{
  font-size:1.8rem;font-weight:800;line-height:1.4;color:var(--dark);margin-bottom:32px;
}

.article-body{font-size:0.95rem;line-height:1.9;color:var(--text-sub)}
.article-body p{margin-bottom:24px}
.article-body p:last-child{margin-bottom:0}
.article-body strong{color:var(--dark);font-weight:600}

.article-back{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-light)}
.article-back a{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--blue);font-weight:500;font-size:0.9rem;transition:all 0.3s var(--ease);
}
.article-back a:hover{transform:translateX(4px)}

/* ============================================
   WORDPRESS SPECIFIC
   ============================================ */
.wp-block-image img{border-radius:var(--radius-md)}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.alignleft{float:left;margin:0 24px 16px 0}
.alignright{float:right;margin:0 0 16px 24px}

/* Pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:48px}
.pagination a,.pagination span{
  padding:10px 16px;border:1px solid var(--border-light);border-radius:var(--radius-sm);
  font-size:.88rem;color:var(--text-sub);transition:all .3s var(--ease);
}
.pagination a:hover{border-color:var(--blue);color:var(--blue)}
.pagination .current{background:var(--blue);border-color:var(--blue);color:var(--white)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .service-detail,
  .service-detail.reverse{grid-template-columns:1fr;gap:40px}
  .service-detail.reverse .service-image,
  .service-detail.reverse .service-content{order:0}
  .service-image .img-placeholder{height:auto;aspect-ratio:16/9}
  .process-flow{grid-template-columns:repeat(5, 1fr);gap:12px}
  .process-flow .process-step::after{right:-12px;font-size:1.1rem;top:2px}
  .mission-grid,.representative-grid{grid-template-columns:1fr;gap:50px}
  .mission-visual{height:350px}
  .representative-image{height:400px}
  .values-grid{grid-template-columns:repeat(2, 1fr)}
}

@media(max-width:768px){
  :root{--header-h:64px}
  .nav{display:none}
  .hamburger{display:flex}
  .nav.mobile-open{
    display:flex;position:fixed;top:0;left:0;
    width:100%;height:100vh;height:100dvh;
    background:var(--dark);
    flex-direction:column;align-items:center;justify-content:center;
    gap:32px;z-index:1002;
    overflow-y:auto;
  }
  .nav.mobile-open .nav-link{
    font-size:1.3rem;font-weight:500;color:var(--white);
    opacity:.85;font-family:var(--font-en);letter-spacing:.08em;
    padding:8px 0;
  }
  .nav.mobile-open .nav-link::after{display:none}
  .nav.mobile-open .nav-link:hover,
  .nav.mobile-open .nav-link.active{opacity:1}
  .nav.mobile-open .nav-cta{
    padding:16px 48px;font-size:1rem;margin-top:16px;
    border-radius:8px;
  }

  .btn{min-width:0;width:100%;max-width:400px}
  main{overflow-x:hidden}
  .page-hero{padding:110px 0 48px}
  .section-padding{padding:72px 0}
  .footer-grid{grid-template-columns:1fr;gap:0;text-align:center}
  .footer-brand{margin-bottom:24px}
  .footer-brand .logo-footer{margin:0 auto 16px}
  .footer-address{margin-top:24px}
  .footer-col a{display:block;text-align:center}
  .footer-bottom{flex-direction:column;text-align:center}
  .pp-card{padding:28px 20px}
  .pp-heading-main{font-size:1.15rem}
  .wpcf7-form .wpcf7-acceptance .wpcf7-list-item,
  .wpcf7-form .wpcf7-acceptance .wpcf7-list-item label{
    font-size:0.75rem!important;
  }
  .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label{font-size:0.75rem!important}
  .wpcf7-form .wpcf7-acceptance a{font-size:0.75rem!important}
  .privacy-check label{font-size:0.75rem!important}
  .cursor{display:none!important}
  .data-table th,.data-table td{padding:14px 16px}
  .data-table th{width:120px}

  /* Hero responsive is now handled by inline rlsm- styles */
  .services-grid{grid-template-columns:1fr 1fr;gap:32px 24px}
  .about-preview-inner{grid-template-columns:1fr;gap:40px}
  .services,.about-preview,.news,.cta{padding:60px 0}
  .news-item{flex-direction:column;align-items:flex-start;gap:12px}
  .news-date{min-width:100%}

  .service-detail,
  .service-detail.reverse{grid-template-columns:1fr;gap:32px;padding:48px 0}
  .service-detail.reverse{direction:ltr}
  .service-detail.reverse .service-image,
  .service-detail.reverse .service-content{order:0}
  .service-image .img-placeholder{height:auto;aspect-ratio:16/9}
  .service-content h3{font-size:1.5rem}
  .process-flow{grid-template-columns:1fr;gap:24px}
  .process-flow .process-step::after{display:none}
  .process-flow .process-step::before{content:'\2193';display:block;font-size:1.2rem;color:var(--text-light);margin-bottom:8px}
  .process-flow .process-step:first-child::before{display:none}

  .mission-section,.representative-section,.team-section{padding:60px 0}
  .mission-visual{height:300px}
  .representative-image{height:300px}
  .values-grid{grid-template-columns:1fr}
  .team-bottom{grid-template-columns:1fr;gap:16px}

  .info-card{padding:32px 24px}
  .access-section{grid-template-columns:1fr;gap:40px;padding:60px 0}
  .map-placeholder{height:300px}
  .cta-section{padding:60px 0}

  .contact-section{padding:60px 0}
  .contact-form-wrapper{margin:0 auto 48px}
  .contact-form-card{padding:24px 16px;border-radius:var(--radius-md)}
  .form-row{grid-template-columns:1fr;gap:16px}
  .form-group input,
  .form-group select,
  .form-group textarea{width:100%;min-width:0;font-size:16px}

  .news-section{padding:60px 0}
  .news-list-page .news-item{grid-template-columns:1fr;gap:12px;padding:16px 0}
  .news-item-content{flex-direction:column;align-items:flex-start}
  .news-item-arrow{margin-left:0}

  .article-wrapper{padding:120px 0 60px}
  .article-title{font-size:1.4rem}
  .article-body{font-size:0.9rem}
}

@media(max-width:480px){
  .services-grid{grid-template-columns:1fr}
  .page-hero{padding:96px 0 40px}
  .data-table th,.data-table td{display:block;width:100%;padding:10px 16px}
  .data-table th{padding-bottom:2px}
  .data-table td{padding-top:2px}
}
