/* THE PORT風に抽象化した、非士業向けコーポレートサイトCSS */
:root{--black:#0d0f14;--ink:#171a22;--ink-soft:#424957;--white:#fff;--smoke:#f5f6f3;--mist:#ecefea;--line:rgba(13,15,20,.13);--blue:#2563eb;--cyan:#00b7c7;--lime:#d6ff48;--grad:linear-gradient(135deg,#2563eb 0%,#00b7c7 55%,#d6ff48 120%);--inner:min(1120px,calc(100vw - 48px));--radius:28px;--shadow:0 24px 80px rgba(13,15,20,.14);--font-sans:"Inter","Helvetica Neue",Arial,"Noto Sans JP",sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);color:var(--ink);background:var(--smoke);line-height:1.8}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}.site-header{position:fixed;inset:0 0 auto 0;z-index:50;transition:background .3s,border .3s,color .3s;color:var(--white)}.site-header.is-scrolled,.site-header.is-open{background:rgba(255,255,255,.9);backdrop-filter:blur(18px);color:var(--ink);border-bottom:1px solid rgba(13,15,20,.08)}.site-header__inner{width:var(--inner);margin:0 auto;min-height:76px;display:flex;align-items:center;gap:30px}.site-logo{margin-right:auto;display:inline-flex;align-items:center}.global-nav{display:flex;gap:28px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.global-nav a{opacity:.85}.global-nav a:hover{opacity:1}.header-contact{padding:11px 20px;border:1px solid currentColor;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.08em}.menu-button{display:none}.drawer-nav{display:none}.section{padding:clamp(92px,12vw,160px) 0}.section__inner{width:var(--inner);margin:0 auto}.section-dark{color:var(--white);background:var(--black)}.section-muted{background:var(--mist)}.eyebrow{margin:0 0 18px;display:inline-flex;align-items:center;gap:9px;color:var(--cyan);font-size:12px;font-weight:900;letter-spacing:.2em;text-transform:uppercase}.eyebrow:before{content:"";width:26px;height:2px;background:currentColor;display:inline-block}h1,h2,h3,p{margin-top:0}h2{font-size:clamp(36px,6vw,82px);line-height:1.06;letter-spacing:-.06em;margin-bottom:28px}.hero{position:relative;min-height:100svh;display:grid;align-items:center;overflow:hidden;isolation:isolate}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 30%,rgba(0,183,199,.35),transparent 35%),radial-gradient(circle at 18% 70%,rgba(37,99,235,.55),transparent 38%);z-index:-2}.hero__bg-word{position:absolute;right:-4vw;bottom:4vh;color:rgba(255,255,255,.05);font-size:clamp(120px,24vw,420px);font-weight:900;letter-spacing:-.12em;line-height:.8;z-index:-1}.hero__grid{width:var(--inner);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,8vw,110px);align-items:center;padding-top:78px}.hero h1{font-size:clamp(74px,12vw,170px);line-height:.82;letter-spacing:-.1em;margin:0 0 36px}.hero h1 span{display:block}.hero__lead{max-width:620px;color:rgba(255,255,255,.78);font-size:clamp(16px,1.4vw,19px)}.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}.hero__visual img{width:min(520px,100%);margin-left:auto;filter:drop-shadow(0 30px 90px rgba(0,0,0,.35))}.scroll-sign{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);font-size:11px;font-weight:800;letter-spacing:.3em;opacity:.75}.scroll-sign:before{content:"";display:block;width:1px;height:48px;background:rgba(255,255,255,.5);margin:0 auto 12px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 24px;border-radius:999px;font-size:13px;font-weight:900;letter-spacing:.08em;transition:transform .25s,box-shadow .25s,background .25s}.button:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.button--light{background:var(--white);color:var(--ink)}.button--outline-light{border:1px solid rgba(255,255,255,.45);color:var(--white)}.button--dark{background:var(--ink);color:var(--white)}.news-strip{background:var(--white);border-bottom:1px solid var(--line)}.news-strip__inner{width:var(--inner);margin:0 auto;padding:28px 0;display:grid;grid-template-columns:86px 1fr 88px;gap:28px;align-items:start}.section-label{font-size:12px;font-weight:900;letter-spacing:.18em;color:var(--blue)}.news-list{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:14px}.news-list li{display:grid;grid-template-columns:104px 1fr;gap:18px}.news-list time{color:var(--ink-soft);font-size:12px;font-weight:800}.text-link{color:var(--blue);font-size:12px;font-weight:900;letter-spacing:.12em}.purpose__grid,.strategy__grid,.company__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(36px,8vw,110px);align-items:center}.purpose__image,.strategy-card,.company-list,.contact-card{border-radius:var(--radius);box-shadow:var(--shadow)}.purpose__image{overflow:hidden;background:#10131b}.purpose__content p,.strategy__content p,.company__content p{color:var(--ink-soft);max-width:620px}.strategy-card{background:var(--white);overflow:hidden}.strategy-card__body{padding:28px}.strategy-card__body span{color:var(--blue);font-weight:900;letter-spacing:.14em}.strategy-card__body h3{font-size:28px;line-height:1.15;margin:12px 0 10px;letter-spacing:-.04em}.strategy-card__body p{color:var(--ink-soft);margin:0}.section-heading{text-align:center;max-width:700px;margin:0 auto 56px}.section-heading p:not(.eyebrow){color:var(--ink-soft)}.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.service-card{min-height:480px;background:var(--white);border:1px solid rgba(13,15,20,.08);border-radius:var(--radius);overflow:hidden;box-shadow:0 16px 50px rgba(13,15,20,.08);display:flex;flex-direction:column}.service-card img{width:100%;aspect-ratio:16/11;object-fit:cover;background:var(--ink)}.service-card div{padding:28px}.service-card span{color:var(--blue);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.service-card h3{font-size:26px;line-height:1.18;letter-spacing:-.04em;margin:12px 0 14px}.service-card p{color:var(--ink-soft);margin-bottom:0}.impact{padding:clamp(90px,12vw,150px) 0;position:relative;overflow:hidden}.impact:before{content:"IMPACT";position:absolute;right:-2vw;top:0;color:rgba(255,255,255,.05);font-size:clamp(92px,16vw,250px);font-weight:900;letter-spacing:-.1em}.impact__head{margin-bottom:48px}.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.impact-card{border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);border-radius:var(--radius);padding:34px;backdrop-filter:blur(12px)}.impact-card strong{display:block;font-size:clamp(52px,7vw,100px);line-height:1;letter-spacing:-.08em}.impact-card span{display:block;color:var(--lime);font-size:13px;font-weight:900;letter-spacing:.18em;margin:12px 0;text-transform:uppercase}.impact-card p{color:rgba(255,255,255,.72);margin:0}.company-list{background:var(--white);padding:12px 30px}.company-list div{display:grid;grid-template-columns:130px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--line)}.company-list div:last-child{border-bottom:0}.company-list dt{color:var(--blue);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.company-list dd{margin:0;font-weight:700}.contact{background:var(--smoke)}.contact-card{background:var(--grad);color:var(--white);padding:clamp(36px,7vw,84px);position:relative;overflow:hidden}.contact-card:after{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.18)}.contact-card p:not(.eyebrow){max-width:640px;color:rgba(255,255,255,.82)}.site-footer{background:#080a10;color:rgba(255,255,255,.72);padding:56px 0}.site-footer__inner{width:var(--inner);margin:0 auto;display:grid;gap:28px}.site-footer nav{display:flex;flex-wrap:wrap;gap:22px;font-size:12px;font-weight:800;letter-spacing:.08em}.site-footer small{font-size:12px;color:rgba(255,255,255,.48)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s,transform .75s}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.12s}.reveal-delay-2{transition-delay:.24s}@media (max-width:900px){:root{--inner:min(100% - 28px,720px)}.global-nav,.header-contact{display:none}.menu-button{display:inline-grid;place-items:center;width:44px;height:44px;border:1px solid currentColor;border-radius:999px;background:transparent;color:inherit}.menu-button span{width:18px;height:2px;background:currentColor;display:block;transition:transform .25s}.menu-button span+span{margin-top:-10px}.site-header.is-open .menu-button span:first-child{transform:translateY(4px) rotate(45deg)}.site-header.is-open .menu-button span:last-child{transform:translateY(-4px) rotate(-45deg)}.drawer-nav{display:none;width:var(--inner);margin:0 auto 18px;padding:18px;background:var(--white);color:var(--ink);border-radius:18px;box-shadow:var(--shadow)}.site-header.is-open .drawer-nav{display:grid;gap:14px}.hero__grid,.purpose__grid,.strategy__grid,.company__grid{grid-template-columns:1fr}.hero{min-height:auto;padding:120px 0 76px}.hero__visual img{margin:0}.news-strip__inner{grid-template-columns:1fr;gap:14px}.news-list li{grid-template-columns:1fr;gap:4px}.service-grid,.impact-grid{grid-template-columns:1fr}.company-list div{grid-template-columns:1fr;gap:8px}}@media (max-width:520px){.hero h1{font-size:clamp(58px,20vw,86px)}h2{font-size:clamp(34px,12vw,54px)}.button{width:100%}.hero__actions{width:100%}.service-card{min-height:auto}}