:root{--cream:#f8f5e9;--cream-dark:#eee9d6;--green:#456f62;--green-pale:#dce8da;--orange:#ed7355;--ink:#25342f;--muted:#66736d;--white:#fff;--radius:30px;--shadow:0 18px 45px rgba(60,78,67,.09);--width:min(1180px,calc(100% - 48px))}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:var(--ink);background:#fff;font:16px/1.85 "Noto Sans JP",sans-serif}a{color:inherit}img{display:block;max-width:100%}.svg-defs{position:absolute;width:0;height:0;overflow:hidden}.site-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;padding:16px max(24px,calc((100% - 1180px)/2));background:rgba(248,245,233,.94);border-bottom:1px solid rgba(237,115,85,.45);backdrop-filter:blur(14px)}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand strong,.brand small{display:block;letter-spacing:.12em}.brand strong{font-size:16px}.brand small{font-size:10px;color:var(--muted)}.robot-badge{display:grid;width:48px;height:48px;place-items:center;border-radius:16px;background:#fff}.robot-badge svg{width:38px;height:38px}.global-nav{display:flex;gap:22px}.global-nav a{text-decoration:none;font-size:14px;font-weight:700;color:var(--green)}.menu-button{display:none;border:0;background:none;color:var(--green);font-weight:700;letter-spacing:.12em}.hero{position:relative;width:var(--width);margin:32px auto 0}.hero-photo{min-height:680px;overflow:hidden;border-radius:70px 70px 70px 0;background:linear-gradient(90deg,rgba(19,34,29,.64),rgba(19,34,29,.06)),url("https://piof.net/assets/hero-office-edited.png") center/cover no-repeat}.hero-copy{padding:132px 7%;color:#fff}.eyebrow{margin:0 0 10px;color:var(--orange);font-size:12px;font-weight:700;letter-spacing:.22em}.hero h1{margin:0;font-size:clamp(46px,7vw,84px);font-weight:700;line-height:1.18;letter-spacing:.04em}.hero-sub{margin:34px 0 0;font-size:clamp(18px,2vw,24px);line-height:1.9}.guide-card{position:absolute;right:5%;bottom:-60px;display:flex;align-items:center;gap:18px;padding:20px 28px;border-radius:30px;background:var(--cream);box-shadow:var(--shadow)}.guide-card svg{width:72px;height:72px}.guide-card strong,.guide-card span{display:block}.guide-card span{margin-top:8px;color:var(--green);font-size:12px;letter-spacing:.16em}.section{width:var(--width);padding:140px 0 0}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:34px}.section-heading h2{margin:0;font-size:clamp(38px,5vw,62px);line-height:1.2}.section-heading>p{max-width:34em;margin:0;color:var(--muted)}.soft-line{width:50%;height:1px;background:var(--cream-dark)}.news-card{display:grid;grid-template-columns:150px 1fr;gap:24px;padding:28px 34px;border-radius:24px;background:var(--cream)}.news-card time{font-weight:700;color:var(--green)}.news-card p{margin:0}.feature-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:22px}.feature-card{overflow:hidden;border-radius:var(--radius);background:var(--cream);box-shadow:var(--shadow)}.photo-pair{display:grid;grid-template-columns:1fr 1fr;gap:4px}.photo-pair img{width:100%;height:280px;object-fit:cover}.feature-body{padding:30px}.feature-body h3,.service-card h3,.tiny-card h3,.company-card h3{margin:0 0 12px;font-size:24px;line-height:1.45}.feature-body p{margin:0 0 10px;color:var(--muted)}.text-link{display:inline-block;margin-top:14px;color:var(--green);font-weight:700;text-decoration:none}.text-link span,.button-link span{color:var(--orange)}.compact-card{display:flex;align-items:center}.services-section{margin-top:130px;padding-bottom:130px}.services-section:before{position:absolute;left:0;right:0;z-index:-1;height:1000px;margin-top:-90px;background:var(--cream);content:""}.card-grid{display:grid;gap:20px}.services-grid{grid-template-columns:repeat(3,1fr)}.service-card{overflow:hidden;border-radius:26px;background:#fff;box-shadow:var(--shadow)}.service-card img{width:100%;height:180px;object-fit:cover}.service-card div{padding:24px}.service-card span,.tiny-card span{color:var(--orange);font-size:12px;font-weight:700;letter-spacing:.16em}.service-card p,.tiny-card p{margin:0;color:var(--muted);font-size:14px}.text-service{display:flex;min-height:250px;align-items:end;background:var(--green-pale)}.tiny-heading{align-items:center}.speech{display:flex;align-items:center;gap:16px;padding:14px 20px;border-radius:24px;background:var(--green-pale);color:var(--green);font-size:13px;font-weight:700}.speech svg{width:58px;height:58px}.tiny-grid{grid-template-columns:repeat(3,1fr)}.tiny-card{overflow:hidden;border-radius:24px;background:#fff;box-shadow:var(--shadow);text-decoration:none;transition:transform .25s ease}.tiny-card:hover{transform:translateY(-7px)}.tiny-card img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:top}.tiny-card div{padding:20px}.tiny-card h3{margin:7px 0;font-size:18px}.company-section{padding-bottom:140px}.company-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}.company-photo{overflow:hidden;border-radius:var(--radius)}.company-photo img{width:100%;height:100%;object-fit:cover}.company-card{padding:34px;border-radius:var(--radius);background:var(--cream)}.company-card dl{display:grid;grid-template-columns:130px 1fr;gap:12px 14px;margin:0}.company-card dt{color:var(--green);font-size:13px;font-weight:700}.company-card dd{margin:0;font-size:14px}.button-link{display:inline-block;margin-top:24px;padding:13px 18px;border-radius:999px;background:#fff;color:var(--green);font-weight:700;text-decoration:none}.site-footer{padding:50px max(24px,calc((100% - 1180px)/2));background:var(--green);color:#fff}.footer-brand{display:flex;align-items:center;gap:12px}.footer-brand svg{width:50px;height:50px;padding:6px;border-radius:14px;background:#fff}.footer-brand strong,.footer-brand span{display:block}.footer-brand span,.site-footer small{opacity:.78;font-size:12px}.site-footer p{font-size:13px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.show{opacity:1;transform:none}
@media(max-width:900px){.site-header{flex-wrap:wrap}.menu-button{display:block}.global-nav{display:none;width:100%;padding:12px 0 2px;flex-wrap:wrap}.global-nav.open{display:flex}.hero-photo{min-height:560px;border-radius:48px 48px 48px 0}.feature-grid,.company-grid{grid-template-columns:1fr}.services-grid,.tiny-grid{grid-template-columns:repeat(2,1fr)}.company-photo{max-height:380px}.section{padding-top:110px}.services-section{margin-top:100px}}
@media(max-width:620px){:root{--width:min(100% - 28px,1180px)}.site-header{padding:12px 16px}.brand strong{font-size:13px}.hero{margin-top:14px}.hero-photo{min-height:520px;border-radius:34px 34px 34px 0;background-position:56% center}.hero-copy{padding:80px 7%}.hero h1{font-size:44px}.hero-sub{font-size:17px}.guide-card{right:12px;bottom:-44px;padding:14px 18px;border-radius:22px}.guide-card svg{width:52px;height:52px}.guide-card strong{font-size:13px}.section{padding-top:94px}.section-heading{display:block}.section-heading>p{margin-top:14px}.soft-line{display:block;width:100%;margin-top:20px}.news-card{display:block;padding:20px}.news-card p{margin-top:8px}.photo-pair img{height:170px}.feature-body{padding:22px}.services-grid,.tiny-grid{grid-template-columns:1fr}.services-section{padding-bottom:90px}.tiny-heading .speech{margin-top:20px}.company-section{padding-bottom:90px}.company-card{padding:22px}.company-card dl{display:block}.company-card dd{margin:2px 0 12px}.site-footer{padding:36px 18px}}
.robot-badge img{width:42px;height:42px;object-fit:contain}.guide-card img{width:84px;height:84px;object-fit:contain}.speech img{width:66px;height:66px;object-fit:contain}.footer-brand img{width:58px;height:58px;padding:4px;border-radius:14px;background:#fff;object-fit:contain}@media(max-width:620px){.guide-card img{width:60px;height:60px}}
html,body{overflow-x:hidden}
.section{margin-left:auto;margin-right:auto}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;width:min(1180px,100%);margin:0 auto}.site-header{padding:12px 24px}.pi-logo{width:70px;height:38px;object-fit:contain}.hero-photo{position:relative;background:linear-gradient(90deg,rgba(29,43,37,.58),rgba(29,43,37,.08) 58%,rgba(29,43,37,.02)),url("assets/hero-robots.png") center/cover no-repeat}.lab-monitor{position:absolute;top:28px;right:28px;display:grid;gap:7px;padding:15px 18px;border-radius:18px;background:rgba(255,252,244,.82);color:var(--ink);box-shadow:var(--shadow);backdrop-filter:blur(10px)}.lab-monitor time{font-family:monospace;font-size:18px;letter-spacing:.08em}.lab-monitor div{display:grid;grid-template-columns:58px 1fr;gap:10px;font-size:12px}.lab-monitor strong{color:var(--green);letter-spacing:.1em}.lab-monitor span{font-family:monospace}.campfire-scene{width:100%;overflow:hidden;background:#071b30}.campfire-scene img{width:100%;max-height:520px;object-fit:cover;object-position:center}.footer-inner{width:min(1180px,100%);margin:0 auto}.footer-brand img{width:86px;height:44px;padding:5px 8px;background:#fff}.site-footer{padding:42px 24px}
@media(max-width:900px){.header-inner{flex-wrap:wrap}.lab-monitor{top:18px;right:18px;padding:10px 12px}.lab-monitor time{font-size:14px}.lab-monitor div{font-size:10px}}
@media(max-width:620px){.site-header{padding:10px 16px}.pi-logo{width:54px;height:30px}.lab-monitor{top:14px;right:14px;gap:4px;padding:8px 9px;border-radius:12px}.lab-monitor time{font-size:11px}.lab-monitor div{grid-template-columns:45px 1fr;gap:5px;font-size:9px}.hero-copy{padding-top:150px}.campfire-scene img{min-height:210px;object-fit:cover}.footer-brand img{width:70px;height:38px}}
